【发布时间】:2019-07-03 06:47:24
【问题描述】:
我正在尝试在 Google App Engine 上部署 Python-Flask 应用程序。该应用程序在没有 MySQL 的情况下运行良好。在导入from flask_mysqldb import MySQL dev_appserver.py 时返回错误ImportError: No module named MySQLdb._mysql
我已经更新了 app.yaml 和 requirements.txt(也试过 MySQL-python,PyMySQL)
libraries:
- name: MySQLdb
version: latest
Flask-MySQLdb==0.2.0
mysqlclient==1.4.1
main.py 的前几行
from flask import Flask, render_template, flash, redirect, url_for, session, logging, request
from flask_mysqldb import MySQL
app = Flask(__name__)
# Config MySQL
app.config['MYSQL_HOST'] = '35.236.72.247'
app.config['MYSQL_USER'] = <removed>
app.config['MYSQL_PASSWORD'] = <removed>
app.config['MYSQL_DB'] = 'myFlaskApp'
app.config['MYSQL_CURSORCLASS'] = 'DictCursor'
# Initialize MySQL
mysql = MySQL(app)
dev_appserver.py app.yaml 的终端转储
INFO 2019-02-09 01:13:00,098 devappserver2.py:278] Skipping SDK update check.
INFO 2019-02-09 01:13:00,172 api_server.py:275] Starting API server at: http://localhost:52922
INFO 2019-02-09 01:13:00,178 dispatcher.py:256] Starting module "default" running at: http://localhost:8080
INFO 2019-02-09 01:13:00,179 admin_server.py:150] Starting admin server at: http://localhost:8000
INFO 2019-02-09 01:13:02,374 instance.py:294] Instance PID: 28866
ERROR 2019-02-09 01:13:04,295 wsgi.py:263]
Traceback (most recent call last):
File "/Users/zq/Desktop/google-cloud-sdk/platform/google_appengine/google/appengine/runtime/wsgi.py", line 240, in Handle
handler = _config_handle.add_wsgi_middleware(self._LoadHandler())
File "/Users/zq/Desktop/google-cloud-sdk/platform/google_appengine/google/appengine/runtime/wsgi.py", line 299, in _LoadHandler
handler, path, err = LoadObject(self._handler)
File "/Users/zq/Desktop/google-cloud-sdk/platform/google_appengine/google/appengine/runtime/wsgi.py", line 85, in LoadObject
obj = __import__(path[0])
File "/Users/zq/Desktop/Python-Flask/main.py", line 3, in <module>
from flask_mysqldb import MySQL
File "/Users/zq/Desktop/Python-Flask/lib/flask_mysqldb/__init__.py", line 1, in <module>
import MySQLdb
File "/Users/zq/Desktop/Python-Flask/lib/MySQLdb/__init__.py", line 18, in <module>
from . import _mysql
File "/Users/zq/Desktop/google-cloud-sdk/platform/google_appengine/google/appengine/tools/devappserver2/python/runtime/sandbox.py", line 1097, in load_module
raise ImportError('No module named %s' % fullname)
ImportError: No module named MySQLdb._mysql
INFO 2019-02-09 01:13:04,301 module.py:861] default: "GET / HTTP/1.1" 500 -
我该如何解决这个问题?或者,在我的烧瓶应用程序中使用 MySQL?该应用程序在我的系统上使用 MySQL 本地运行良好。
【问题讨论】:
-
你安装的是什么版本的mysqlclient?安装版本 1.4.1(删除 1.4.2)
-
你是对的。我重新安装了 mysqlclient 指定 pip mysqlclient==1.4.1 并且至少它现在检测到 mysql 模块。谢谢
-
现在的错误是:from MySQLdb import * AttributeError: 'module' object has no attribute 'NULL'。我会调查的
标签: python google-app-engine flask google-cloud-platform mysql-python