модуль django уже импортирует и предупреждения Python egg - PullRequest
0 голосов
/ 03 мая 2011

Может кто-нибудь помочь мне избавиться от этих предупреждений в Джанго, пожалуйста?

/usr/lib/python2.6/site-packages/simplejson-2.1.5-py2.6-linux-x86_64.egg/simplejson/_speedups.py:3: UserWarning: Module taggit was already imported from /var/www/html/matilah/taggit/__init__.py, but /usr/lib/python2.6/site-packages/django_taggit-0.9.3-py2.6.egg is being added to sys.path

Traceback (most recent call last):
 File "manage.py", line 11, in <module>
   execute_manager(settings)
 File "/usr/lib/python2.6/site-packages/django/core/management/__init__.py", line 438, in execute_manager
   utility.execute()
 File "/usr/lib/python2.6/site-packages/django/core/management/__init__.py", line 379, in execute
   self.fetch_command(subcommand).run_from_argv(self.argv)
 File "/usr/lib/python2.6/site-packages/django/core/management/__init__.py", line 261, in fetch_command
   klass = load_command_class(app_name, subcommand)
 File "/usr/lib/python2.6/site-packages/django/core/management/__init__.py", line 67, in load_command_class
   module = import_module('%s.management.commands.%s' % (app_name, name))
 File "/usr/lib/python2.6/site-packages/django/utils/importlib.py", line 35, in import_module
   __import__(name)
 File "/usr/lib/python2.6/site-packages/haystack/__init__.py", line 154, in <module>
   handle_registrations()
 File "/usr/lib/python2.6/site-packages/haystack/__init__.py", line 151, in handle_registrations
   search_sites_conf = importlib.import_module(settings.HAYSTACK_SITECONF)
 File "/usr/lib/python2.6/site-packages/django/utils/importlib.py", line 35, in import_module
   __import__(name)
 File "/var/www/html/matilah/search_sites.py", line 2, in <module>
   haystack.autodiscover()
 File "/usr/lib/python2.6/site-packages/haystack/__init__.py", line 106, in autodiscover
   app_path = importlib.import_module(app).__path__
 File "/usr/lib/python2.6/site-packages/django/utils/importlib.py", line 35, in import_module
   __import__(name)
 File "/var/www/html/matilah/disqus/__init__.py", line 5, in <module>
   from django.utils import simplejson as json
 File "/usr/lib/python2.6/site-packages/django/utils/simplejson/__init__.py", line 111, in <module>
   import simplejson
 File "/usr/lib/python2.6/site-packages/simplejson-2.1.5-py2.6-linux-x86_64.egg/simplejson/__init__.py", line 111, in <module>

 File "/usr/lib/python2.6/site-packages/simplejson-2.1.5-py2.6-linux-x86_64.egg/simplejson/decoder.py", line 7, in <module>
 File "/usr/lib/python2.6/site-packages/simplejson-2.1.5-py2.6-linux-x86_64.egg/simplejson/scanner.py", line 10, in <module>
 File "/usr/lib/python2.6/site-packages/simplejson-2.1.5-py2.6-linux-x86_64.egg/simplejson/scanner.py", line 6, in _import_c_make_scanner
 File "/usr/lib/python2.6/site-packages/simplejson-2.1.5-py2.6-linux-x86_64.egg/simplejson/_speedups.py", line 7, in <module>
 File "/usr/lib/python2.6/site-packages/simplejson-2.1.5-py2.6-linux-x86_64.egg/simplejson/_speedups.py", line 4, in __bootstrap__
 File "/usr/lib/python2.6/site-packages/pkg_resources.py", line 841, in resource_filename
   self, resource_name
 File "/usr/lib/python2.6/site-packages/pkg_resources.py", line 1310, in get_resource_filename
   self._extract_resource(manager, self._eager_to_zip(name))
 File "/usr/lib/python2.6/site-packages/pkg_resources.py", line 1332, in _extract_resource
   self.egg_name, self._parts(zip_path)
 File "/usr/lib/python2.6/site-packages/pkg_resources.py", line 921, in get_cache_path
   self.extraction_error()
 File "/usr/lib/python2.6/site-packages/pkg_resources.py", line 887, in extraction_error
   raise err
pkg_resources.ExtractionError: Can't extract file(s) to egg cache

The following error occurred while trying to extract file(s) to the Python egg
cache:

 [Errno 13] Permission denied: '/home/interworx/.python-eggs'

The Python egg cache directory is currently set to:

 /home/interworx/.python-eggs

Perhaps your account does not have write access to this directory?  You can
change the cache directory by setting the PYTHON_EGG_CACHE environment
variable to point to an accessible directory.

Я не уверен, связана ли ошибка «Модуль уже импортирован» с ошибкой «не удается извлечь PYTHON EGG».

В моем WSGI у меня уже есть следующая строка os.environ['PYTHON_EGG_CACHE'] = rel('python-eggs'), и я точно знаю, что это работает. В противном случае WSGI не загрузит мое приложение. Поэтому я не уверен, что здесь делать.

Спасибо!

Ответы [ 2 ]

2 голосов
/ 03 мая 2011

Когда вы получаете сообщение типа «Возможно, ваша учетная запись не имеет доступа для записи в этот каталог?»Лучше всего сделать быстрый тест.Попробуйте изменить его на "/ tmp" (который доступен для записи всем) и посмотрите, все ли начинает работать.Если это исправляет, вы можете определить более подходящий каталог и убедиться, что у вас (или у сервера) есть права на запись в него.

Обновление: Вы правильно выбрали решениесамое раннее сообщение об ошибке первым.Вот быстрая утилита Python Module Dump , которую я написал несколько лет назад для отслеживания ошибочно включенного модуля.Вы можете попытаться вставить его в интересные моменты вдоль пути кода инициализации и посмотреть, сможете ли вы определить, когда произошел предыдущий импорт.

0 голосов
/ 03 мая 2011

Существует вероятность того, что ваша первоначальная проблема "Модуль уже был импортирован" на самом деле связана с ошибкой разрешений, которая у вас возникла.Лучшим вариантом было бы исправить настройки прав доступа / владения в каталоге /home/interworx/.python-eggs (как было сказано Питером Роуэллом выше).

Сегодня я натолкнулся на этого замечательного небольшого освежителя в разрешениях.Университет Google Code.Не мешало бы просмотреть это, когда у вас есть время: http://code.google.com/edu/tools101/linux/ownership_permissions.html

Просто прочитайте комментарии выше, вот мои мысли:

Я думаю, что проблема в том, что файл .wsgiне устанавливать переменную среды во времени.Можете ли вы опубликовать свой файл .wsgi?Кроме того, как вы захватываете пакеты?Это сценарий?Вручную через пипс?

...