先来看查看效果:

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

关于python代码:

#!/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 list 完成最简单的DB连接池的更多相关文章

  1. 用swoole简单实现MySQL连接池

    MySQL连接池 在传统的网站开发中,比如LNMP模式,由Nginx的master进程接收请求然后分给多个worker进程,每个worker进程再链接php-fpm的master进程,php-fpm再 ...

  2. Go语言之从0到1实现一个简单的Redis连接池

    Go语言之从0到1实现一个简单的Redis连接池 前言 最近学习了一些Go语言开发相关内容,但是苦于手头没有可以练手的项目,学的时候理解不清楚,学过容易忘. 结合之前组内分享时学到的Redis相关知识 ...

  3. 自定义一个简单的JDBC连接池

    一.什么是JDBC连接池? 在传统的JDBC连接中,每次获得一个Connection连接都需要加载通过一些繁杂的代码去获取,例如以下代码: public static Connection getCo ...

  4. 转 Swoole】用swoole简单实现MySQL连接池

    MySQL连接池 在传统的网站开发中,比如LNMP模式,由Nginx的master进程接收请求然后分给多个worker进程,每个worker进程再链接php-fpm的master进程,php-fpm再 ...

  5. Redis 简单使用 and 连接池(python)

    Redis 简介 NoSQL(not only sql):非关系型数据库 支持 key-value,  list,  set,  zset,  hash 等数据结构的存储:支持主从数据备份,集群:支持 ...

  6. python 基础 10.0 nosql 简介--redis 连接池及管道

    一. NOSQL 数据库简介 NoSQL 泛指非关系型的数据库.非关系型数据库与关系型数据库的差别 非关系型数据库的优势: 1.性能NOSQL 是基于键值对的,可以想象成表中的主键和值的对应关系,而且 ...

  7. 自定义DB连接池实现

    实现一个简单的数据库连接池 1,连接池接口 package dbsource; import java.sql.Connection; import java.sql.SQLException; /* ...

  8. Redisclient连接方式Hiredis简单封装使用,连接池、屏蔽连接细节

    工作须要对Hiredis进行了简单封装,实现功能: 1.API进行统一,对外仅仅提供一个接口. 2.屏蔽上层应用对连接的细节处理: 3.底层採用队列的方式保持连接池,保存连接会话. 4.重连时採用时间 ...

  9. 利用Python进行数据分析(1) 简单介绍

    一.处理数据的基本内容 数据分析 是指对数据进行控制.处理.整理.分析的过程. 在这里,“数据”是指结构化的数据,例如:记录.多维数组.Excel 里的数据.关系型数据库中的数据.数据表等. 二.说说 ...

随机推荐

  1. PYTHON基础-入门

    变量名可以是数字,字母,下划线,字母不能开头.

  2. ORA-12541:TNS:无监听程序

    1.OracleServiceORCL确认已经在服务中启动 2.OracleOraDb11g_home1TNSListener确认已经在服务中启动 3.服务端listener.ora和tnsnames ...

  3. express 内存溢出问题分析定位

    一.现象 1. 如下报错 FATAL ERROR: CALL_AND_RETRY_LAST Allocation failed - JavaScript heap out of memory 1: n ...

  4. Spring <mvc:default-servlet-handler/>

    优雅REST风格的资源URL不希望带 .html 或 .do 等后缀.由于早期的Spring MVC不能很好地处理静态资源,所以在web.xml中配置DispatcherServlet的请求映射,往往 ...

  5. dubbo 面试

    1.使用dubbo+zookeeper ,如果注册中心挂掉,是否可以继续通信?(zk集群可以达到高可用,但是如果全部挂掉呢?) 我答了不可以吧(项目没用过,自学没又这深度) 正确答案: dubbo使用 ...

  6. Spring:AOP

    摘要 本文内容为我在网上搜集Spring AOP资料的汇总.摘抄. AOP是一种编程思想,其对不同对象进行了横向的抽象,将不同对象的.和主流程无关的公共逻辑抽象出来以方便维护.AOP的实现基础为AOP ...

  7. volatile和synchronized实现内存可见性的区别

    先看看synchronized实现内存可见性 加锁(synchronized同步)的功能不仅仅局限于互斥行为,同时还存在另外一个重要的方面:内存可见性.我们不仅希望防止某个线程正在使用对象状态而另一个 ...

  8. 企业BGP网络规划案例(二)

    设计思路梳理 1.AS的划分 : 由于该办公网物理上被划分为总部和两个异地的办公分支,总部和分支互联采用MSTP线路,为了方便管理和更为灵活的进行路由控制,选择BGP作为总部和分支的路由协议.关于AS ...

  9. SCRUM管理之KPI与OKRs结合

    以下内容是本人在担任ScrumMaster中的实际应用,供大家交流学习参考. 目录 1绩效考核原则 4 2绩效考核范围 4 3绩效计算 4 3.1KPI 4 3.1.1KPI指标评分表 4 3.1.2 ...

  10. Hillstone基础上网配置

    1.接口配置 1)进入设备管理界面后,点击左边 网络—接口: 2)选择相应的接口,点击编辑: 3)在接口配置界面中,选择接口的安全域类型(三层接口即为三层安全域,二层接口即为二层安全域).安全域名称 ...