gpt4 book ai didi

python - 服务器运行时重新创建 SQLAlchemy 对象是否安全?

转载 作者:太空宇宙 更新时间:2023-11-03 21:44:51 25 4
gpt4 key购买 nike

我们的应用程序使用flask + Gunicorn。现在我们希望让它能够在运行时重新加载数据库配置,这意味着它可以切换到新的数据库而无需重新启动进程。在配置中心的帮助下,我们可以在运行时调度配置,但是如何重新初始化全局变量数据库?

db = SQLAlchemy()
def create_app():
app = Flask(__name__)
app.config.from_object(dynamic_config)
db.init_app(app)

并假设在某个时候。我们发送新的配置,如何使用新的配置来初始化数据库?或者用新的 SQLAlchemy() 实例替换它是否安全?就像这样做:

from models import set_db # which will set global db to new instance
from app import app
def callback(odl, new):
new_db = SQLAlchemy()
# re-construct config with old, and new
# now app.config is updated
new_db.init_app(app)
set_db(new_db)

这样做可以吗?我担心,这会导致线程安全之类的问题,并可能破坏 Transaction。

帮我解决这个问题,非常感谢

最佳答案

如果我是你,我会使用 SQLALCHEMY_BINDS配置或具有不同配置的数据库的不同实例,而不是每次都更改配置。我认为使用应用程序更改数据库结构不是一个好习惯(如果您这样做)

关于python - 服务器运行时重新创建 SQLAlchemy 对象是否安全?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52574775/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com