Skip to content
/ lasagna Public

A Docker Compose template that builds a interactive development environment for PySpark with Jupyter Lab, MinIO as object storage, Hive Metastore, Trino and Kafka

Notifications You must be signed in to change notification settings

gmrqs/lasagna

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

33 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

alt text Ou pastabricks, se preferir, é um ambiente de desenvolvimento interativo que criei para praticar PySpark

Montado utilizando Docker Compose ele estrutura um Jupyter Lab, Cluster Spark, MinIO object storage, Hive Metastore, Trino e de quebra vem um Kafka pra simular eventos/streaming.

Requisitos:

  • Docker Desktop
  • Docker Compose

Para utilizá-lo basta clonar o repositório e executar no diretório principal o comando:

docker compose up -d

o docker vai buildar as imagens sozinho, recomendo uma conexão de internet estável

Utilize o comando abaixo para obter o link do Jupyter Lab.

 docker logs workspace 2>&1 | grep http://127.0.0.1

(se preferir pode ver nos logs do Docker Desktop também)

Clique no link http://127.0.0.1:8888/lab?token=<token_gigante_super_seguro>

Para iniciar o broker kafka você deve ir até o diretório kafka desse repositório e executar:

docker compose up -d

O que é criado?

alt text

Os template docker-compose.yml criam uma série de containers, entre eles:

Workspace

Um cliente Jupyter Lab para sessões de desenvolvimento interativo com:

  • Diretório work para persistir scripts e notebooks criados;
  • Configuração spark-defaults.conf para facilitar configuração das SparkSessions no cluster;
  • Kernels dedicados para PySpark com Hive, Iceberg ou Delta

⚠️ Utilize o magic %SparkSession para configurar a Spark Session

alt text

  • Extensão jupyter_sql_editor instalada para execução de SQL diretamente do notebook usando dos comandos magic %sparksql e %trino
  • Extensão jupyterlab_s3_browser para acessar os buckets MinIO direto do Jupyter Lab

MinIO

Uma instância do MinIO, serviço de object storage que emula o funcionamento de um S3 com:

  • Interface web acessivel em localhost:9090
  • API para protocolo s3a na porta 9000
  • Diretório mount/minio e mount/minio-config para persistir dados entre sessões

Standalone Spark Cluster

Um cluster Spark para processamento dos workloads contendo:

  • 1 Master node (master na porta 7077, web-ui em localhost:5050)
  • 2 Worker node (web-ui em localhost:5051 e localhost:5052)
  • Dependências necessárias para conexão com o MinIO já instaladas nas imagens
  • Comunicação com MinIO através da porta 9000

Hive Standalone Metastore

Uma instância do Hive Standalone Metastore utilizando PostgreSQL no back-end para permitir a persistencia de metadados.

  • Diretório mount/postgres para persistir tabelas entre sessões de desenvolvimento
  • Comunicação com o cluster Spark através do Thrift na porta 9083
  • Comunicação com o PostgresSQL através de JDBC na porta 5432

Trino

Uma instância unica de Trino para servir de motor de query. Já integrado com Hive Metastore e MinIO

  • Catálogos Hive, Delta e Iceberg já configurados. Toda tabela criada via PySpark será acessível no Trino
  • Serviço disponível na porta padrão 8080

Kafka

Docker compose de uma instancia zookeper + single-node de kafka para criação de um stream de dados fictício com um producer em Python.

  • Utiliza a mesma network criado pelo compose do PySpark.
  • Script de kafka-producer disponível utilizando Faker para gerar eventos aleatórios no kafka
  • Acessivel através do kafka:29092

About

A Docker Compose template that builds a interactive development environment for PySpark with Jupyter Lab, MinIO as object storage, Hive Metastore, Trino and Kafka

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published