【发布时间】:2021-10-04 12:15:28
【问题描述】:
我在 pythonanuwhere 上部署了我的 Django 应用程序,并希望将一个文件添加到计划任务中。但它给了我一个错误:
django.core.exceptions.ImproperlyConfigured:请求设置 LOGGING_CONFIG,但未配置设置。您必须在访问设置之前定义环境变量 DJANGO_SETTINGS_MODULE 或调用 settings.configure()。
我试过这个:
os.environ.setdefault('DJANGO_SETTING_MODULE', 'smsreminder.settings')
django.setup()
结果相同,但与 django.setup() 一致 我要执行的文件中的脚本:
import datetime
from django_common.auth_backends import User
from reminder.models import Remind
from twilio.base.exceptions import TwilioRestException
from twilio.rest import Client
def my_scheduled_job():
content = Remind.objects.all()
account_sid = "--------------------------"
auth_token = "--------------------------"
for smscontent in content:
if smscontent.remind_date == datetime.today().date():
tempusers = User.objects.filter(username=smscontent.author)
for recipient in tempusers:
try:
client = Client(account_sid, auth_token)
message = client.messages.create(
body="I just want to remind, that you have some task for today {date}: {task}. {time} is the deadline!".format(
date=str(smscontent.remind_date), task=str(smscontent.title),
time=str(smscontent.remind_time)),
to=str(recipient.username),
from_="+18568889437")
print(message.sid)
except TwilioRestException:
pass
return
错误:
Traceback (most recent call last):
File "/home/remindmy/sms-reminder/reminder/cron.py", line 3, in <module>
from django_common.auth_backends import User
File "/home/remindmy/.virtualenvs/remindervenv/lib/python3.9/site-packages/django_common/auth_backends.py", line 6, in <module>
from django.contrib.auth.backends import ModelBackend
File "/home/remindmy/.virtualenvs/remindervenv/lib/python3.9/site-packages/django/contrib/auth/backends.py", line 2, in <module>
from django.contrib.auth.models import Permission
File "/home/remindmy/.virtualenvs/remindervenv/lib/python3.9/site-packages/django/contrib/auth/models.py", line 3, in <module>
from django.contrib.auth.base_user import AbstractBaseUser, BaseUserManager
File "/home/remindmy/.virtualenvs/remindervenv/lib/python3.9/site-packages/django/contrib/auth/base_user.py", line 48, in <module>
class AbstractBaseUser(models.Model):
File "/home/remindmy/.virtualenvs/remindervenv/lib/python3.9/site-packages/django/db/models/base.py", line 108, in __new__
app_config = apps.get_containing_app_config(module)
File "/home/remindmy/.virtualenvs/remindervenv/lib/python3.9/site-packages/django/apps/registry.py", line 253, in get_containing_app_config
self.check_apps_ready()
File "/home/remindmy/.virtualenvs/remindervenv/lib/python3.9/site-packages/django/apps/registry.py", line 135, in check_apps_ready
settings.INSTALLED_APPS
File "/home/remindmy/.virtualenvs/remindervenv/lib/python3.9/site-packages/django/conf/__init__.py", line 82, in __getattr__
self._setup(name)
File "/home/remindmy/.virtualenvs/remindervenv/lib/python3.9/site-packages/django/conf/__init__.py", line 63, in _setup
raise ImproperlyConfigured(
django.core.exceptions.ImproperlyConfigured: Requested setting INSTALLED_APPS, but settings are not configured. You must either define the environment variable DJANGO_SETTINGS_MODULE or call settings.co
nfigure() before accessing settings.
【问题讨论】:
-
虽然可以按照您尝试的方式在计划任务中运行 Django 代码,但您需要注意多个问题(例如确保路径是设置正确,导入顺序正确等),因此建议编写管理命令并将其作为计划任务运行。
-
这里是一个关于创建管理命令的 Django 文档的链接,如果有用的话:docs.djangoproject.com/en/3.2/howto/custom-management-commands
标签: python django virtualenv pythonanywhere