1、mysql服务器的线程数查看方法:
show global status like 'Thread%';

Threads_created:创建过的线程数,如果发现Threads_created值过大的话,表明MySQL服务器一直在创建线程,这也是比较耗资源,可以适当增加配置文件中thread_cache_size值
2、优化参数thread_cache_size
thread_cache_size:当客户端断开之后,服务器处理此客户的线程将会缓存起来以响应下一个客户而不是销毁(前提是缓存数未达上限)
即可以重新利用保存在缓存中线程的数量,当断开连接时如果缓存中还有空间,那么客户端的线程将被放到缓存中,如果线程重新被请求,那么请求将从缓存中读取,如果缓存中是空的或者是新的请求,那么这个线程将被重新创建,如果有很多新的线程,增加这个值可以改善系统性能。
thread_cache_size大小的设置:
如果是短连接,适当设置大一点,因为短连接往往需要不停创建,不停销毁,如果大一点,连接线程都处于取用状态,不需要重新创建和销毁,所以对性能肯定是比较大的提升。
对于长连接,不能保证连接的稳定性,所以设置这参数还是有一定必要,可能连接池的问题,会导致连接数据库的不稳定性,也会出现频繁的创建和销毁,但这个情况比较少,如果是长连接,可以设置成小一点,一般在50-100左右。
物理内存设置规则:通过比较Connections 和 Threads_created 状态的变量,可以看到这个变量的作用。(-->表示要调整的值) 根据物理内存设置规则如下:
1G ---> 8
2G ---> 16
3G ---> 32
>3G ---> 64
查询thread_cache_size设置
show global status like'thread_cache_size';
优化方法:
1、mysql> set global thread_cache_size=16
2、编辑/etc/my.cnf 更改/添加
thread_concurrency = 16
3、mysql kill线程
mysqladmin start slave stop slave kill某个连接到mysqlServer的线程
==================
thread_cache_size功能在mysql数据库配置文件中是非常重要的一项功能了,如果对thread_cache_size优化做得好我们可以让服务器跑得非常快,设置不好就会发现很小访问量就非常的卡哦。 thread_cache_size 查询进程使用情况 代码如下 复制代码 mysql> show global status like ‘Thread%’; +——————-+———-+ | Variable_name | Value | +——————-+———-+ | Threads_cached | 26 | | Threads_connected | 510 | | Threads_created | 35168165 | | Threads_running | 459 | +——————-+———-+ 4 rows in set (0.01 sec) 查询服务器 thread_cache_size配置 代码如下 复制代码 mysql> show variables like ‘thread_cache_size’; +——————-+——-+ | Variable_name | Value | +——————-+——-+ | thread_cache_size | 32 | +——————-+——-+ 1 row in set (0.00 sec) 如果我们在MySQL服务器配置文件中设置了thread_cache_size,当客户端断开之后, 服务器处理此客户的线程将会缓存起来以响应下一个客户而不是销毁(前提是缓存数未达上限)。 Threads_created表示创建过的线程数,如果发现Threads_created值过大的话, 表明 MySQL服务器一直在创建线程,这也是比较耗资源,可以适当增加配置文件中thread_cache_size值, 根据调查发现以上服务器线程缓存thread_cache_size没有进行设置,或者设置过小,这个值表示可以重新利用保存在缓存中线程的数量,当断开 连接时如果缓存中还有空间,那么客户端的线程将被放到缓存中,如果线程重新被请求,那么请求将从缓存中读取,如果缓存中是空的或者是新的请求,那么这个线 程将被重新创建,如果有很多新的线程,增加这个值可以改善系统性能.通过比较 Connections 和 Threads_created 状态的变量,可以看到这个变量的作用。(?>表示要调整的值) 根据物理内存设置规则如下: 1G ?> 8 2G ?> 16 3G ?> 32 >3G ?> 64

本文介绍了MySQL服务器中线程缓存(thread_cache_size)的重要性及其优化方法。通过合理设置线程缓存大小,可以有效减少线程创建和销毁带来的资源消耗,显著提高服务器性能。

被折叠的 条评论
为什么被折叠?



