[英]Connect to AWS RDS MySQL database instance with Flask-SQLAlchemy
对于我的 Flask 应用程序,我想使用 Flask-SQLAlchemy 扩展连接到我在 AWS RDS 上创建的数据库实例。
当我尝试连接时,应用程序超时并出现以下错误:
sqlalchemy.exc.OperationalError: (OperationalError) (2003, "无法连接到 MySQL 服务器上的 'xxxxxxxxxxxxxxx.xxxxxxxxxxxx.us-east-1.rds.amazonaws.com'(60")
我的代码如下所示:
from flask import Flask
from flask.ext.sqlalchemy import SQLAlchemy
application = Flask(__name__)
application.config['SQLALCHEMY_DATABASE_URI'] = 'mysql://{master username}:{db password}@{endpoint}/{db instance name}'
db = SQLAlchemy(application)
@application.route('/')
def hello_world():
return 'Hello World'
if __name__ == '__main__':
application.run()
Flask-SQLAlchemy 文档说 mysql 数据库连接的 SQLALCHEMY_DATABASE_URI 的格式应该如下所示:
mysql://username:password@server/db
此外,我可以查看 AWS RDS 控制台以获取有关我的数据库实例的信息。 控制台看起来像这样。
现在我假设 SQLAlchemy 中的“用户名”指的是 AWS RDS 控制台中的“主用户名”,SQLAlchemy 中的“服务器”指的是 AWS RDS 控制台中的“端点”,而“db”指的是“数据库”实例名称”
我究竟做错了什么??
如果有人可以用 AWS RDS 控制台术语为我描述 SQLALCHEMY_DATABASE_URI,那将完全解决问题。
转到您的 AWS RDS 控制台并选择您的实例 -> 数据库安全组 -> 单击默认
并根据推荐的 IP 范围添加新的 CIDR。
这基本上是一个防火墙配置,它决定了谁可以连接到数据库实例。
您可以将其设置为 0.0.0.0/0,这样防火墙就不会阻止您从任何主机/网络访问它。
确保在附加配置下的数据库初始设置中创建数据库名称,除非 AWS RDS 不会创建数据库。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.