您能否教我如何将GCP中的云功能连接到云SQL?

时间:2020-07-01 14:20:55

标签: python google-cloud-platform google-cloud-functions google-cloud-sql mysql-python

我看到了GCP快速入门(https://cloud.google.com/sql/docs/mysql/quickstart-connect-functions),并尝试将Google云功能连接到Cloud SQL的My SQL。实际上,该网站正在使用HTTP触发器,但是我想在GCS中使用“完成/创建”操作作为云功能的触发器。因此,我使用了以下python代码和txt代码。

【MAIN.PY】

import sqlalchemy
from google.cloud import storage

# Set the following variables depending on your specific
# connection name and root password from the earlier steps:


def sql_select(data, context):
    connection_name = "INSTANCE_CONNECTION_NAME"
    db_password = "DATABASE_USER_PASSWORD"
    db_name = "DATABASE_NAME"
    db_user = "root" 
    driver_name = 'mysql+pymysql'
    query_string = '"unix_socket": "/cloudsql/{}".format(connection_name)'
    print("I am here 1")

    db = sqlalchemy.create_engine(
        sqlalchemy.engine.url.URL(
            drivername=driver_name,
            username=db_user,
            password=db_password,
            database=db_name,
            query={query_string},
        ),
        pool_size=5,
        max_overflow=2,
        pool_timeout=30,
        pool_recycle=1800)
    

    # stmt = sqlalchemy.text('INSERT INTO entries (guestName, content) values ("third guest", "Also this one");')
    # try:
    #     with db.connect() as conn:
    #         conn.execute(stmt)
    # except Exception as e:
    #     return 'Error: {}'.format(str(e))
    # return 'ok'

【REQUIREMENTS.TXT】

SQLAlchemy==1.3.18

    PyMySQL==0.9.3

Click==7.0
Flask==1.0.2
itsdangerous==1.1.0
Jinja2==2.10
MarkupSafe==1.1.0
Pillow==5.4.1
qrcode==6.1
six==1.12.0
Werkzeug==0.14.1
google-cloud-storage==1.23.0

我试图通过按“测试功能”选项卡来测试代码。但是我遇到以下错误,无法将我制作的云函数连接到云SQL(My SQL)。

【错误信息】

Error: function terminated. Recommended action: inspect logs for termination reason. Details:
'set' object has no attribute 'get' 

我试图更改为最新版本的sqlalchemy。但是我无法解决错误。 而且我不知道要解决这个问题。 是否有将云功能连接到云SQL的解决方案? 谢谢

1 个答案:

答案 0 :(得分:3)

您引用的链接应该为您提供几乎所有需要的内容。

您应该(!?)能够为GCS存储桶事件触发该功能,但是您需要确保正确部署该功能:

请参阅:https://cloud.google.com/functions/docs/calling/storage#object_finalize

您需要import sqlalchemy。您已将软件包包含在requirements.txt中,但是错过了第二步。

创建Cloud SQL实例,数据库等后,您需要更新connection_namedb_password等的值。

我认为您的query_string陈述是错误的,可能会更好:

query_string = dict({"unix_socket": "/cloudsql/{}".format(connection_name)})

这可能是错误的根源。