如何使用 Flask Application Factory 和 Peewee FlaskDB 连接到远程 MySQL 数据库
How do I connect to a remote MySQL db using Flask Application Factory and Peewee FlaskDB
我正在学习 Flask 并一直在开发应用程序,在使用 SQLite 数据库时一切正常。但是,当我尝试连接到远程 MySQL 服务器(使用或不使用 SSL)时,我一无所获。
这是__init__.py
import os
from flask import Flask
from peewee import *
from playhouse.flask_utils import FlaskDB
from flask_bcrypt import Bcrypt
from flask_login import LoginManager
from flask_mail import Mail
from myapi.config import Config
from myapi.main.loggers import logger
db = FlaskDB()
bcrypt = Bcrypt()
login_manager = LoginManager()
login_manager.login_view = 'users.login'
login_manager.login_message_category = 'info'
mail = Mail()
def create_app(config_class=Config):
app = Flask(__name__)
app.config.from_object(Config)
db.init_app(app)
bcrypt.init_app(app)
login_manager.init_app(app)
mail.init_app(app)
from myapi.users.routes import users
from myapi.posts.routes import posts
from myapi.main.routes import main
from myapi.errors.handlers import errors
app.register_blueprint(users)
app.register_blueprint(posts)
app.register_blueprint(main)
app.register_blueprint(errors)
logger.info('App has been created.')
return app
有效的数据库配置:
DATABASE = {
'name': 'example.db',
'engine': 'peewee.SqliteDatabase',
}
我想使用的数据库配置(但我一生还没有准备好)是:
DATABASE = {
'name': 'mydb',
'engine': 'peewee.MySQLDatabase',
'user': 'root',
'passwd': 'root',
'host': 'xxx.xxx.xxx.xxx'}
我从 python 得到的错误是:
peewee.ImproperlyConfigured: MySQL driver not installed!
我可以通过 MySQL Workbench 和 HeidiSQL 连接到 MySQL,所以我看不到问题所在。
(此外,如果有人对在上述情况下进行加密和 运行 有任何指示,那就太好了!)
您需要确保安装了 python mysql 绑定。通常你会想要安装 pymysql:
pip install pymysql
我正在学习 Flask 并一直在开发应用程序,在使用 SQLite 数据库时一切正常。但是,当我尝试连接到远程 MySQL 服务器(使用或不使用 SSL)时,我一无所获。
这是__init__.py
import os
from flask import Flask
from peewee import *
from playhouse.flask_utils import FlaskDB
from flask_bcrypt import Bcrypt
from flask_login import LoginManager
from flask_mail import Mail
from myapi.config import Config
from myapi.main.loggers import logger
db = FlaskDB()
bcrypt = Bcrypt()
login_manager = LoginManager()
login_manager.login_view = 'users.login'
login_manager.login_message_category = 'info'
mail = Mail()
def create_app(config_class=Config):
app = Flask(__name__)
app.config.from_object(Config)
db.init_app(app)
bcrypt.init_app(app)
login_manager.init_app(app)
mail.init_app(app)
from myapi.users.routes import users
from myapi.posts.routes import posts
from myapi.main.routes import main
from myapi.errors.handlers import errors
app.register_blueprint(users)
app.register_blueprint(posts)
app.register_blueprint(main)
app.register_blueprint(errors)
logger.info('App has been created.')
return app
有效的数据库配置:
DATABASE = {
'name': 'example.db',
'engine': 'peewee.SqliteDatabase',
}
我想使用的数据库配置(但我一生还没有准备好)是:
DATABASE = {
'name': 'mydb',
'engine': 'peewee.MySQLDatabase',
'user': 'root',
'passwd': 'root',
'host': 'xxx.xxx.xxx.xxx'}
我从 python 得到的错误是:
peewee.ImproperlyConfigured: MySQL driver not installed!
我可以通过 MySQL Workbench 和 HeidiSQL 连接到 MySQL,所以我看不到问题所在。
(此外,如果有人对在上述情况下进行加密和 运行 有任何指示,那就太好了!)
您需要确保安装了 python mysql 绑定。通常你会想要安装 pymysql:
pip install pymysql