繁体   English   中英

如何将flask-sqlalchemy与Google Cloud Functions结合使用?

[英]How can I use flask-sqlalchemy with Google Cloud Functions?

如何将flask-sqlalchemy与Google Cloud Functions和Cloud SQL等功能集成?

查看最小的应用程序示例 ,它包装了app变量:

from flask import Flask
from flask_sqlalchemy import SQLAlchemy

app = Flask(__name__)
app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:////tmp/test.db'
db = SQLAlchemy(app)

class User(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    username = db.Column(db.String(80), unique=True, nullable=False)
    email = db.Column(db.String(120), unique=True, nullable=False)

    def __repr__(self):
        return '<User %r>' % self.username

但我的Google Cloud功能无法访问任何名为app

def my_function(request):
    return "Hello world!"

使用app = Flask(__name__)创建我自己的应用app = Flask(__name__)不起作用,因为Cloud Functions不使用此应用程序来返回响应。

您可以改用flask.current_app 您还必须配置flask-sqlalchemy以使用CloudSQL提供的Unix域套接字:

from flask import current_app as app
from flask_sqlalchemy import SQLAlchemy

# Set these in the environment variables for the function
db_user = os.environ.get('CLOUD_SQL_USERNAME')
db_password = os.environ.get('CLOUD_SQL_PASSWORD')
db_name = os.environ.get('CLOUD_SQL_DATABASE_NAME')
db_connection_name = os.environ.get('CLOUD_SQL_CONNECTION_NAME')

# This is for Postgres, it's similar for MySQL
app.config['SQLALCHEMY_DATABASE_URI'] = f'postgresql://{db_user}:{db_password}@/{db_name}?host=/cloudsql/{db_connection_name}'

# This must be set, determine which is best for you
app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = False

db = SQLAlchemy(app)
...

然后,您可以在函数中查询User模型:

def my_function(request):
    user = User.query.first()
    return f"Hello {user.username)!"

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM