B站Django项目天天生鲜学习|celery异步发送邮件遇到的问题

环境:win10,Python3.7,Django2.2.15,celery4.3.0

django.core.exceptions.ImproperlyConfigured: Requested setting EMAIL_FROM, but 
settings are not configured. You must either define the environment variable 
DJANGO_SETTINGS_MODULE or call settings.configure() before accessing settings.

解决办法:在当前views中最前面加入"DJANGO_SETTINGS_MODULE"相关配置信息

import os

# 在任务处理者加这一句,broker和worker在同一台机子上则需要加上本段代码
import django
os.environ.setdefault("DJANGO_SETTINGS_MODULE","dailyfresh.settings")
django.setup()

安装eventlet

D:\PycharmProjects\dailyfresh>pip install eventlet

重启worker

D:\PycharmProjects\dailyfresh>celery -A celery_tasks.tasks worker -l info -P eventlet

启动之后是这个样子

[tasks]
  . celery_tasks.tasks.send_register_active_email

[2022-04-01 08:55:06,199: INFO/MainProcess] Connected to redis://127.0.0.1:6379/8
[2022-04-01 08:55:06,219: INFO/MainProcess] mingle: searching for neighbors
[2022-04-01 08:55:07,265: INFO/MainProcess] mingle: all alone
[2022-04-01 08:55:07,279: INFO/MainProcess] pidbox: Connected to redis://127.0.0.1:6379/8.
[2022-04-01 08:55:07,282: WARNING/MainProcess] d:\program files\python3.7\lib\site-packages\celery\fixups\django.py:202: UserWarning: Using settings.DEBUG leads to a memory leak, never use this setting in production environments!
  warnings.warn('Using settings.DEBUG leads to a memory leak, never '
[2022-04-01 08:55:07,283: INFO/MainProcess] celery@DESKTOP-A7EPP6R ready.

中间有段warning不用管,直接发送就行,完成~

[2022-04-01 08:55:52,612: INFO/MainProcess] Received task: celery_tasks.tasks.send_register_active_email[0f7c4d89-9d05-4b47-8264-dc2a0e4c3961]
[2022-04-01 08:55:57,239: INFO/MainProcess] Task celery_tasks.tasks.send_register_active_email[0f7c4d89-9d05-4b47-8264-dc2a0e4c3961] succeeded in 4.625s: None

查了挺多资料的,引用了网友文章中的内容,但是太多了,链接找不见了,如有侵权请告知删除。

猜你喜欢

转载自blog.csdn.net/xiaoluobotm/article/details/123890798
今日推荐