数据处理框架用到 mysql, 需要在多进程中的多线程中使用 mysql 的连接
使用到的模块: DBUtils

实现:

  1. 使用 DBUtils 中的 PooledDB 类来实现.

  2. 自己写一个类, 继承 PooledDB 类, 这样就能使用到 PooledDB 中的其它常用的方法.

  3. 使用单例模式, 确保整个应用服务中只有一个连接池对象.

  4. 使用: 可以定义全局变量初始化连接池对象, 在别的地方获取mysql连接使用.

连接池 demo:

  1. # coding: utf-8
  2. import pymysql
  3. import functools
  4. from seemmo.common.time_func import now_time, today
  5. from conf.config import DB_HOST, DB_PORT, DB_USER, DB_NAME, DB_CHARSET
  6. from pymysql.cursors import DictCursor
  7. from DBUtils.PooledDB import PooledDB

  8. # 获取加密的mysql密码
  9. from seemmo.common.utils import get_pwd
  10. DB_PASSWD = get_pwd("mysql_pwd")


  11. class MysqlPool(PooledDB):
  12. __instance = None
  13. __pool = None

  14. def __new__(cls, *args, **kwargs):
  15. if not cls.__instance:
  16. # cls.__instance = object.__new__(cls)
  17. cls.__instance = super().__new__(cls)
  18. return cls.__instance

  19. def __init__(self):
  20. """创建链接池"""
  21. PooledDB.__init__(self, pymysql, maxconnections=50, mincached=0, maxcached=0, maxshared=0, blocking=True, host=DB_HOST, port=DB_PORT,user=DB_USER, password=DB_PASSWD, database=DB_NAME, charset=DB_CHARSET, cursorclass=DictCursor)

  22. def conn(self):
  23. _conn = self.connection()
  24. return _conn

使用 (装饰器) :

  1. # 创建连接池对象
  2. mysql_pool = MysqlPool()


  3. # mysql 闭包环境
  4. def db_wrap(method):
  5. @functools.wraps(method)
  6. def _wrapper(*args, **kwargs):
  7. conn = mysql_pool.conn()
  8. cursor = conn.cursor()
  9. try:
  10. conn.begin()
  11. retval = method(cursor, *args, **kwargs)
  12. conn.commit()
  13. except Exception as e:
  14. conn.rollback()
  15. raise e
  16. finally:
  17. cursor.close()
  18. conn.close()
  19. return retval
  20. return _wrapper


  21. @db_wrap
  22. def create_table(cursor, sql):
  23. ret = cursor.execute(sql)
  24. return ret


  25. @db_wrap
  26. def query_by_index(cursor, table_name, start_index, next_index):
  27. """
  28. 根据 index 范围查询违法记录
  29. :param cursor: 数据库操作游标
  30. :param table_name: 需要操作的表名称
  31. :param start_index: 开始 index
  32. :param next_index: 截止 index
  33. :return: 查询结果
  34. """
  35. sql = """select * from {} where id > {} and id <= {}""".format(table_name, start_index, next_index)
  36. cursor.execute(sql)
  37. res = cursor.fetchall()
  38. return res

PooledDB的参数:

  1. mincached,最少的空闲连接数,如果空闲连接数小于这个数,pool会创建一个新的连接

  2. maxcached,最大的空闲连接数,如果空闲连接数大于这个数,pool会关闭空闲连接

  3. maxconnections,最大的连接数,

  4. blocking,当连接数达到最大的连接数时,在请求连接的时候,如果这个值是True,请求连接的程序会一直等待,直到当前连接数小于最大连接数,如果这个值是False,会报错,

  5. maxshared 当连接数达到这个数,新请求的连接会分享已经分配出去的连接

在uwsgi中,每个http请求都会分发给一个进程,连接池中配置的连接数都是一个进程为单位的(即上面的最大连接数,都是在一个进程中的连接数),而如果业务中,一个http请求中需要的sql连接数不是很多的话(其实大多数都只需要创建一个连接),配置的连接数都不需要太大。

连接池对性能的提升表现在:1.在程序创建连接的时候,可以从一个空闲的连接中获取,不需要重新初始化连接,提升获取连接的速度2.关闭连接的时候,把连接放回连接池,而不是真正的关闭,所以可以减少频繁地打开和关闭连接

DBUtils下载地址:https://pypi.python.org/pypi/DBUtils/

ending ~

Python DBUtils 连接池对象 (PooledDB)的更多相关文章

  1. python - DBUtils 连接池减少oracle数据库的连接数

    问题: 接到需求,告知项目的oracle连接次数过多,对系统造成太过大的负担,要求减少oracle数据库的连接次数 分析: 仔细分析代码以后,发现产生问题的原因,在于之前要求提升oracle监控的监控 ...

  2. DBUtils连接池,websocket

    1.mysql数据库连接池 概念:数据库连接池(Connection pooling)是程序启动时建立足够的数据库连接,并将这些连接组成一个连接池,由程序动态地对池中的连接进行申请,使用,释放. 这样 ...

  3. javaEE ->DBUtils&连接池

    第1章    DBUtils 如果只使用JDBC进行开发,我们会发现冗余代码过多,为了简化JDBC开发,本案例我们讲采用apache commons组件一个成员:DBUtils. DBUtils就是J ...

  4. 在spring中如何生成一个bean (一个对象,比如jedis的连接池对象)【我】

    在spring中,要想生成一个单例对象(比如jedis的连接池对象) 方法1: 在 spring中用 bean 标签生成(反正就是让spring生成并管理单例的对象) 方法2: 把要生成的单例对象类, ...

  5. python DBUtils 线程池 连接 Postgresql(多线程公用线程池,DB-API : psycopg2)

    一.DBUtils DBUtils 是一套允许线程化 Python 程序可以安全和有效的访问数据库的模块,DBUtils提供两种外部接口: PersistentDB :提供线程专用的数据库连接,并自动 ...

  6. python通过连接池连接redis,操作redis队列

    在每次使用redis都进行连接的话会拉低redis的效率,都知道redis是基于内存的数据库,效率贼高,所以每次进行连接比真正使用消耗的资源和时间还多.所以为了节省资源,减少多次连接损耗,连接池的作用 ...

  7. python mysql连接池

    话不多说,直接撸代码 # coding=utf-8 from DBUtils.PooledDB import PooledDB import pymysql as mysql import trace ...

  8. 配置jdpc连接池对象

  9. JDBC获取超出最大连接的连接池对象

随机推荐

  1. [Beta阶段]第五次Scrum Meeting

    Scrum Meeting博客目录 [Beta阶段]第五次Scrum Meeting 基本信息 名称 时间 地点 时长 第五次Scrum Meeting 19/05/10 新主楼F座2楼 50min ...

  2. C# 序列化与反序列化Serialization之Json Xml Binary Soap JavaScript序列化

    所谓的序列化其实就是把一个内存中的对象信息转化成一个可以持久化保存的形式,方便保存数据库和文件或着用于传输, 序列化的主要作用是不同平台之间进行通信与信息的传递保存等,常用的有序列化有Json Xml ...

  3. Base64编码解码(js)

    开源的base64.js,使用很简单,浏览器引入该JS文件,然后Base64编码这样: Base64.encode('china is so nb'); // 编码 "Y2hpbmEgaXM ...

  4. redis创建集群至少需要几个节点?至少需要几个master节点?

    描述: 这也算个思考吧,通过redis-trib.rb可创建redis集群,然后通过--replicas后面接的数字,表示1个主节点对应几个从节点,那么我就做了如下的测试,想要达到的效果就是有6个节点 ...

  5. fatal error: sys/videoio.h: No such file or directory

    Determining if the include file sys/videoio.h exists failed with the following output:Change Dir: /h ...

  6. maven安装和应用

    maven安装和应用 觉得有用的话,欢迎一起讨论相互学习~Follow Me 参考文献 https://www.cnblogs.com/xihehua/p/9639045.html https://w ...

  7. TensorFlow 8 bit模型量化

    本文基本参考自这篇文章:8-Bit Quantization and TensorFlow Lite: Speeding up mobile inference with low precision ...

  8. ETF计算公式:IOPV

    IOPV=(申购.赎回清单中必须现金替代的替代金额+申购.赎回清单中退补现金替代成份证券的数量与最新成交价相乘之和+申购.赎回清单中可以现金替代成份证券的数量与最新成交价相乘之和+申购.赎回清单中禁止 ...

  9. 量化编程技术—pandas与数据分析

    # -*- coding: utf-8 -*- # @Date: 2017-08-26 # @Original: import numpy as np stock_cnt = 200 view_day ...

  10. adb 命令简介

    adb命令配置 1 在命令行下,进入用户目录 cd $HOME 2 .bash_profile文件 输入下行命令获取当前文件列表: ls -al 查看文件列表,如果没有.bash_profile文件, ...