Celery Filas de Tarefas Assíncronas

Celery é um sistema de filas para processamento assíncrono.
Ele executa tarefas em segundo plano fora do ciclo principal.
Primeiramente, Celery usa um broker (Redis ou RabbitMQ) para comunicação.
Por exemplo, você envia um e-mail sem bloquear a resposta HTTP.
Além disso, Celery escala horizontalmente com muitos workers.
A voz passiva é usada aqui: “as tarefas são enfileiradas e processadas depois”.
Quando utilizar Celery? Em operações demoradas e assíncronas.
Por exemplo, processamento de imagens, envio de e-mails ou web scraping.
Também em tarefas periódicas (cron jobs) e pipelines de dados.
Vamos explorar conceitos, instalação e exemplos práticos.
Três subtítulos guiarão você pelo universo Celery.
Ao final, você implementará filas robustas em seus projetos.

Conceitos fundamentais: broker, worker e tasks

O broker é o intermediário entre produtores e consumidores.
Redis e RabbitMQ são os brokers mais comuns para Celery.
Workers são processos que executam as tarefas da fila.
Tasks são funções decoradas com @app.task.
Quando usar cada componente? Broker para comunicação entre serviços.
Worker para processamento paralelo de tarefas.
A voz passiva é aplicada: “as tarefas são serializadas em JSON”.
Exemplo básico de configuração e tarefa Celery:

O worker precisa estar rodando para executar as tarefas.
O comando celery -A tasks worker inicia o worker.

Enfileirando e monitorando tarefas

Para enfileirar uma tarefa, use o método .delay().
Ele retorna um objeto AsyncResult para acompanhamento.
Use .get() para aguardar o resultado (bloqueante).
Use .ready() para verificar se a tarefa terminou.
Quando usar essas funções? Em aplicações web assíncronas.
Também em scripts que precisam monitorar progresso.
A voz passiva é aplicada: “os resultados são armazenados no backend”.
Exemplo de enfileiramento e monitoramento:

O método .s() cria uma assinatura de tarefa.
Assinaturas permitem composição e encadeamento.

Celery para tarefas periódicas (celery beat)

Celery Beat é o scheduler para tarefas periódicas.
Ele enfileira tarefas em intervalos regulares automaticamente.
Quando usar Beat? Em backups, limpeza de dados ou relatórios.
Por exemplo, enviar relatório todo dia às 8h.
A voz passiva é aplicada: “os intervalos são definidos no arquivo de configuração”.
Exemplo de configuração de tarefas periódicas:

Para rodar o Beat: celery -A tasks beat --loglevel=info.
Para rodar worker: celery -A tasks worker --loglevel=info.
A fórmula de throughput da fila:
\(T = \frac{N_{\text{tarefas}}}{N_{\text{workers}} \times \text{velocidade}}\)
Celery é essencial para aplicações web robustas.
Comece com tarefas simples e evolua para workflows complexos.
Sua aplicação ficará mais rápida e responsiva.

Deixe um comentário