数据库版本:percona-mysql 5.6.16
在很长一段时间,都会出现程序连接数据库,出现响应慢的情况,正常在几到几十毫秒之间,但是偶尔会出现上百毫秒的情况;
开始由于开发重新设置并调整过程序连接池,一直怀疑是连接池的问题,但是问题依旧;
因为使用的版本是 percona-mysql 5.6.16 并且使用了数据库连接池。
Thread Pool 根据参数 thread_pool_size 被分为若干个 group, 每个 group 维护 client 发起的 connections, 当 MySQL 建立 connection 时,
MySQL 根据 connection 的 thread id 对 thread_pool_size 取模, 将 connection 发起的 sql 语句分配到对应的 group。每个 group 的*** worker
数量为 thread_pool_oversubscribe+1。若 worker 达到***数量后还是不足以处理回话请求, 则连接在本 group 上等待, 导致 sql 语句的 rt 增大;
因此将 thread_pool_oversubscribe 参数调大,但是问题依旧;
检查 thread_cache_size,服务器内存大小为 64G,thread_cache_size=128;
每建立一个连接,都需要一个线程来与之匹配,此参数用来缓存空闲的线程,以至不被销毁,如果线程缓存中有空闲线程,这时候如果建立新连接,MYSQL 就会很快的响应连接请求;
- show status like '%thread%';
- Variable_name Value
- Threads_cached 0
- Threads_connected 219
- Threads_created 655068
- Threads_running 48
使用 show status 查看当前 mysql 连接情况:
- SHOW STATUS WHERE Variable_name LIKE '%Thread%';
Threads_cached : 代表当前此时此刻线程缓存中有多少空闲线程。
Threads_connected : 代表当前已建立连接的数量,因为一个连接就需要一个线程,所以也可以看成当前被使用的线程数。
Threads_created : 代表从最近一次服务启动,已创建线程的数量。
Threads_running : 代表当前激活的(非睡眠状态)线程数。并不是代表正在使用的线程数,有时候连接已建立,但是连接处于 sleep 状态,这里相对应的线程也是 sleep 状态。
***将 thread_cache_size 设置成与 threads_connected 一样。
- show variables like '%thread%';
- +-----------------------------------------+-----------------+
- | Variable_name | Value |
- +-----------------------------------------+-----------------+
- | innodb_purge_threads | 1 |
- | innodb_read_io_threads | 4 |
- | innodb_thread_concurrency | 0 |
- | innodb_thread_sleep_delay | 10000 |
- | innodb_write_io_threads | 4 |
- | max_delayed_threads | 20 |
- | max_insert_delayed_threads | 20 |
- | myisam_repair_threads | 1 |
- | performance_schema_max_thread_classes | 50 |
- | performance_schema_max_thread_instances | -1 |
- | pseudo_thread_id | 8735851 |
- | thread_cache_size | 128 |
- | thread_concurrency | 24 |
- | thread_handling | pool-of-threads |
- | thread_pool_high_prio_mode | transactions |
- | thread_pool_high_prio_tickets | 4294967295 |
- | thread_pool_idle_timeout | 60 |
- | thread_pool_max_threads | 100000 |
- | thread_pool_oversubscribe | 40 |
- | thread_pool_size | 12 |
- | thread_pool_stall_limit | 500 |
- | thread_stack | 262144 |
- | thread_statistics | OFF |
- +-----------------------------------------+-----------------+
可以不断刷新,如果 Threads_cached = 0 且 Threads_created 不断增大,那么当前 thread_cache_size 的值设置要改大,改到 Threads_connected 值左右,
再结合物理内存 1G —> 8;2G —> 16; 3G —> 32; >3G —> 64 二个情况综合考虑一下值, 将 thread_cache_size 改为 512;
注译:
Threads_cached : 代表当前此时此刻线程缓存中有多少空闲线程。
Threads_connected : 代表当前已建立连接的数量,因为一个连接就需要一个线程,所以也可以看成当前被使用的线程数。
Threads_created : 代表从最近一次服务启动,已创建线程的数量。
Threads_running : 代表当前激活的(非睡眠状态)线程数。并不是代表正在使用的线程数,有时候连接已建立,但是连接处于 sleep 状态,这里相对应的线程也是 sleep 状态。
修改 thread_cache_size 为 512 后,重新测试程序连接数据库响应时间,速度极快,不再出现程序连接数据库响应慢的情况!
vbs:把一段文字中指定字符颜色变成红色的正则 functionc(Tstr,Word) Dimre Setre...
【排序算法】之lowb三人组冒泡、插入、选择 什么是lowb三人组 冒泡排序bubble so...
微信文件传输助手是微信电脑版与手机微信之间相互传输图片等文件的好工具,但很...
一石激起千层浪,继中国区浩浩荡荡的大裁员告一段落之后,甲骨文并未因此收起手...
歌词编辑器 歌词编辑器 第一步:选择要播放的歌曲并播放 第二步:填写全部的歌词...
一、正则表达式概述 二、正则表达式在VBScript中的应用 三、正则表达式在VavaScr...
本文将研究 ES6 的 for ... of 循环。 旧方法 在过去,有两种方法可以遍历 javas...
前言 相信大家都知道在IDE中代码的智能提示几乎都是标配,虽然一些文本编辑器也...
ADO对象: Connection Command Recordset Record Stream ASP支持的对象很多,可...
计算属性computed: 支持缓存,只有依赖数据发生改变,才会重新进行计算 不支持...