4

问题

我正在尝试将我的 geodjango 应用程序部署到 Heroku。该应用程序运行,但是当我尝试查看/admin/world/worldborder/wolrd geodjango 教程应用程序)或我自己的自定义 Spots 应用程序(使用 geodjango)时,站点崩溃。

如果我看一下,我heroku logs会发现测功机出现 500 错误:

2012-07-20T08:16:23+00:00 heroku[router]: GET myapp.herokuapp.com/admin/spots/spot/ dyno=web.1 queue=0 wait=0ms service=654ms status=500 bytes=4922

然后我通过电子邮件收到此错误:

AttributeError: 'module' object has no attribute 'GeoSQLCompiler'

完整的追溯可以在这里找到

我在其他地方的 aws ec2 实例上有我的数据库服务器,并在该服务器上完成了这些安装说明

应用上下文

Django==1.4 独角兽==0.14.2

我使用以下内容创建了我的 heroku 应用程序

heroku create myapp --stack cedar --buildpack http://github.com/cirlabs/heroku-buildpack-geodjango/

如您所见,我正在使用自定义 buildpack为 geodjango 安装所有必要的东西。如果我不使用这个自定义 buildpack 并简单地使用heroku create myapp,那么我会收到这个很长的错误

我还将这些添加到 heroku 配置变量中

GEOS_LIBRARY_PATH='/app/.geodjango/geos/lib/libgeos_c.so'
GDAL_LIBRARY_PATH='/app/.geodjango/gdal/lib/libgdal.so'

我已经尝试过的

我用谷歌搜索了这个错误,在这里只看到了一篇文章。基本上说要确保我的数据库后端正确设置为使用(我已经这样做了)

'ENGINE': 'django.contrib.gis.db.backends.postgis',

我还尝试更改为以下内容:

GEOS_LIBRARY_PATH='/myapp/.geodjango/geos/lib/libgeos_c.so'
GDAL_LIBRARY_PATH='/myapp/.geodjango/gdal/lib/libgdal.so'

这个应用程序在我的本地开发机器上运行良好,python manage.py runserver或者foreman start -f Profile.dev

为什么我不能在 Heroku 上使用基于 geodjango 的应用程序,我该如何解决这个问题?

4

1 回答 1

0

我大约有 93.2% 的人确定这是一个path问题。Web 开发中的主要PITA之一是您的命令行环境可能与服务器环境几乎没有共同之处。

当我需要确切知道从哪个目录加载哪些模块的哪个版本时,我使用以下内容。它返回一个 2-tuples 列表('name', 'path-to-module')。在你的初始化完成之后调用它,或者在你尝试加载你的地理模块(或其他同样有趣的地方)之前和/或之后调用它,并将结果转储到屏幕或日志文件中。

我不知道这会解决你的问题,但它可能会给你一些有趣的见解。

注意:您可以根据需要编辑(或注释掉)re.sub()s。我只是把它们放进去,因为一大页绝对路径名很难看,并且可以掩盖这样一个事实,即某些东西是从系统的副本而不是您自己的副本加载的。

modulelist.py

import sys, re, os
import django

def ModuleList():
    ret = []
    dir_project = os.path.dirname(os.path.dirname(os.path.realpath(__file__)))
    project_name = os.path.basename(dir_project)

    for k,v in sys.modules.items():

        x = str(v)
        if 'built-in' in x:
            ret.append((k, 'built-in'))
            continue

        m = re.search(r"^.*?'(?P<module>.*?)' from '(?P<file>.*?)'.*$", x)
        if m:
            d = m.groupdict()
            f = d['file']
            f = re.sub(r'/usr/.*?/lib/python[.0-9]*/site-packages/django/', 'system django >> ', f)
            f = re.sub(r'/usr/.*?/lib/python[.0-9]*/site-packages/', 'site-packages >> ', f)
            f = re.sub(r'/usr/.*?/lib/python[.0-9]*/', 'system python >> ', f)
            f = re.sub(dir_project+'.*python/', 'local python >> ', f)
            f = re.sub(dir_project+'.*django/', 'local django >> ', f)
            f = re.sub(dir_project+r'(/\.\./)?', project_name + ' >> ', f)
            ret.append((d['module'], f))
    ret.sort( lambda a,b: cmp(a[0].lower(), b[0].lower()) )
    ret.insert(0, ('Python version', sys.version) )
    ret.insert(0, ('Django version', django.get_version()) )

    return ret
# ModuleList

if __name__ == "__main__":
    for x in ModuleList():
        print "%s\t%s" % (x[0], x[1])
于 2012-07-24T18:13:36.990 回答