Ошибка в запланированных задачах: «django.core.исключения.Неправильно настроено: Запрошена настройка LOGGING_CONFIG, но параметры не настроены.’

#python #django #virtualenv #pythonanywhere

Вопрос:

Я развернул свое приложение Django на pythonanuwhere и хочу добавить один файл в запланированные задачи. Но это дает мне ошибку:

django.ядро.исключения.Неправильно настроено: Запрошена настройка 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.
 

Комментарии:

1. Хотя это возможно для запуска кода Django внутри запланированной задачи так, как вы пытаетесь это сделать, есть несколько проблем, о которых вам нужно позаботиться (например, убедиться, что путь задан правильно, что импорт выполнен в правильном порядке и т. Д.), Поэтому рекомендуется скорее написать команду управления и запустить ее как запланированную задачу.

2. Вот ссылка на документы Django по созданию команд управления, если это полезно: docs.djangoproject.com/en/3.2/howto/custom-management-commands

Ответ №1:

Сегодня я столкнулся с той же проблемой:

Как предполагает ошибка

 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.
 

НАСТРОЙКА S, а не НАСТРОЙКА. Таким образом, вам просто нужно обновить свой исходный код с заглавной буквы S

 os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'smsreminder.settings')
django.setup()