数据库连接池并不能减少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客户端都可以不用,这样能保证数据库逻辑能够同步顺序书写,不需要像异步那样嵌套回调.
通常,mysql的最大连接数默认是100, 最大可以达到16384与连接数相关的几个参数:在修改最大连接数的时候会有这样一个疑问—这个值是不是越大越好,或者设置为多大才合适?
这个参数的大小要综合很多因素来考虑,比如使用的平台所支持的线程库数量(windows只能支持到2048)、服务器的配置(特别是内存大小)、每个连接占用资源(内存和负载)的多少、系统需要的响应时间等。可以在global或session范围内修改这个参数。连接数的增加会带来很多连锁反应,需要在实际中避免由此引发的负面影响。
mysql数据库单表插入速度每秒最高100000 rows没问题,在标准配置下。mysql的读写速度跟硬盘的速度,网卡的速度,写入行的数据量,数据在硬盘中的存放位置等等因素都有关系的。要统计这个最好的是进行测试,然后得出一个平均值。没有人能够光通过配置得出这些数据的。
通常,在MySQL上,每个应用程序的连接数的合理限制是100-200。要根据应用程序的性能和要求来进行调整。另外,还要考虑服务器的内存大小、CPU和网络带宽等因素。
在MySQL中,max_connections参数的默认值是151,因此,建议将max_connections调整到100-200之间,以充分利用服务器的资源,以及满足MySQL服务器的性能要求。
在MySQL中,可以使用以下命令查看当前设置的最大线程数:show variables like 'max_connections'
;该命令将返回当前设置的最大连接数,也就是可允许的最大线程数。如果需要修改最大线程数,可以使用set global max_connections=新值;命令进行修改。需要注意的是,修改最大线程数可能会影响数据库性能,因此需要谨慎考虑。