celery AttributeError: 'str' object has no attribute 'items' django Day14

使用Celery结合Redis实现邮件发送功能,解决因Redis版本过高导致的错误。通过降级Redis版本至2.10.6,成功修复AttributeError异常,实现任务队列中邮件的正常发送。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

用celery实现发送邮件的功能,用redis作为中间人。

可以正常启动celery,但是一旦用celery发送邮件,就会报错并退出:

[2018-12-28 13:49:14,636: ERROR/MainProcess] Unrecoverable error: AttributeError("'str' object has no attribute 'items'",)
Traceback (most recent call last):
  File "/home/python/.virtualenvs/django_class/lib/python3.5/site-packages/celery/worker/__init__.py", line 206, in start
    self.blueprint.start(self)
  File "/home/python/.virtualenvs/django_class/lib/python3.5/site-packages/celery/bootsteps.py", line 123, in start
    step.start(parent)
  File "/home/python/.virtualenvs/django_class/lib/python3.5/site-packages/celery/bootsteps.py", line 374, in start
    return self.obj.start()
  File "/home/python/.virtualenvs/django_class/lib/python3.5/site-packages/celery/worker/consumer.py", line 280, in start
    blueprint.start(self)
  File "/home/python/.virtualenvs/django_class/lib/python3.5/site-packages/celery/bootsteps.py", line 123, in start
    step.start(parent)
  File "/home/python/.virtualenvs/django_class/lib/python3.5/site-packages/celery/worker/consumer.py", line 884, in start
    c.loop(*c.loop_args())
  File "/home/python/.virtualenvs/django_class/lib/python3.5/site-packages/celery/worker/loops.py", line 76, in asynloop
    next(loop)
  File "/home/python/.virtualenvs/django_class/lib/python3.5/site-packages/kombu/async/hub.py", line 340, in create_loop
    cb(*cbargs)
  File "/home/python/.virtualenvs/django_class/lib/python3.5/site-packages/kombu/transport/redis.py", line 1019, in on_readable
    self._callbacks[queue](message)
  File "/home/python/.virtualenvs/django_class/lib/python3.5/site-packages/kombu/transport/virtual/__init__.py", line 534, in _callback
    self.qos.append(message, message.delivery_tag)
  File "/home/python/.virtualenvs/django_class/lib/python3.5/site-packages/kombu/transport/redis.py", line 146, in append
    pipe.zadd(self.unacked_index_key, delivery_tag, time()) \
  File "/home/python/.virtualenvs/django_class/lib/python3.5/site-packages/redis/client.py", line 2263, in zadd
    for pair in iteritems(mapping):
  File "/home/python/.virtualenvs/django_class/lib/python3.5/site-packages/redis/_compat.py", line 123, in iteritems
    return iter(x.items())
AttributeError: 'str' object has no attribute 'items'


查了好久发现原来是因为以前下的redis版本过高(   3.0.1   ),重装redis 

pip install redis==2.10.6

就可以发送邮件了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值