2015-09-28 26 views
10

yüklü rağmenDjango 1.8 ve Ubuntu 14.04 LTS üzerinde Python 3.4 koşuyorum. Yakın zamanda, Django uygulamam GEOS'un mevcut olmadığını bildiriyor. GEOS yüklendi ve libgeos_c.so olması gereken yerde (/usr/lib/). Kodum iyi görünüyor. Hala çalışan bir docker görüntüsünün kaynağıdır. Bu bir os/uyumsuzluk sorunu olduğunu gösteriyor. Herhangi bir yardım çok takdir edilecektir."django.core.exceptions.ImproperlyConfigured": GEOS gerekli ve algılanmadı. " GEOS

tam traceback ben libgdal-dev yeniden denedim

Traceback (most recent call last): 
    File "<path/to/my/homedir>/pycharm-4.5.1/helpers/pydev/pydevd.py", line 2358, in <module> 
    globals = debugger.run(setup['file'], None, None, is_module) 
    File "<path/to/my/homedir>/pycharm-4.5.1/helpers/pydev/pydevd.py", line 1778, in run 
    pydev_imports.execfile(file, globals, locals) # execute the script 
    File "<path/to/my/homedir>/pycharm-4.5.1/helpers/pydev/_pydev_imps/_pydev_execfile.py", line 18, in execfile 
    exec(compile(contents+"\n", file, 'exec'), glob, loc) 
    File "<path/to/my/pycharm/project>/manage.py", line 10, in <module> 
    execute_from_command_line(sys.argv) 
    File "<path/to/my/virtualenv>/lib/python3.4/site-packages/django/core/management/__init__.py", line 338, in execute_from_command_line 
    utility.execute() 
    File "<path/to/my/virtualenv>/lib/python3.4/site-packages/django/core/management/__init__.py", line 312, in execute 
    django.setup() 
    File "<path/to/my/virtualenv>/lib/python3.4/site-packages/django/__init__.py", line 18, in setup 
    apps.populate(settings.INSTALLED_APPS) 
    File "<path/to/my/virtualenv>/lib/python3.4/site-packages/django/apps/registry.py", line 108, in populate 
    app_config.import_models(all_models) 
    File "<path/to/my/virtualenv>/lib/python3.4/site-packages/django/apps/config.py", line 198, in import_models 
    self.models_module = import_module(models_module_name) 
    File "/usr/lib/python3.4/importlib/__init__.py", line 109, in import_module 
    return _bootstrap._gcd_import(name[level:], package, level) 
    File "<frozen importlib._bootstrap>", line 2231, in _gcd_import 
    File "<frozen importlib._bootstrap>", line 2214, in _find_and_load 
    File "<frozen importlib._bootstrap>", line 2203, in _find_and_load_unlocked 
    File "<frozen importlib._bootstrap>", line 1200, in _load_unlocked 
    File "<frozen importlib._bootstrap>", line 1129, in _exec 
    File "<frozen importlib._bootstrap>", line 1448, in exec_module 
    File "<frozen importlib._bootstrap>", line 321, in _call_with_frames_removed 
    File "<path/to/my/virtualenv>/lib/python3.4/site-packages/django/contrib/auth/models.py", line 41, in <module> 
    class Permission(models.Model): 
    File "<path/to/my/virtualenv>/lib/python3.4/site-packages/django/db/models/base.py", line 139, in __new__ 
    new_class.add_to_class('_meta', Options(meta, **kwargs)) 
    File "<path/to/my/virtualenv>/lib/python3.4/site-packages/django/db/models/base.py", line 324, in add_to_class 
    value.contribute_to_class(cls, name) 
    File "<path/to/my/virtualenv>/lib/python3.4/site-packages/django/db/models/options.py", line 250, in contribute_to_class 
    self.db_table = truncate_name(self.db_table, connection.ops.max_name_length()) 
    File "<path/to/my/virtualenv>/lib/python3.4/site-packages/django/db/__init__.py", line 36, in __getattr__ 
    return getattr(connections[DEFAULT_DB_ALIAS], item) 
    File "<path/to/my/virtualenv>/lib/python3.4/site-packages/django/db/utils.py", line 240, in __getitem__ 
    backend = load_backend(db['ENGINE']) 
    File "<path/to/my/virtualenv>/lib/python3.4/site-packages/django/db/utils.py", line 111, in load_backend 
    return import_module('%s.base' % backend_name) 
    File "/usr/lib/python3.4/importlib/__init__.py", line 109, in import_module 
    return _bootstrap._gcd_import(name[level:], package, level) 
    File "<frozen importlib._bootstrap>", line 2231, in _gcd_import 
    File "<frozen importlib._bootstrap>", line 2214, in _find_and_load 
    File "<frozen importlib._bootstrap>", line 2203, in _find_and_load_unlocked 
    File "<frozen importlib._bootstrap>", line 1200, in _load_unlocked 
    File "<frozen importlib._bootstrap>", line 1129, in _exec 
    File "<frozen importlib._bootstrap>", line 1448, in exec_module 
    File "<frozen importlib._bootstrap>", line 321, in _call_with_frames_removed 
    File "<path/to/my/virtualenv>/lib/python3.4/site-packages/django/contrib/gis/db/backends/postgis/base.py", line 8, in <module> 
    from .features import DatabaseFeatures 
    File "<path/to/my/virtualenv>/lib/python3.4/site-packages/django/contrib/gis/db/backends/postgis/features.py", line 1, in <module> 
    from django.contrib.gis.db.backends.base.features import BaseSpatialFeatures 
    File "<path/to/my/virtualenv>/lib/python3.4/site-packages/django/contrib/gis/db/backends/base/features.py", line 3, in <module> 
    from django.contrib.gis.db.models import aggregates 
    File "<path/to/my/virtualenv>/lib/python3.4/site-packages/django/contrib/gis/db/models/__init__.py", line 12, in <module> 
    "See also https://docs.djangoproject.com/en/%s/ref/contrib/gis/install/geolibs/" % get_docs_version()) 
django.core.exceptions.ImproperlyConfigured: GEOS is required and has not been detected. Are you sure it is installed? See also https://docs.djangoproject.com/en/1.8/ref/contrib/gis/install/geolibs/ 

olduğunu. İlgili tüm paketler (GDAL, GEOS vb.) Günceldir.

Python koduna geri dönmeyi denedim. djanjo/contrib/gis/geos/__ init__.py'da aşağıdaki hatalardan dolayı başarısız olur. HAS_GEOS yanlış olarak ayarlandığında, GEOS'un mevcut olmadığını bildirir.

try: 
    from .libgeos import geos_version, geos_version_info # NOQA: flake8 detects only the last __all__ 
    HAS_GEOS = True 
    __all__ += ['geos_version', 'geos_version_info'] 
except ImportError: 
    HAS_GEOS = False 

Yeni bir işletim sistemi yükseltmesi/düzeltme ekinin GEOS veya GDAL bozuk olduğundan şüpheleniyorum. Kök nedeni, ktypes ile ilgili bir şey gibi görünüyor, ancak ne olabileceğini göremiyorum.

Aşağıdakiler yararlı olabilir.

>>> from _ctypes import Union, Structure, Array 
Traceback (most recent call last): 
    File "<input>", line 1, in <module> 
    File "/<path/to/my/homedir>/pycharm-4.5.1/helpers/pydev/pydev_import_hook.py", line 21, in do_import 
    module = self._system_import(name, *args, **kwargs) 
ImportError: /usr/lib/python3.4/lib-dynload/_ctypes.cpython-34m-x86_64-linux-gnu.so: undefined symbol: _PyTraceback_Add 


>>> from django.contrib.gis import gdal 
Traceback (most recent call last): 
    File "<input>", line 1, in <module> 
    File "/<path/to/my/homedir>/pycharm-4.5.1/helpers/pydev/pydev_import_hook.py", line 21, in do_import 
    module = self._system_import(name, *args, **kwargs) 
    File "/<path/to/my/homedir>/pycharm-4.5.1/helpers/pydev/pydev_import_hook.py", line 21, in do_import 
    module = self._system_import(name, *args, **kwargs) 
    File "/<path/to/my/virtualenv>/lib/python3.4/site-packages/django/contrib/gis/gdal/__init__.py", line 47, in <module> 
    from django.contrib.gis.gdal.driver import Driver # NOQA 
    File "/<path/to/my/homedir>/pycharm-4.5.1/helpers/pydev/pydev_import_hook.py", line 21, in do_import 
    module = self._system_import(name, *args, **kwargs) 
    File "/<path/to/my/virtualenv>/lib/python3.4/site-packages/django/contrib/gis/gdal/driver.py", line 1, in <module> 
    from ctypes import c_void_p 
    File "/<path/to/my/homedir>/pycharm-4.5.1/helpers/pydev/pydev_import_hook.py", line 21, in do_import 
    module = self._system_import(name, *args, **kwargs) 
    File "/usr/lib/python3.4/ctypes/__init__.py", line 7, in <module> 
    from _ctypes import Union, Structure, Array 
    File "/<path/to/my/homedir>/pycharm-4.5.1/helpers/pydev/pydev_import_hook.py", line 21, in do_import 
    module = self._system_import(name, *args, **kwargs) 
ImportError: /usr/lib/python3.4/lib-dynload/_ctypes.cpython-34m-x86_64-linux-gnu.so: undefined symbol: _PyTraceback_Add 

cevap

24

Benimle aynı olmayan bir python projesinde de aynı problemi yaşadım. Bu benim de karşılaşılan çizgidir ve hangi burada götürdü: Ubunut mevcut sanal ortamlar ile uyumlu olmayan bir Python 3.4 güncellemesini itti gibi

ImportError: /usr/lib/python3.4/lib-dynload/_ctypes.cpython-34m-x86_64-linux-gnu.so: undefined symbol: _PyTraceback_Add 

görünüyor. Ben sanalenv yeniden oluşturarak sorunu çözebilir. Bu andan için kullanışsız olduğu nereden basitçe sistemin bir ile VIRTUALENV en piton değiştirilir:

cd my-virtualenv 
cp /usr/bin/python3.4 bin/python3.4 

bunu yapmak için çok aklı başında şey olup olmadığını söyleyemem, ama çalışmak görünüyor benim vaka. Bu gerçek dışı Sembolik bağ dosya, çünkü

+0

Eskiyle aynı gereksinimleri.txt ile yeni _virtualenv_ oluşturmayı denedim. Hala aynı hatayı aldım. Virtualenv'in pythonunu '/ usr/bin/python3.4' ile değiştirmeyi denedim. Hala aynı hatayı alıyoruz. – user3892196

+1

Python3'ün değiştirilmesi, hile yaptı. Virtualenv'imi yeniden oluşturmak için çok tembel. Bahşiş için teşekkürler. – Akhorus

2

Sen, yerine

cp /usr/bin/python3 /path/to/my-virtualenv/bin/python3 

yapmalıdır.

+0

'python3'' python3.4'üne bağlantılar. Ls' komutundan eklenmiş snippet'e bakın. 'lrwxrwxrwx 1 kök Kök silinemiyor 9 Haziran 3 16:34/usr/bin/python3 -> python3.4' ' -rwxr-xr-x 2 kök, kök 3.697.592 Temmuz 28 20:56/usr/bin/python3. 4 ' – user3892196