一、背景
项目关键依赖:
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的使用成本很高,而且也很复杂,在非必要的时候,应该考虑更轻量级的调度库。