Uwsgi:不能将Django的设置作为包使用

2024-05-17 19:41:25 发布

您现在位置:Python中文网/ 问答频道 /正文

我尝试使用包分割django的设置,这在this文章中印象深刻。在

我的问题是uwsgi不认识我的项目.设置包裹。在

【一些歌词】 与机密.py我稍微修改了结构,所以除了机密.py存储在github中,并且秘密.py由ansible管理。

所以我现在的设置是一个具有以下结构的包:

project/
├── manage.py
└── project
    ├── __init__.py
    ├── settings
    │   ├── __init__.py
    │   ├── defaults.py
    │   ├── development.py
    │   ├── production.py
    │   ├── staging.py
    │   └── secrets.py
    ├── urls.py
    └── wsgi.py

重要文件内容:

设置

^{pr2}$

设置/开发.py

from .defaults import *

DEBUG = True

INSTALLED_APPS += (
    'debug_toolbar',
)

设置/默认值.py

import os
import secrets

SECRET_KEY = secrets.SECRET_KEY

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.postgresql_psycopg2',
        'NAME': secrets.DATABASE_NAME,
        'USER': secrets.DATABASE_USER,
        'PASSWORD': secrets.DATABASE_PASSWORD,
        'HOST': 'localhost',
        'PORT': '',
    }
}

# and so on, almost default

设置/机密.py

SECRET_KEY = '1YdCOUsWeKk&BWDa$PI6X1@IdUH5vjkjcB^v&k3J@*fRRVRPrW'

DATABASE_NAME = 'mydb'
DATABASE_USER = 'myuser'
DATABASE_PASSWORD = '1l3S7KURpd1MYPOr'

DJANGO_环境

$ echo $DJANGO_ENVIRONMENT
development

-------------------------------------------------------------------------------

在这一点上,我可以开始manage runserver和{},没有问题:

$ python manage.py check
System check identified no issues (0 silenced).

但是,如果我试着用UWSGI,我就得到了UWSGI的错误-错误.log(我的项目名称是pdfupload):

[uwsgi-daemons] respawning "python /home/vagrant/pdfupload/manage.py rqworker default" (uid: 1000 gid: 1000)
Traceback (most recent call last):
  File "/home/vagrant/pdfupload/manage.py", line 10, in <module>
    execute_from_command_line(sys.argv)
  File "/usr/local/lib/python2.7/dist-packages/django/core/management/__init__.py", line 338, in execute_from_command_line
    utility.execute()
  File "/usr/local/lib/python2.7/dist-packages/django/core/management/__init__.py", line 330, in execute
    self.fetch_command(subcommand).run_from_argv(self.argv)
  File "/usr/local/lib/python2.7/dist-packages/django/core/management/__init__.py", line 182, in fetch_command
    settings.INSTALLED_APPS
  File "/usr/local/lib/python2.7/dist-packages/django/conf/__init__.py", line 48, in __getattr__
    self._setup(name)
  File "/usr/local/lib/python2.7/dist-packages/django/conf/__init__.py", line 44, in _setup
    self._wrapped = Settings(settings_module)
  File "/usr/local/lib/python2.7/dist-packages/django/conf/__init__.py", line 113, in __init__
    raise ImproperlyConfigured("The SECRET_KEY setting must not be empty.")
django.core.exceptions.ImproperlyConfigured: The SECRET_KEY setting must not be empty.

显然,由于导入错误,uwsgi无法读取django的设置。在

有uwsgi.ini文件公司名称:

[uwsgi]
chdir=/home/vagrant/pdfupload
master=True
disable-logging=False
chmod-socket = 777
chown-socket = vagrant

logto      = /home/vagrant/log/uwsgi.log
req-logger = file:/home/vagrant/log/uwsgi-access.log
logger     = file:/home/vagrant/log/uwsgi-error.log

vacuum=True
pidfile=/run/uwsgi/pdfupload.pid
max-requests=5000
socket=/run/uwsgi/pdfupload.socket
processes=2
harakiri=20

pythonpath=..
env=DJANGO_SETTINGS_MODULE=pdfupload.settings
module = django.core.wsgi:get_wsgi_application()
touch-reload=/tmp/pdfupload.reload

虚拟环境不使用。在

请帮我完成这个设置。在


Tags: djangoinpyloghomeinitusrlocal