【问题标题】:Import error when using uwsgi with django (Symbol not found: __PyInt_AsInt)将 uwsgi 与 django 一起使用时导入错误(未找到符号:__PyInt_AsInt)
【发布时间】:2015-03-09 03:01:40
【问题描述】:

我已尝试寻找修复方法,但无法解决。对不起,如果这个问题存在于其他地方。

我正在关注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

我已经遇到了 uWSGI 没有使用正确安装的问题。uwsgi 会尝试使用 /usr/local/bin/uwsgi 尽管

which uwsgi
//anaconda/bin/uwsgi

,产生No such file or directory。目前,我设置uWSGI="//anaconda/bin/uwsgi" 来解决这个问题并让uwsgi 工作,但我怀疑可能会发生类似的问题。我认为它可能正在尝试使用/usr/bin/python 而不是/anaconda/bin/python,并且无法从anaconda 导入,从而导致错误。但是,我不确定如何解决它/确认这是问题所在,任何建议都将不胜感激。

谢谢!

编辑:我也试过import _io 使用安装的所有当前版本的python,没有问题。 brew unlink python 帮助解决了 uwsgi 问题的 anaconda 版本冲突(最初使用别名修复,如上所述),但这个问题仍然存在。

编辑:从 $PATH 中删除 anaconda,然后重新安装/取消链接/链接 django、openssl 和 libxml2 “工作”。我会在稍后的步骤中找出这是否会导致问题,但我仍然不知道 anaconda 安装发生了什么。自从我使用 scipy/numpy/etc 以来,我真的很想弄清楚发生了什么。非常频繁,所以这绝对是一个临时修复。有任何想法吗?

【问题讨论】:

  • 您是通过pip install uwsgi 安装uWSGI 来进行Anaconda Python 编译,而不是/usr/bin/python/usr/loacl/bin/uwsgi
  • 我实际上并不确定我要为哪一个安装(我刚刚运行了pip install uwsgi),尽管我非常确信它是为 Anaconda 安装的,因为一旦安装完成,它就会调用它来自//anaconda/bin/uwsgi。另外pip show uwsgi给我pip show uwsgi --- Name: uWSGI Version: 2.0.9 Location: /anaconda/lib/python2.7/site-packages Requires:
  • 当它尝试使用 anaconda 时,我无法让它与 virtualenv 一起工作。不过,我会更多地研究它。谢谢!

标签: python django uwsgi


【解决方案1】:

我刚刚在我的 django 项目的 Mac 上运行 uwsgi 时遇到了这个问题

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)

除了Symbol not found: _PyExc_MemoryError 之外,与 OP 得到的错误非常相似。

我在我的 conda 环境中通过 pip 安装了uwsgi,显然通过 pip 安装的包与 anaconda 环境的 python 不兼容。

解决方案是从我的环境中删除 uwsgi

pip uninstall uwsgi

并使用 anaconda 安装它

conda install -c conda-forge uwsgi

完成此操作并使用我的 django 应用程序运行 uwsgi 后,它运行良好。

感谢blog 在那里我找到了我的问题的解决方案,这可能会解决uwsgidjango 的许多类似问题

【讨论】:

    猜你喜欢
    • 2019-01-31
    • 2018-07-31
    • 2012-01-04
    • 2017-07-17
    • 2015-12-06
    • 1970-01-01
    • 2018-12-19
    • 2015-09-27
    • 2021-12-21
    相关资源
    最近更新 更多