在 Linux 上实现 Celery 的负载均衡,你需要遵循以下步骤:
-
安装 Celery:
使用 pip 安装 Celery:
pip install celery
-
创建一个 Celery 实例:
在你的项目中创建一个名为
celery.py
的文件,然后添加以下代码:from celery import Celery app = Celery('myapp', broker='pyamqp://guest@localhost//', backend='rpc://', include=['myapp.tasks']) if __name__ == '__main__': app.start()
这里,我们创建了一个名为
myapp
的 Celery 实例,使用 RabbitMQ 作为消息代理(broker),并将任务结果存储在 RPC 后端。你需要根据你的实际情况修改 broker 和 backend 的 URL。 -
定义任务:
在你的项目中创建一个名为
tasks.py
的文件,然后定义一些任务。例如:from myapp.celery import app @app.task def add(x, y): return x + y @app.task def mul(x, y): return x * y
-
配置负载均衡器:
为了实现负载均衡,你需要配置一个负载均衡器,例如使用 Nginx。首先,安装 Nginx:
sudo apt-get install nginx
然后,编辑 Nginx 配置文件(通常位于
/etc/nginx/nginx.conf
或/etc/nginx/sites-available/default
),添加以下内容:http { upstream celery_workers { server worker1.example.com; server worker2.example.com; server worker3.example.com; } server { location / { proxy_pass http://celery_workers; } } }
这里,我们创建了一个名为
celery_workers
的上游服务器组,包含三个 Celery worker。然后,我们将请求代理到这个组。 -
运行 Celery worker:
在每个 worker 节点上,运行以下命令启动 Celery worker:
celery -A myapp worker --loglevel=info
-
启动 Nginx:
使用以下命令启动 Nginx:
sudo service nginx start
现在,你已经在 Linux 上实现了 Celery 的负载均衡。当你向 Nginx 发送任务请求时,Nginx 会将请求分发到其配置的 Celery worker 上,从而实现负载均衡。