一. 数据库连接池
   python 编程中可以使用MySQLdb 进行数据库的连接及诸如查询,插入,更新等操作,但是每次连接mysql 数据库请求时,都是独立的去请求访问,相当浪费资源,而且访问数量达到一定书力量时,对mysql的性能会产生较大的影响。因此,实际使用中,通常会使用数据库的连接池技术,来访问数据库达到资源复用的目的。
 
 
python 的数据库连接池包  DBUtils:
DBUtils 是一套python 数据库连接池包,并允许对非线程安全的数据库接口进行线程安全包装。DBUtils 来自 Webware for  pthon
 
DBUtils 提供两种外部接口:
* PersistentDB:提供线程专用的数据库连接,并自动管理连接。
*PooledDB: 提供线程间可共享的数据库连接,并自动管理连接。
下载地址:https://pypi.python.org/pypi/DBUtils/  下载解压后,使用python setup.py install 命令进行安装
或者使用:pip install DBUtils
 
 
#/usr/bin/python
#-*- coding:utf-8 -*-
#@Time   :2017/11/22 15:43
#@Auther :liuzhenchuan
#@File   :数据库连接池.py
 
import MySQLdb
from DBUtils.PooledDB import PooledDB
 
db_config= {
    'host':'192.168.10.199',
    'port':3306,
    'user':'root',
    'passwd':'123123',
    'db':'python',
    'charset':'utf8'
}
pool = PooledDB(creator=MySQLdb,mincached=5,blocking=True,**db_config)
 
if __name__ == '__main__':
    cnx = pool.connection()
    cus = cnx.cursor()
    SQL = 'select *from test;'
    try:
        cus.execute(SQL)
        result = cus.fetchall()
        print result
        cus.close()
        cnx.commit
    except Exception as e:
        raise e
    finally:
        cnx.close()
 
 
>>>
((100L,), (99L,), (95L,), (95L,), (98L,), (97L,), (96L,), (95L,), (100L,), (101L,), (102L,), (103L,), (104L,), (105L,), (106L,), (107L,), (108L,), (109L,), (110L,), (111L,), (112L,), (113L,), (114L,), (115L,), (116L,), (117L,), (118L,), (119L,), (120L,), (121L,), (122L,), (123L,), (124L,), (125L,), (126L,), (127L,), (128L,), (129L,))
 
 
参数说明:
pool = PooledDB(MySQLdb,5, **db_config)  #5 为连接池里的最少连接数
 
cnx = pool.connection()   # 以后每次需要数据库连接就是用connection() 函数获取连接就好了
cus = cnx.cursor()
cus = cnx.cursor()
SQL = 'select *from test;'
try:
  cus.execute(SQL)
   result = cus.fetchall()
   print result
   cus.close()
   cnx.commit
 
PooledDB 的参数:
1.mincached,最少的空闲连接数,如果空闲连接数小于这个数,pool 会创建一个新的连接
2.maxcached,最大的空闲连接数,如果空闲连接数大于这个数,pool 会关闭空闲连接
3.maxconnections,最大的连接数。
4.blocking,当链接数达到最大的链接数时,在请求连接的时候,如果这个值是True,请求连接的程序会一直等待,直到当前连接数小于最大连接数,如果这个值是Flase,会报错
5.maxshared 当连接数达到这个数,新请求的链接会分享已经分配出去的链接。
 
在uwsgi 中,每个httpd请求都会分发给一个进程,连接池中配置的链接数都是一个进程为单位的(即上面的最大连接数,都是在一个进程中的链接数),而如果业务中,一个httpd请求中需要的sql连接数不是很多的话(其实大多数都只需要创建一个连接),配置的链接数配置都不需要太大。
 
连接池对性能的提升变现在:
1.在程序创建连接的时候,可以从一个空闲的链接中获取,不需要重新初始化连接,提升获取链接的速度
2.关闭连接的时候,把链接放回连接池,而不是真的关闭,所以可以减少频繁的打开和关闭连接
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

python 基础 9.5 数据库连接池的更多相关文章

  1. JDBC基础学习(六)—数据库连接池

    一.数据库连接池介绍 1.数据库连接池的缘由      对于一个简单的数据库应用,由于对于数据库的访问不是很频繁.这时可以简单地在需要访问数据库时,就新创建一个连接,用完后就关闭它,这样做也不会带来什 ...

  2. javaweb基础(39)_数据库连接池

    一.应用程序直接获取数据库连接的缺点 用户每次请求都需要向数据库获得链接,而数据库创建连接通常需要消耗相对较大的资源,创建时间也较长.假设网站一天10万访问量,数据库服务器就需要创建10万次连接,极大 ...

  3. python基础之小数据池、代码块、编码和字节之间换算

    一.代码块.if True: print(333) print(666) while 1: a = 1 b = 2 print(a+b) for i in '12324354': print(i) 虽 ...

  4. python基础之小数据池、代码块、编码

    一.代码块.if True: print(333) print(666) while 1: a = 1 b = 2 print(a+b) for i in '12324354': print(i) 虽 ...

  5. python基础之小数据池

    一,id,is,== 在Python中,id是什么?id是内存地址,比如你利用id()内置函数去查询一个数据的内存地址: name = '太白' print(id(name)) # 158583128 ...

  6. MySQL调优基础, 与hikari数据库连接池配合

    1.根据硬件配置系统参数 wait_timeout  非交互连接的最大存活时间, 10-30min max_connections   全局最大连接数 默认100 根据情况调整 back_log   ...

  7. python基础之小数据池,is和==区别 编码问题

    主要内容 小数据池,is和==区别 编码问题 小数据池 一种缓存机制,也称为驻留机制,是为了能更快提高一些字符串和整数的处理速度is 和 == 的区别 == 主要指对变量值是否相等的判断,只要数值相同 ...

  8. Python基础篇 -- 小数据池和再谈编码

    小数据池 1. id() 通过id()可以查看到一个变量表示的值在内存中的地址 s = "Agoni" print(id(s)) # 2410961093272 2. is 和 = ...

  9. python单例与数据库连接池

    单例:专业用来处理连接多的问题(比如连接redis,zookeeper等),全局只有一个对象 单例代码def singleton(cls): instances = {} def _singleton ...

随机推荐

  1. selenium控制浏览器为手机模式

    # -*- coding: utf-8 -*- from selenium import webdriver from time import sleep mobileEmulation = {'de ...

  2. hive参数——深入浅出学Hive

    第一部分:Hive 参数 hive.exec.max.created.files •说明:所有hive运行的map与reduce任务可以产生的文件的和 •默认值:100000  hive.exec.d ...

  3. 2017.6.30 使用git新建项目、仓库并拉取、提交代码

    1.在码云上新建一个项目rms 2.在本地指定位置新建仓库,生成.git文件夹 3.同步远程仓库,并拉取最新代码 远程仓库默认名为orgin.可以修改,这里就是用默认名了. 注意:这里使用ssh方式的 ...

  4. php中const和static的区别和联系

    1.const是类中的常量,类外用define来定义常量2.const只可以修饰类的属性,不能修饰类的方法,static可以修饰属性,也可以修饰方法3.const和static都属于类本身,而不属于n ...

  5. apache环境下禁止某文件夹内运行PHP脚本、禁止访问文件或目录执行权限的设置方法

    apache环境下禁止某文件夹内运行PHP脚本.禁止访问文件或目录执行权限的设置方法   首先我们来看两段对上传目录设置无权限的列子,配置如下: <Directory "要去掉PHP执 ...

  6. javascript 数组 find

    find() 方法返回通过测试(函数内判断)的数组的第一个元素的值. let arr = [1,2,3,4] console.log(arr.find(i => {return i>1}) ...

  7. 如何修改myeclipse中web项目的工作路径或默认路径

    如何修改myeclipse中web项目的工作路径或默认路径 博客分类: J2EE开发技术指南   安装好myeclipse后,第一次启动myeclipse时,都会弹出会弹出Workspace Laun ...

  8. zabbix监控客户端本地网络的延时状态

    配置zabbix客户端配置文件 vim /etc/zabbix/zabbix_agentd.conf 添加  Include=/etc/zabbix/zabbix_agentd.d/ 添加脚本对服务器 ...

  9. UVa 437 The Tower of Babylon(DP 最长条件子序列)

     题意  给你n种长方体  每种都有无穷个  当一个长方体的长和宽都小于还有一个时  这个长方体能够放在还有一个上面  要求输出这样累积起来的最大高度 由于每一个长方体都有3种放法  比較不好控制 ...

  10. hdu 5348 MZL&#39;s endless loop

    给一个无向图(事实上是有向的.可是没有指定边的方向),你须要指定边的方向,使得每一个点入度和出度相差不超过1. 事实上就是找很多条路径.合起来能走完这个图..先统计各个顶点的度.度为奇数必是起点或终点 ...