python怎么创建数据库连接池?
不用连接池的MySQL连接方法import MySQLdbconn= MySQLdb.connect(host='localhost',user='root',passwd='pwd',db='myDB',port=3306) cur=conn.cursor()SQL="select * from table1"r=cur.execute(SQL)r=cur.fetchall()cur.close()conn.close()用连接池后的连接方法import MySQLdbfrom DBUtils.PooledDB import PooledDBpool = PooledDB(MySQLdb,5,host='localhost',user='root',passwd='pwd',db='myDB',port=3306) #5为连接池里的最少连接数
mysql和oracle连表的区别?
1、体积不同。oracle是oracle的数据库产品,它体积比较庞大,一般是用来开发大型应用(例如分布式)的。而mysql的体积相对来说比较小,较之oracle更容易安装、维护以及管理,操作也简单,最重要的是它是三个中唯一一个开源数据库,但目前也属于Oracle公司的产品了。
2、容量不同。Oracle容量无限,根据配置决定;而mysql使用MyISAM存储引擎,最大表尺寸为65536TB。 MySQL数据库的最大有效表尺寸通常是由操作系统对文件大小的限制决定的,而不是由MySQL内部限制决定。
3、平台支持及速度的区别。Oracle支持大对数平台;而mysql支持各种平台,适合Linux。至于速度,oracle在linux下的性能,在少量数据时速度低于mysql,在千万级时速度快于Mysql。
4、数据库崩溃造成的影响不同。oracle数据库崩溃后恢复很麻烦,因为他把很多东西放在内存里;数据库连接要慢些,最好用连接池;而mysql使用缺省的ip端口,但是有时候这些ip也会被一些黑客闯入,使用myisam配置,不慎损坏数据库,结果可能会导致所有的数据丢失。
5、性能的区别。Oracle全面,完整,稳定,但一般数据量大,对硬件要求较高 ;而mysql使用CPU和内存极少,性能很高,但扩展性较差。
6、授权价格区别。Oracle价格较贵,例如Oracle 10G//11G 标准版 [10用户]¥25600 ,Oracle 10G//11G 标准版 [1CPU无限用户] ¥157600。而MySQL采用双重授权,他们是GPL和MySQLAB制定的商业许可协议
mysql数据库的最大连接数100是什么概念?
数据库连接池并不能减少MySQL查询的消耗,而是为了避免MySQL维持大量的数据库连接.
MySQL最大连接数max_connections默认值为151(最大值可以过万). 假设一个worker进程保持一个到MySQL的长连接. 当Swoole服务的worker进程数(对应CPU核心数)超过151时,MySQL默认会拒绝新的连接. 假设一台服务器CPU核心数为32,开启32个Swoole worker进程. 当服务器数量达到4台时(32*4=128),MySQL才需要考虑配置更大的max_connections. 把max_connections调整为1510(默认值的10倍),可供40台Swoole应用服务器使用. 可见,当Swoole应用服务器过百时,数据库连接池才有意义,否则就是简单问题复杂化.
Swoole的MySQL连接池是通过异步swoole_mysql+SplQueue来实现的.
一般情况下,用PDO长连接就行了,连Swoole提供的异步MySQL客户端都可以不用,这样能保证数据库逻辑能够同步顺序书写,不需要像异步那样嵌套回调.