我看到了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的解决方案? 谢谢
答案 0 :(得分:3)
您引用的链接应该为您提供几乎所有需要的内容。
您应该(!?)能够为GCS存储桶事件触发该功能,但是您需要确保正确部署该功能:
请参阅:https://cloud.google.com/functions/docs/calling/storage#object_finalize
您需要import sqlalchemy
。您已将软件包包含在requirements.txt
中,但是错过了第二步。
创建Cloud SQL实例,数据库等后,您需要更新connection_name
,db_password
等的值。
我认为您的query_string
陈述是错误的,可能会更好:
query_string = dict({"unix_socket": "/cloudsql/{}".format(connection_name)})
这可能是错误的根源。