0

我正在尝试使用 Apache 部署我的 Django 站点,但我遇到了 ImageKit 库的问题。这是来自 /var/log/apache2/error.log 的错误:

No handlers could be found for logger "django.request"
[1.2.3.4] mod_wsgi (pid=17276): Exception occurred processing WSGI script '/var/www/mysite.com/portfoliosite/portfoliosite/wsgi.py'.
[1.2.3.4] Traceback (most recent call last):
[1.2.3.4]   File "/home/ubuntu/.virtualenvs/portfoliositeenv/lib/python3.4/site-packages/django/core/handlers/wsgi.py", line 189, in __call__
[1.2.3.4]     response = self.get_response(request)
[1.2.3.4]   File "/home/ubuntu/.virtualenvs/portfoliositeenv/lib/python3.4/site-packages/django/core/handlers/base.py", line 218, in get_respo$
[1.2.3.4]     response = self.handle_uncaught_exception(request, resolver, sys.exc_info())
[1.2.3.4]   File "/home/ubuntu/.virtualenvs/portfoliositeenv/lib/python3.4/site-packages/django/core/handlers/base.py", line 264, in handle_un$
[1.2.3.4]     if resolver.urlconf_module is None:
[1.2.3.4]   File "/home/ubuntu/.virtualenvs/portfoliositeenv/lib/python3.4/site-packages/django/core/urlresolvers.py", line 395, in urlconf_mo$
[1.2.3.4]     self._urlconf_module = import_module(self.urlconf_name)
[1.2.3.4]   File "/usr/lib/python2.7/importlib/__init__.py", line 37, in import_module
[1.2.3.4]     __import__(name)
[1.2.3.4]   File "/var/www/mysite.com/portfoliosite/portfoliosite/urls.py", line 21, in <module>
[1.2.3.4]     url(r'^', include('portfolio.urls')), # route root through portfolio routes
[1.2.3.4]   File "/home/ubuntu/.virtualenvs/portfoliositeenv/lib/python3.4/site-packages/django/conf/urls/__init__.py", line 33, in include
[1.2.3.4]     urlconf_module = import_module(urlconf_module)
[1.2.3.4]   File "/usr/lib/python2.7/importlib/__init__.py", line 37, in import_module
[1.2.3.4]     __import__(name)
[1.2.3.4]   File "/var/www/mysite.com/portfoliosite/portfolio/urls.py", line 3, in <module>
[1.2.3.4]     from . import views
[1.2.3.4]   File "/var/www/mysite.com/portfoliosite/portfolio/views.py", line 9, in <module>
[1.2.3.4]     from .models import Project
[1.2.3.4]   File "/var/www/mysite.com/portfoliosite/portfolio/models.py", line 2, in <module>
[1.2.3.4]     from imagekit.models import ImageSpecField
[1.2.3.4]   File "/home/ubuntu/.virtualenvs/portfoliositeenv/lib/python3.4/site-packages/imagekit/__init__.py", line 2, in <module>
[1.2.3.4]     from . import conf
[1.2.3.4] ImportError: cannot import name conf

有谁知道可能导致这种情况发生的原因?执行“sudo python3 manage.py runserver”工作正常,但 Apache 遇到此库错误。这里有一些更相关的信息:

wsgi.py:

import os
import sys
import site

# Add the site-packages of the chosen virtualenv to work with
site.addsitedir('/home/ubuntu/.virtualenvs/portfoliositeenv/lib/python3.4/site-packages/')

# Add the app's directory to the PYTHONPATH
sys.path.append('/var/www/mysite.com/portfoliosite')
sys.path.append('/var/www/mysite.com/portfoliosite/portfoliosite')

os.environ['DJANGO_SETTINGS_MODULE'] = 'portfoliosite.settings'

# Activate your virtual env
activate_env=os.path.expanduser('/home/ubuntu/.virtualenvs/portfoliositeenv/bin/activate_this.py')
exec(open(activate_env).read(), dict(__file__=activate_env))

import django.core.handlers.wsgi
application = django.core.handlers.wsgi.WSGIHandler()

/etc/apache2/apache2.conf(我添加的部分):

WSGIPythonPath /var/www/mysite.com/portfoliosite:/home/ubuntu/.virtualenvs/portfoliositeenv/lib/python3.4/site-packages/

Alias /media/ /var/www/mysite.com/portfoliosite/portfolio/media/
Alias /static/ /var/www/mysite.com/static/

<Directory /var/www/mysite.com/static>
    Require all granted
</Directory>

<Directory /var/www/mysite.com/media>
    Require all granted
</Directory>

WSGIScriptAlias / /var/www/mysite.com/portfoliosite/portfoliosite/wsgi.py

<Directory /var/www/mysite.com/portfoliosite>
    <Files wsgi.py>
        Require all granted
    </Files>
</Directory>

这真是令人沮丧,任何帮助将不胜感激。谢谢!

4

1 回答 1

0

弄清楚了!我正在混合 Python 版本,您可以在日志中看到一些指向 Python 2.7 的路径,而我的 virtualenv 正在使用 Python 3。我创建了一个新的虚拟环境并将所有路径更改为使用 Python 2.7,它现在​​似乎可以工作了。

于 2015-12-26T16:48:55.397 回答