mysql自定义变量拼接_开发自定义Mysql连接池

更新时间:2023-05-12 02:36:44 阅读: 评论:0

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()

本文发布于:2023-05-12 02:36:44,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/fan/89/885942.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:链接   创建   连接   是否   等待
相关文章
留言与评论(共有 0 条评论)
   
验证码:
推荐文章
排行榜
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图