利用python list完成最简单的DB连接池方法


Posted in Python onAugust 09, 2019

先来看查看效果:

利用python list完成最简单的DB连接池方法

在代码连接数据库后,并且执行三条sql后,将mysql直接重启掉,故我们的连接池连接均是不ok的,所以,它会全部删除再抓新的连接下来,重启mysql命令:

利用python list完成最简单的DB连接池方法

关于python代码:

'''
遇到问题没人解答?小编创建了一个Python学习交流QQ群:857662006 
寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!
'''
#!/usr/bin/env python3
# -*- coding: UTF-8 -*-

import pymysql
import random
import time

# 初始化mysql 连接池
def MySQLInit(mysql_host,mysql_port,mysql_user,mysql_password,mysql_charset,mysql_dbname,mysql_maxconnect):

  # 定义返回mysql连接池的类型,这里定义为 list   
  return_db_list = []

  for Connect in range(0,mysql_maxconnect):
    try:
      db = pymysql.connect(
        host = mysql_host , 
        port = mysql_port , 
        user = mysql_user , 
        passwd = mysql_password ,
        db = mysql_dbname ,
        charset = mysql_charset 
      )

      print ("连接MySQL数据库成功,MySQL数据库ID为:%s" %(db))
      return_db_list.append(db)
    except Exception as e:
      print ("连接MySQL数据库出错")
      print (e)

  # 如果mysql连接池为空,则返回-1
  if 0 == len(return_db_list):
    print ("错误 , 连接MySQL数据库失败,连接池为0")
    return -1

  else:
    # 返回mysql连接池
    return return_db_list

def Pull_DB_Connect(mysql_host,mysql_port,mysql_user,mysql_password,mysql_charset,mysql_dbname , MySQL_Connect_Pool , mysql_maxconnect) :
  
  # 打印补充前的mysql连接数
  print ("补充前MySQL连接数为:",len(MySQL_Connect_Pool))
  
  # 循环相差的连接数
  for Connect in range((len(MySQL_Connect_Pool)) , mysql_maxconnect):
    try:
      db = pymysql.connect(
        host = mysql_host , 
        port = mysql_port , 
        user = mysql_user , 
        passwd = mysql_password ,
        db = mysql_dbname ,
        charset = mysql_charset 
      )

      print ("重新补充,连接MySQL数据库成功,MySQL数据库ID为:%s" %(db))
      # 将刚刚连接成功的DB连接追加到MySQL_Connect_Pool中
      MySQL_Connect_Pool.append(db)
    except Exception as e:
      print ("重新补充,连接MySQL数据库出错")
      print (e)

  if 0 == len(MySQL_Connect_Pool):
    print ("错误 , 连接MySQL数据库失败,连接池为0")
    return -1

  else:
    # 打印连接池总数并且返回
    print("Mysql 连接池总数为:" , len(MySQL_Connect_Pool))
    return MySQL_Connect_Pool 

def main() :

  # 定义测试mysql信息
  mysql_host = "192.168.1.100"
  mysql_port = 3306
  mysql_user = "liwang" 
  mysql_password = "liwang"
  mysql_charset = "utf8"
  mysql_dbname = "itchat"
  mysql_maxconnect = 3

  # 初始化mysql连接池
  MySQL_Connect_Pool = MySQLInit(mysql_host,mysql_port,mysql_user,mysql_password,mysql_charset,mysql_dbname,mysql_maxconnect)

  # 定义初始化sql 
  sql = "show databases;"

  
  while True:
    # 随机获连接池的下标
    db_link = random.randint(0,len(MySQL_Connect_Pool)-1)
    try:
      # 执行sql 
      cursor = MySQL_Connect_Pool[db_link].cursor()
      cursor.execute(sql)
      print (cursor.fetchall())
    except Exception as e:
      # 如果执行失败,模拟为DB连接失效,则打印错误信息,删除错误的MySQL_Connect_Pool信息
      print (e)
      del MySQL_Connect_Pool[db_link]
      print ("数据库无法连接,删除Mysql连接池下标:" , db_link)
      # 重新补充mysql连接池
      Pull_DB_Connect(mysql_host,mysql_port,mysql_user,mysql_password,mysql_charset,mysql_dbname,MySQL_Connect_Pool,mysql_maxconnect)
    
    # 休眠10s 
    time.sleep(10)

if __name__ == "__main__" :
  main()

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python连接sql server乱码的解决方法
Jan 28 Python
python写入中英文字符串到文件的方法
May 06 Python
利用Python生成文件md5校验值函数的方法
Jan 10 Python
python实现excel读写数据
Mar 02 Python
python3下使用cv2.imwrite存储带有中文路径图片的方法
May 10 Python
pandas.dataframe按行索引表达式选取方法
Oct 30 Python
对python捕获ctrl+c手工中断程序的两种方法详解
Dec 26 Python
python列表的逆序遍历实现
Apr 20 Python
解决Keras使用GPU资源耗尽的问题
Jun 22 Python
python闭包与引用以及需要注意的陷阱
Sep 18 Python
Python通过队列来实现进程间通信的示例
Oct 14 Python
利用Python实现学生信息管理系统的完整实例
Dec 30 Python
python使用requests.session模拟登录
Aug 09 #Python
如何在Cloud Studio上执行Python代码?
Aug 09 #Python
python切片(获取一个子列表(数组))详解
Aug 09 #Python
Python多叉树的构造及取出节点数据(treelib)的方法
Aug 09 #Python
一行python实现树形结构的方法
Aug 09 #Python
解决django同步数据库的时候app models表没有成功创建的问题
Aug 09 #Python
Python3 venv搭建轻量级虚拟环境的步骤(图文)
Aug 09 #Python
You might like
PHP通过session id 实现session共享和登录验证的代码
2012/06/03 PHP
PHP关联链接常用代码
2012/11/05 PHP
2014年10个最佳的PHP图像操作库
2014/07/14 PHP
php字符串截取函数用法分析
2014/11/25 PHP
PHP7内核CGI与FastCGI详解
2019/04/14 PHP
laravel框架创建授权策略实例分析
2019/11/22 PHP
extJs 下拉框联动实现代码
2010/04/09 Javascript
jquery1.5.1中根据元素ID获取元素对象的代码
2011/04/02 Javascript
js中widow.open()方法使用详解
2013/07/30 Javascript
Javascript闭包(Closure)详解
2015/05/05 Javascript
js轮播图代码分享
2016/07/14 Javascript
Ajax分页插件Pagination从前台jQuery到后端java总结
2016/07/22 Javascript
canvas滤镜效果实现代码
2017/02/06 Javascript
详解Node项目部署到云服务器上
2017/07/12 Javascript
vue router使用query和params传参的使用和区别
2017/11/13 Javascript
vue中如何创建多个ueditor实例教程
2017/11/14 Javascript
(模仿京东用户注册)用JQuery实现简单表单验证,初学者必看
2018/01/08 jQuery
babel之配置文件.babelrc入门详解
2018/02/22 Javascript
javascript自定义日期比较函数用法示例
2019/07/22 Javascript
vue动态子组件的两种实现方式
2019/09/01 Javascript
JavaScript监听键盘事件代码实现
2020/06/03 Javascript
[50:15]VP vs Mineski 2018国际邀请赛淘汰赛BO3 第二场 8.22
2018/08/23 DOTA
Python获取电脑硬件信息及状态的实现方法
2014/08/29 Python
用Python编写简单的微博爬虫
2016/03/04 Python
普通院校学生的自荐信
2013/11/27 职场文书
巧克力蛋糕店创业计划书
2014/01/14 职场文书
一年级数学教学反思
2014/02/01 职场文书
计算机网络工程专业职业生涯规划书
2014/03/10 职场文书
西式结婚主持词
2014/03/14 职场文书
二审代理词范文
2015/05/25 职场文书
2016年企业先进员工事迹材料
2016/02/25 职场文书
2016年党员干部廉政承诺书
2016/03/24 职场文书
教你用Python写一个植物大战僵尸小游戏
2021/04/25 Python
python前后端自定义分页器
2022/04/13 Python
Python如何让字典保持有序排列
2022/04/29 Python
css如何把元素固定在容器底部的四种方式
2022/06/16 HTML / CSS