use*_*900 5 python django uwsgi
我尝试过寻找修复方法,但未能成功。抱歉,如果其他地方存在这个问题。
我正在关注http://uwsgi-docs.readthedocs.org/en/latest/tutorials/Django_and_nginx.html,目前正在尝试确保django与uWSGI一起工作。我正在尝试运行uWSGI --http-socket :8000 --module mysite.wsgi,但得到:
Traceback (most recent call last):
File "./mysite/wsgi.py", line 13, in <module>
from django.core.wsgi import get_wsgi_application
File "/anaconda/lib/python2.7/site-packages/django/core/wsgi.py", line 2, in <module>
from django.core.handlers.wsgi import WSGIHandler
File "/anaconda/lib/python2.7/site-packages/django/core/handlers/wsgi.py", line 3, in <module>
import cgi
File "/anaconda/lib/python2.7/cgi.py", line 50, in <module>
import mimetools
File "/anaconda/lib/python2.7/mimetools.py", line 6, in <module>
import tempfile
File "/anaconda/lib/python2.7/tempfile.py", line 32, in <module>
import io as _io
File "/anaconda/lib/python2.7/io.py", line 51, in <module>
import _io
ImportError: dlopen(/anaconda/lib/python2.7/lib-dynload/_io.so, 2): Symbol not found: __PyInt_AsInt
Referenced from: /anaconda/lib/python2.7/lib-dynload/_io.so
Expected in: dynamic lookup
Run Code Online (Sandbox Code Playgroud)
我已经遇到了 uWSGI 未使用正确安装的问题。尽管uwsgi会尝试使用/usr/local/bin/uwsgi
which uwsgi
//anaconda/bin/uwsgi
Run Code Online (Sandbox Code Playgroud)
, 导致No such file or directory。目前,我准备uWSGI="//anaconda/bin/uwsgi"解决这个问题并让 uwsgi 工作,但我怀疑可能会发生类似的问题。我认为它可能试图使用/usr/bin/python而不是/anaconda/bin/python,并且它无法从 anaconda 导入,从而导致错误。但是,我不确定如何解决它/确认这是问题所在,任何建议将不胜感激。
谢谢!
编辑:我还尝试import _io使用安装的所有当前版本的python,并且没有问题。brew unlink python帮助处理了冲突的 anaconda 版本问题uwsgi(最初使用别名修复,如上所述),但这个问题仍然存在。
编辑:从 $PATH 中删除 anaconda,然后重新安装/取消链接/链接 django、openssl 和 libxml2 “有效”。我很快就会知道这是否会在后面的步骤中导致问题,但我仍然不知道 anaconda 安装发生了什么。我真的很想知道自从我使用 scipy/numpy/etc 以来发生了什么。非常频繁,所以这绝对是一个临时修复。有任何想法吗?
我刚刚在尝试uwsgi在 Mac 上运行 django 项目时遇到了这个问题
uwsgi --http :9090 --module uwsgi_django_project.wsgi
(在本例中我的 django 项目被命名为uwsgi_django_project)
来自 uwsgi 的堆栈跟踪是
Traceback (most recent call last):
File "./uwsgi_django_project/wsgi.py", line 12, in <module>
from django.core.wsgi import get_wsgi_application
File "/opt/anaconda3/envs/django_uwsgi_39/lib/python3.8/site-packages/django/__init__.py", line 1, in <module>
from django.utils.version import get_version
File "/opt/anaconda3/envs/django_uwsgi_39/lib/python3.8/site-packages/django/utils/version.py", line 1, in <module>
import datetime
File "/opt/anaconda3/envs/django_uwsgi_39/lib/python3.8/datetime.py", line 8, in <module>
import math as _math
ImportError: dlopen(/opt/anaconda3/envs/django_uwsgi_39/lib/python3.8/lib-dynload/math.cpython-38-darwin.so, 2): Symbol not found: _PyExc_MemoryError
Referenced from: /opt/anaconda3/envs/django_uwsgi_39/lib/python3.8/lib-dynload/math.cpython-38-darwin.so
Expected in: flat namespace
in /opt/anaconda3/envs/django_uwsgi_39/lib/python3.8/lib-dynload/math.cpython-38-darwin.so
unable to load app 0 (mountpoint='') (callable not found or import error)
Run Code Online (Sandbox Code Playgroud)
与 OP 收到的错误非常相似,Symbol not found: _PyExc_MemoryError只是相反。
我已经uwsgi在 conda 环境中通过 pip 安装了,显然通过 pip 安装的包和 anaconda 环境的 python 之间存在不兼容。
uwsgi解决方案是从我的环境中删除
pip uninstall uwsgi
并使用 anaconda 安装它
conda install -c conda-forge uwsgi
完成此操作并使用我的 django 应用程序运行 uwsgi 后,它工作正常。
感谢这个博客,我在其中找到了我的问题的解决方案,它可能会解决很多类似的uwsgi问题django
| 归档时间: |
|
| 查看次数: |
2199 次 |
| 最近记录: |