mysql⾃定义变量拼接_开发⾃定义Mysql连接池
使⽤第三⽅包
tar -zxvf *. * python3 tup.py build && python3 tup.py installimport time
import pymysql
import threading
from DBUtils.PooledDB import PooledDB, SharedDBConnection
POOL = PooledDB(
creator=pymysql, # 使⽤链接数据库的模块
maxconnections=6, # 连接池允许的最⼤连接数,0和None表⽰不限制连接数
mincached=2, # 初始化时,链接池中⾄少创建的空闲的链接,0表⽰不创建
maxcached=5, # 链接池中最多闲置的链接,0和None不限制
maxshared=3, # 链接池中最多共享的链接数量,0和None表⽰全部共享。PS: ⽆⽤,因为pymysql和MySQLdb等模块
的 threadsafety都为1,所有值⽆论设置为多少,_maxcached永远为0,所以永远是所有链接都共享。
blocking=True, # 连接池中如果没有可⽤连接后,是否阻塞等待。True,等待;Fal,不等待然后报错
maxusage=None, # ⼀个链接最多被重复使⽤的次数,None表⽰⽆限制
tssion=[], # 开始会话前执⾏的命令列表。如:["t datestyle to ...", "t time zone ..."]
ping=0,
# ping MySQL服务端,检查是否服务可⽤。# 如:
0 = None = never, 1 = default = whenever it is requested, 2 = when a cursor is created, 4 = when a query is executed, 7 = always
host='127.0.0.1',
port=3306,
ur='root',
password='123',
databa='pooldb',
chart='utf8'
)
def func():
# 检测当前正在运⾏连接数的是否⼩于最⼤链接数,如果不⼩于则:等待或报rai TooManyConnections异常
# 否则
# 则优先去初始化时创建的链接中获取链接 SteadyDBConnection。
# 然后将SteadyDBConnection对象封装到PooledDedicatedDBConnection中并返回。
# 如果最开始创建的链接没有链接,则去创建⼀个SteadyDBConnection对象,再封装到PooledDedicatedDBConnection中并返回。
# ⼀旦关闭链接后,连接就返回到连接池让后续线程继续使⽤。
conn = tion()
# print(th, '链接被拿⾛了', conn1._con)
# print(th, '池⼦⾥⽬前有', pool._idle_cache, '\r\n') cursor = conn.cursor()
result = cursor.fetchall()
#并没有关闭,只是把连接放回到了连接池中
conn.clo()
func()