kar*_*tik 5 django heroku redis celery django-celery
在我的本地环境中,我将 celery 用于计划任务,它在本地系统中工作我使用 redis 作为工作人员,现在我想在 heroku 服务器中配置 django celery 我尝试在 heroku 应用程序中使用 heroku-redis 附加组件
在我的 settings.py 中添加了这些东西:
r = redis.from_url(os.environ.get("REDIS_URL"))
BROKER_URL = redis.from_url(os.environ.get("REDIS_URL"))
CELERY_RESULT_BACKEND = os.environ.get('REDIS_URL')
CELERY_ACCEPT_CONTENT = ['application/json']
CELERY_TASK_SERIALIZER = 'json'
CELERY_RESULT_SERIALIZER = 'json'
CELERY_TIMEZONE = 'Canada/Eastern'
redis_url = urlparse.urlparse(os.environ.get('REDIS_URL'))
CACHES = {
"default": {
"BACKEND": "redis_cache.RedisCache",
"LOCATION": "{0}:{1}".format(redis_url.hostname, redis_url.port),
"OPTIONS": {
"PASSWORD": redis_url.password,
"DB": 0,
}
}
}
Run Code Online (Sandbox Code Playgroud)
在我的 procfile 之后,我添加了:
web: gunicorn bizbii.wsgi --log-file -
worker : celery workder -A tasks.app -l INFO
python manage.py celeryd -v 2 -B -s celery -E -l INFO
Run Code Online (Sandbox Code Playgroud)
但任务仍然没有运行
之后,我运行日志命令,使其返回:
2016-07-30T08:53:19+00:00 app[heroku-redis]: source=REDIS sample#active-connections=1 sample#load-avg-1m=0.07 sample#load-avg-5m=0.075 sample#load-avg-15m=0.07 sample#read-iops=0 sample#write-iops=0 sample#memory-total=15664876.0kB sample#memory-free=13426732.0kB sample#memory-cached=460140kB sample#memory-redis=299616bytes sample#hit-rate=1 sample#evicted-keys=0
Run Code Online (Sandbox Code Playgroud)
之后,使用以下命令创建 dyno:
heroku run bash -a bizbii2
Run Code Online (Sandbox Code Playgroud)
并运行以下命令:
python manage.py celeryd -v 2 -B -s celery -E -l INFO
Run Code Online (Sandbox Code Playgroud)
所以它返回错误,如:
[2016-08-03 08:23:26,506: ERROR/Beat] beat: Connection error: [Errno 111] Connection refused. Trying again in 8.0 seconds...
[2016-08-03 08:23:26,843: ERROR/MainProcess] consumer: Cannot connect to amqp://guest:**@127.0.0.1:5672//: [Errno 111] Connection refused.
Trying again in 8.00 seconds...
Run Code Online (Sandbox Code Playgroud)
请给我建议我们如何在 heroku 服务器上部署 celery
我有这个确切的问题。我用以下行更新了我的 procfile,错误消失了:
worker: celery -A TASKFILE worker -B --loglevel=info
Run Code Online (Sandbox Code Playgroud)
将 TASKFILE 替换为例如:proj.celery或proj.tasks。这取决于您将任务放在哪里。
| 归档时间: |
|
| 查看次数: |
4996 次 |
| 最近记录: |