Bootstrap

【celery踩坑】celery因为版本不同,导致broker报错

一、背景

项目关键依赖:
fastapi==0.100.1
celery==4.4.7

celery启动命令:

celery worker -A xxx.celery -P eventlet -c 100 -l INFO --logfile=celery.log -D

在docker启动项目时,即使celery的配置正常,celery配置的broker_url没有问题,也会报错:

[2024-02-06 15:21:13,678: ERROR/MainProcess] consumer: Cannot connect to amqp://guest:**@127.0.0.1:5672//: [Errno 111] ECONNREFUSED.
Trying again in 10.00 seconds... (5/100)

到容器中,直接打印celery的配置,broker_url是正确的,但是依然是会报这个错

二、解决措施

改过celery的启动命令,最初以为是-P的问题,但是换了threads、gevent、solo都没用,rabbitmq的url还是错的。
改过broker_url,写死成redis的url,还是不行

最终,我看了一下老项目,发现celery的版本有差别,以前用的是celery4.4.0,直接把celery的版本换成4.4.0,然后就可以了

虽然解决了问题,但是原因没找到,如果各位知道原因,请留言,万分感谢!!!

三、思考

在使用celery的过程中,经常会出现一些版本或者配置问题,虽然很细小,但是每次解决都要话费大量的时间和精力,。
技术角度和使用成本上看,celery的使用成本很高,而且也很复杂,在非必要的时候,应该考虑更轻量级的调度库。

;