配置不正确:加载 psycopg2 模块时出错:没有名为“psycopg2._psycopg”的模块 zappa

Vik*_*kov 10 python django postgresql zappa python-zappa

我正在使用 zappa 将后端部署到 AWS Lambda。它运行得很好,直到我决定使用 PostgreSQL。我在设置中添加了这样的内容:

\n
DATABASES = {\n    'default': {\n        'ENGINE': 'django.db.backends.postgresql',\n        'NAME': config('DATABASE_NAME'),\n        'USER': config('DATABASE_USER'),\n        'PASSWORD': config('DATABASE_PASSWORD'),\n        'HOST': config('DATABASE_HOST'),\n        'PORT': '5432'\n    }\n}\n
Run Code Online (Sandbox Code Playgroud)\n

我正在使用 AWS RDS。我安装了 psycopg2-binary 和 psycopg2 (版本 2.8.6),但问题仍然存在。python版本是3.8。

\n

完整的错误日志:

\n
   [1621168086542] [ERROR] ImproperlyConfigured: Error loading psycopg2 module: No module named 'psycopg2._psycopg'\nTraceback (most recent call last):\n\xc2\xa0\xc2\xa0File "/var/task/handler.py", line 609, in lambda_handler\n\xc2\xa0\xc2\xa0\xc2\xa0\xc2\xa0return LambdaHandler.lambda_handler(event, context)\n\xc2\xa0\xc2\xa0File "/var/task/handler.py", line 240, in lambda_handler\n\xc2\xa0\xc2\xa0\xc2\xa0\xc2\xa0handler = cls()\n\xc2\xa0\xc2\xa0File "/var/task/handler.py", line 146, in __init__\n\xc2\xa0\xc2\xa0\xc2\xa0\xc2\xa0wsgi_app_function = get_django_wsgi(self.settings.DJANGO_SETTINGS)\n\xc2\xa0\xc2\xa0File "/var/task/zappa/ext/django_zappa.py", line 20, in get_django_wsgi\n\xc2\xa0\xc2\xa0\xc2\xa0\xc2\xa0return get_wsgi_application()\n\xc2\xa0\xc2\xa0File "/var/task/django/core/wsgi.py", line 12, in get_wsgi_application\n\xc2\xa0\xc2\xa0\xc2\xa0\xc2\xa0django.setup(set_prefix=False)\n\xc2\xa0\xc2\xa0File "/var/task/django/__init__.py", line 24, in setup\n\xc2\xa0\xc2\xa0\xc2\xa0\xc2\xa0apps.populate(settings.INSTALLED_APPS)\n\xc2\xa0\xc2\xa0File "/var/task/django/apps/registry.py", line 114, in populate\n\xc2\xa0\xc2\xa0\xc2\xa0\xc2\xa0app_config.import_models()\n\xc2\xa0\xc2\xa0File "/var/task/django/apps/config.py", line 211, in import_models\n\xc2\xa0\xc2\xa0\xc2\xa0\xc2\xa0self.models_module = import_module(models_module_name)\n\xc2\xa0\xc2\xa0File "/var/lang/lib/python3.8/importlib/__init__.py", line 127, in import_module\n\xc2\xa0\xc2\xa0\xc2\xa0\xc2\xa0return _bootstrap._gcd_import(name[level:], package, level)\n\xc2\xa0\xc2\xa0File "<frozen importlib._bootstrap>", line 1014, in _gcd_import\n\xc2\xa0\xc2\xa0File "<frozen importlib._bootstrap>", line 991, in _find_and_load\n\xc2\xa0\xc2\xa0File "<frozen importlib._bootstrap>", line 975, in _find_and_load_unlocked\n\xc2\xa0\xc2\xa0File "<frozen importlib._bootstrap>", line 671, in _load_unlocked\n\xc2\xa0\xc2\xa0File "<frozen importlib._bootstrap_external>", line 783, in exec_module\n\xc2\xa0\xc2\xa0File "<frozen importlib._bootstrap>", line 219, in _call_with_frames_removed\n\xc2\xa0\xc2\xa0File "/var/task/django/contrib/auth/models.py", line 2, in <module>\n\xc2\xa0\xc2\xa0\xc2\xa0\xc2\xa0from django.contrib.auth.base_user import AbstractBaseUser, BaseUserManager\n\xc2\xa0\xc2\xa0File "/var/task/django/contrib/auth/base_user.py", line 48, in <module>\n\xc2\xa0\xc2\xa0\xc2\xa0\xc2\xa0class AbstractBaseUser(models.Model):\n\xc2\xa0\xc2\xa0File "/var/task/django/db/models/base.py", line 122, in __new__\n\xc2\xa0\xc2\xa0\xc2\xa0\xc2\xa0new_class.add_to_class('_meta', Options(meta, app_label))\n\xc2\xa0\xc2\xa0File "/var/task/django/db/models/base.py", line 326, in add_to_class\n\xc2\xa0\xc2\xa0\xc2\xa0\xc2\xa0value.contribute_to_class(cls, name)\n\xc2\xa0\xc2\xa0File "/var/task/django/db/models/options.py", line 206, in contribute_to_class\n\xc2\xa0\xc2\xa0\xc2\xa0\xc2\xa0self.db_table = truncate_name(self.db_table, connection.ops.max_name_length())\n\xc2\xa0\xc2\xa0File "/var/task/django/db/__init__.py", line 28, in __getattr__\n\xc2\xa0\xc2\xa0\xc2\xa0\xc2\xa0return getattr(connections[DEFAULT_DB_ALIAS], item)\n\xc2\xa0\xc2\xa0File "/var/task/django/db/utils.py", line 214, in __getitem__\n\xc2\xa0\xc2\xa0\xc2\xa0\xc2\xa0backend = load_backend(db['ENGINE'])\n\xc2\xa0\xc2\xa0File "/var/task/django/db/utils.py", line 111, in load_backend\n\xc2\xa0\xc2\xa0\xc2\xa0\xc2\xa0return import_module('%s.base' % backend_name)\n\xc2\xa0\xc2\xa0File "/var/lang/lib/python3.8/importlib/__init__.py", line 127, in import_module\n\xc2\xa0\xc2\xa0\xc2\xa0\xc2\xa0return _bootstrap._gcd_import(name[level:], package, level)\n\xc2\xa0\xc2\xa0File "/var/task/django/db/backends/postgresql/base.py", line 29, in <module>\n\xc2\xa0\xc2\xa0\xc2\xa0\xc2\xa0raise ImproperlyConfigured("Error loading psycopg2 module: %s" % e)\n
Run Code Online (Sandbox Code Playgroud)\n

Col*_*cks 7

(可能的)问题是您正在.zipMacOS 上构建 lambda 包。当您部署 lambda 函数时,它在 Linux 环境(特别是 AWS 的 Linux2 环境)中运行。psycopg2-binaryMacOS 与 Linux 环境的情况有所不同,因此,如果您在 Mac 上构建 lambda 包(包括 ),psycopg2-binary然后部署到 lambda,您将遇到上述问题。

您需要在 AWS Linux 容器内构建 lambda 函数。这是一个 Dockerfile,您可以使用它来创建一个容器,在其中安装psycopg2-binary并构建 lambda zip 包。然后一切都应该有效:

FROM amazonlinux:2.0.20200207.1

RUN cd /opt && \
    yum install -y gcc openssl-devel bzip2-devel libffi-devel wget tar gzip make && \
    wget https://www.python.org/ftp/python/3.8.2/Python-3.8.2.tgz && \
    tar xzf Python-3.8.2.tgz && \
    cd Python-3.8.2 && \
    ./configure --enable-optimizations && \
    make altinstall && \
    rm -f /opt/Python-3.8.2.tgz && \
    echo "alias python3=python3.8" > ~/.bashrc
Run Code Online (Sandbox Code Playgroud)

注意 amaonzonlinux:2.0 操作系统,然后我只需将 python 3.8.2 安装到环境中(如果需要,您可以使用不同版本的 python)。从那里您可以复制代码并构建 lambda.zip包并部署到 lambda。