gpt4 book ai didi

python - 虚假导入错误(模块导入子模块?)

转载 作者:太空狗 更新时间:2023-10-29 19:29:46 24 4
gpt4 key购买 nike

我有一个问题,我真的不知道从哪里开始解决。也许它会敲响某人的钟。

TLDR: Django 应用程序崩溃并在重新启动时运行但无法导入某些模块。再次重启后,一切又好了。

整个故事:

偶尔在不同的 Python(2.5.x、2.6.x 和 2.6.x)和 Django 版本(分别为 1.1.0、1.2.5 和 1.3.0)上运行不同的应用程序(我们现在最多三个)表现出虚假的 ImportErrors。例如,其中一个应用程序通过在内部抛出 ImportError 开始使每个请求失败:

from django.contrib.gis.maps.google import GMarker, GEvent

我们收集了 strace 输出,相关 block 如下(为简洁起见,用 DIR 替换了绝对路径并保护了罪犯)。

stat64("DIR/django/contrib/gis/maps/google/GMarker", 0xf699ce3c) = -1 ENOENT (No such file or directory)
open("DIR/django/contrib/gis/maps/google/GMarker.so", O_RDONLY|O_LARGEFILE) = -1 ENOENT (No such file or directory)
open("DIR/django/contrib/gis/maps/google/GMarkermodule.so", O_RDONLY|O_LARGEFILE) = -1 ENOENT (No such file or directory)
open("DIR/django/contrib/gis/maps/google/GMarker.py", O_RDONLY|O_LARGEFILE) = -1 ENOENT (No such file or directory)
open("DIR/django/contrib/gis/maps/google/GMarker.pyc", O_RDONLY|O_LARGEFILE) = -1 ENOENT (No such file or directory)

(同样的东西 s/GMarker/GEvent/)

重启进程后一切顺利,同时运行:

python -c 'from django.contrib.gis.maps.google import GMarker'

不会产生任何错误。

GMarker 和 GEvent 类实际上在 django.contrib.gis.maps.google.overlays 中定义并在 ...maps/google/__init__.py 中导入:

from django.contrib.gis.maps.google.gmap import GoogleMap, GoogleMapSet
from django.contrib.gis.maps.google.overlays import GEvent, GIcon, GMarker, GPolygon, GPolyline
from django.contrib.gis.maps.google.zoom import GoogleZoom

因此完全可以预期加载 GMarker.py 等。将失败。 Python 似乎以某种方式忘记了 __init__.py 及其命名空间。

这些应用程序的流量相对较高,可以想象(尽管不确定)它们可能已经超出了 VM 限制并几乎正常恢复。此外,至少在两种情况下,该应用程序存在导致崩溃的早期问题——一种情况是 SIGSEGV,另一种情况是 err... 其他问题)。单个应用程序重启导致它抛出 ImportErrors,而另一个应用程序使其再次运行。损坏的 .py[c]?时间戳是古老的。

所有这些应用程序都在 flup wsgi-to-fastcgi 服务器上运行。

到目前为止,这些应用程序中的每一个都失败了一次(在完全不同的模块中,两次 __init__.py “被遗忘”但我找不到第三个错误 ATM)所以我无法判断模块是否是有点意思。

感谢任何和所有的建议和想法!

最佳答案

实际上,您的 strace 行没有一点帮助;这些访问不会导致模块被导入。

此类导入错误可能有多种原因:

  1. 有人修改了 sys.path 并且它不再在模块路径中
  2. 这些模块中的循环导入,由您首先从另一个模块导入触发!
  3. 您有站点冲突(是的,有那种),从不同的站点包位置加载相同的模块
  4. 您在搜索路径中有一个模块与某处的其他模块或系统模块发生冲突。

如果您粘贴第二组 strace 行,我们会更接近解决方案吗?

更新

对于 2. 我的意思是如果你有 2 个具有以下结构的文件

foo.py/init.py:

from bar import baz

bar.py/init.py:

import foo
def baz():
pass

snafu.py:

import bar
import foo

确定.py:

import foo
import snafu

运行 python snafu.py,你会得到一个崩溃和类似的 strace 输出,运行 python ok.py,一切正常。

关于python - 虚假导入错误(模块导入子模块?),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7260964/

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