【问题标题】:How do I connect to a remote MySQL db using Flask Application Factory and Peewee FlaskDB如何使用 Flask Application Factory 和 Peewee FlaskDB 连接到远程 MySQL 数据库
【发布时间】:2021-10-18 02:39:50
【问题描述】:

我正在学习 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 配置(但我这辈子还没有工作过)是:

    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,所以我看不到问题所在。

(另外,如果有人对在上述场景中启动和运行加密有任何指示,那就太好了!)

【问题讨论】:

    标签: mysql flask peewee python-3.9


    【解决方案1】:

    您需要确保安装了 python mysql 绑定。通常你会想要安装 pymysql:

    pip install pymysql
    

    【讨论】:

    • 谢谢!完美运行。关于如何指定与 SSL 连接的任何想法?对于我指定的任何其他参数,我都会收到“TypeError: __init__() got an unexpected keyword argument 'requireSSL'”。
    猜你喜欢
    • 2018-10-26
    • 1970-01-01
    • 2023-03-13
    • 2013-05-03
    • 2013-02-13
    • 2011-01-20
    • 1970-01-01
    • 2016-03-06
    • 1970-01-01
    相关资源
    最近更新 更多