Google Cloud Functions中没有名为psycopg2._psycopg2的模块

时间:2019-04-25 01:12:28

标签: google-cloud-functions psycopg2 google-cloud-sql

我有一个Google Cloud Function,它通过psycopg2使用Google Cloud SQL。我的requirements.txt文件中包含psycopg2,但是一旦服务更新,我就会收到错误No module named psycopg2._psycopg2

Cloud Function's environment中运行的psycopg2的C库是否有问题?我该如何解决?

main.py

import psycopg2

def postgres_demo(request):
    return "hi"

requirements.txt

psycopg2==2.8.2

serverless.yml

service: gcf-python-v2

provider:
    name: google
    stage: dev
    runtime: python37
    region: us-central1
    project: my-project
    credentials: ~/.gcloud/keyfile.json

plugins:
    - serverless-google-cloudfunctions
    - serverless-python-requirements

custom:
    pythonRequirements:
        pythonBin: python3

package:
    exclude:
        - node_modules/**
        - .gitignore
        - .git/**

functions:
    second:
        handler: postgres_demo
        events:
            - http: path

运行serverless deploy总是会导致:

Deployment failed: RESOURCE_ERROR

 {"ResourceType":"cloudfunctions.v1beta2.function","ResourceErrorCode":"400","ResourceErrorMessage":"Function failed on loading user code. Error message: Code in file main.py can't be loaded.\nDid you list all required modules in requirements.txt?\nDetailed stack trace: Traceback (most recent call last):\n  File \"/env/local/lib/python3.7/site-packages/google/cloud/functions/worker.py\", line 305, in check_or_load_user_function\n    _function_handler.load_user_function()\n  File \"/env/local/lib/python3.7/site-packages/google/cloud/functions/worker.py\", line 184, in load_user_function\n    spec.loader.exec_module(main)\n  File \"<frozen importlib._bootstrap_external>\", line 728, in exec_module\n  File \"<frozen importlib._bootstrap>\", line 219, in _call_with_frames_removed\n  File \"/user_code/main.py\", line 1, in <module>\n    import psycopg2\n  File \"/user_code/psycopg2/__init__.py\", line 50, in <module>\n    from psycopg2._psycopg import (                     # noqa\nModuleNotFoundError: No module named 'psycopg2._psycopg'\n"}

1 个答案:

答案 0 :(得分:2)

我通过完全删除python-serverless-requirements并使用无服务器的package选项来确保zip文件中仅包含main.pyrequirements.txt来解决此问题。

Google云端将软件包安装在requirements.txt本身中,因此您不需要无服务器插件。 Google云端还为psycopg2提供了必要的C库。