【发布时间】:2019-09-10 07:12:43
【问题描述】:
我正在开发一个集成了 MySQL (flask-mysqldb) 和 MQTT (flask-mqtt) 的 Flask 应用程序。我可以从 Flask 方法(例如 @app.route('/'))执行任何 DB 操作,但如果我在收到消息时尝试从 MQTT 方法执行此操作(例如 @mqtt.on_message()),它什么也不做。最后一种方法非常有效,因为它接收并在日志中显示收到的消息。
我有一个执行数据库操作的方法,取决于我从哪里调用它,它是否有效。我猜应该是mysql对象的原因,但具体我也不知道。
这是我正在使用的代码(只是问题):
@mqtt.on_message()
def handle_mqtt_message(client, userdata, message):
print('New message {}'.format(message.payload.decode()))
storeDB('test') #Here it doesn't work
################## Methods ###########################
def storeDB(param_text):
cur = mysql.connection.cursor()
cur.execute(
'INSERT INTO contacts (fullname, phone, email) VALUES (%s,%s,%s)', (param_text, param_text, param_text))
mysql.connection.commit()
###################### FLASK #########################
@app.route('/')
def index():
storeDB('temp') #Here it works
return 'Hello World'
如果我访问localhost,它会在浏览器中显示“Hello World”文本并更新数据库;否则,如果我收到一条 MQTT 消息,它会显示在终端上,但不会更新数据库。
谢谢。
【问题讨论】:
-
好吧,我猜这个问题来自
flask-mysqldb包。我现在已经使用原生 MySQLdb Python 包 (MySQLdb) 进行了尝试,它运行良好(有点“棘手”,但工作正常,正是我所期望的)。我知道这本身不是一个解决方案,因为我正在使用另一个包,但它是使它工作的另一种方法。
标签: python-3.x flask mqtt mysql-python