我想将我的python程序从普通连接更改为连接池,以便在几个小时内没有发送查询时数据库连接不会丢失,并且数据库不会一次被一堆查询淹没使用高峰。
我使用的是 Python 3.7.4、mysql-connector-python 8.0.17 和 MariaDB 10.4.7。
当我使用正常连接时它工作正常,但 MariaDB 显然不支持pool_reset_session
的设定mysql.connector.pooling.MySQLConnectionPool
在我的代码开始时,它会尝试创建数据库(如果数据库尚不存在),这导致了我收到的错误。
import mysql.connector as mariadb
from mysql.connector import errorcode
from mysql.connector import pooling
cnx = mariadb.pooling.MySQLConnectionPool(user='root', password='password', host='localhost',
pool_name='connectionpool', pool_size=10, pool_reset_session=True)
try:
db = cnx.get_connection()
cursor = db.cursor()
cursor.execute("CREATE DATABASE IF NOT EXISTS tests")
print("Created database")
except mariadb.Error as err:
print(f"Failed creating database: {err}")
finally:
print("Finally (create)")
db.close()
我预计这个片段只会创建数据库tests
但我得到了以下两个错误:
mysql.connector.errors.NotSupportedError: MySQL version 5.7.2 and earlier does not support COM_RESET_CONNECTION.
也
mysql.connector.errors.OperationalError: 1047 (08S01): Unknown command
从回溯日志来看,这似乎是由于尝试执行而引起的db.close()
在第 17 行。
带回溯的完整输出:https://pastebin.com/H3SAvA9N https://pastebin.com/H3SAvA9N
我问我能做些什么来解决这个问题,以及是否可以在 MariaDB 10.4.7 中使用这种连接池(我很困惑,因为它说 MySQL
我还发现 MariaDB Connector/J 确实提供了这样一个选项,称为useResetConnection
但我不想仅仅为了这个功能而学习Java。