gpt4 book ai didi

python - uwsgi 和 django - django uwsgi 导入正在离开 virtualenv 并崩溃

转载 作者:太空宇宙 更新时间:2023-11-04 06:05:40 27 4
gpt4 key购买 nike

从 ini 文件启动 uwsgi 时崩溃,堆栈跟踪如下:

Traceback (most recent call last):                                                                                                                                                                                                                 
File "/var/www/vhosts/x/projectX/wsgi.py", line 18, in <module>
from django.core.wsgi import get_wsgi_application
File "/var/www/vhosts/x/virtenv/local/lib/python2.7/site-packages/django/core/wsgi.py", line 1, in <module>
from django.core.handlers.wsgi import WSGIHandler
File "/var/www/vhosts/x/virtenv/local/lib/python2.7/site-packages/django/core/handlers/wsgi.py", line 4, in <module>
import logging
File "/usr/lib64/python2.7/logging/__init__.py", line 26, in <module>
import sys, os, time, cStringIO, traceback, warnings, weakref
ImportError: No module named time

路径/var/www/vhosts/x/virtenv/是正确的 virtualenv,它按预期使用 python 2.7。但是由于某些原因,在导入“logging”时,它会跳转到/usr/lib64/

这里还有两点要注意:

  1. 使用 -p 命令(手动指定/usr/bin/python2.7 作为 python 版本)并使用 --no-site-packages 设置 virtualenv
  2. 我们有几乎相同的 uwsgi.ini 文件与另一个 django 应用程序一起工作(没有问题)。唯一的区别似乎是这个项目 X 运行的是 Django 1.6.1 而另一个项目运行的是 Django 1.5

最奇怪的是,如果我尝试手动执行 wsgi.py 文件中的代码,它工作得很好。 (我获取 virtualenv,启动 python 命令行并在那里复制 wsgi.py 的命令)

这是 uwsgi.ini 文件:

[uwsgi]
# variables
projectname = projectX
projectdomain = x.mydomain.com
base = /var/www/vhosts/x

# config
socket = 127.0.0.1:8989
chdir = %(base)
wsgi-file = %(base)/%(projectname)/wsgi.py
master = true
pidfile = /tmp/%(projectname)-master.pid
vacuum = true

max-requests = 5000
processes = 10
#harakiri = 20
uid = 109
gid = 113

callable = projectX

env = DJANGO_SETTINGS_MODULE=settings
home = %(base)/virtenv
touch-reload = %(base)
py-autoreload = 3

#daemonize = /var/log/x/uwsgi.log
virtualenv = %(base)/virtenv
pythonpath = %(base)/virtenv/lib/python2.7
pythonpath = %(base)
pythonpath = %(base)/%(projectname)

wsgi.py 文件:

import os

os.environ.setdefault("DJANGO_SETTINGS_MODULE", "projectX.settings")

from django.core.wsgi import get_wsgi_application # <-- this is line 18
application = get_wsgi_application()

最佳答案

通过更改解决

env = DJANGO_SETTINGS_MODULE=settings

env = DJANGO_SETTINGS_MODULE=projectX.settings

如果有人知道为什么这适用于 django 1.5 而不是 1.6.1,我会非常感兴趣。

关于python - uwsgi 和 django - django uwsgi 导入正在离开 virtualenv 并崩溃,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22254974/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com