我有一个 Flask 应用程序,使用 Flask-SQLAlchemy 和 MySQL 数据库,其中数据库定义如下:
db.py
:
from flask_sqlalchemy import SQLAlchemy
db = SQLAlchemy()
main.py
:
from db import db
app = Flask(__name__)
app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = False
app.config['SQLALCHEMY_DATABASE_URI'] = "mysql+pymysql://" + \
DB_USERNAME + ":" + DB_PASSWORD + "@" + DB_HOST + "/" + DB_DATABASE
db.init_app(app)
@app.teardown_appcontext
def teardown_db(error):
db.session.close()
db.engine.dispose()
user.py
:
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)
我使用模型查询我的数据库db.engine.execute()
在需要时编写原始 SQL 查询或使用集成的 Flask-SQLAlchemy API 来读取数据,例如User.query.filter_by().all()
.
我使用以下命令将新数据写入数据库:
new_user_entry = User(username = "abc", email = "[email protected] /cdn-cgi/l/email-protection")
db.session.add(new_user_entry)
db.session.commit()
我正在使用监控我的 MySQL 服务器show processlist
我注意到,对于我收到的每个请求,数据库连接都会不断增加 2。数据库连接似乎只有当我停止 Flask 进程时才会重置。随着时间的推移,MySQL 服务器会抛出以下错误:
`sqlalchemy.exc.TimeoutError: QueuePool limit of size 10 overflow 10 reached, connection timed out, timeout 30 (Background on this error at: http://sqlalche.me/e/3o7r)`
我使用 Gunicorn 和 gevent/eventlet 以及 2 个工作进程来为应用程序提供服务。我用的是python3。
我在这里错过了什么吗?我尝试结束数据库会话并处置引擎,但这似乎不起作用。