Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1848662
  • 博文数量: 293
  • 博客积分: 10127
  • 博客等级: 上将
  • 技术积分: 3029
  • 用 户 组: 普通用户
  • 注册时间: 2010-08-12 19:05
文章分类

全部博文(293)

文章存档

2011年(11)

2010年(282)

我的朋友

分类: Mysql/postgreSQL

2010-08-30 03:05:52

MySQL连接不仅能通过网络方式,还可以通过命名管道的方式,不论是哪种方式连接MySQL,在MySQL中都是通过线程的方式管理所有客户端请求的。每一个客户端连接都会有一个与之对应的连接线程。在MySQL中实现了一个Thread Cache池,将空闲的连接线程存放其中,而不是完成请求后就销毁。这样,当有新的连接请求时,MySQL首先会检查Thread Cache中是否存在空闲连接线程,如果存在则取出来直接使用,如果没有空闲连接线程,才创建新的连接线程。具体参数:

Thread_cache_size:Thread Cache池中应该存放的连接线程数。

Thread_stack:每个连接线程被创建时,MySQL给它分配的内存大小。当MySQL创建一个新的连接线程时,需要给它分配一定大小的内存堆栈空间,以便存放客户端的请求的Query及自身的各种状态和处理信息。

查看连接线程相关的系统变量的设置值: show   variables   like 'thread%';

如图,系统设置了Thread Cache池最多将缓存25个连接线程,每个连接线程创建之初,系统分配192KB的内存堆栈给它。

查看系统被连接的次数及当前系统中连接线程的状态值

show status like 'connections';

show status like '%thread%';


系统启动到现在共接受到客户端的连接7次,共创建了1个连接线程,当前有1个连接线程处于和客户端连接的状态,而1个连接状态的线程中只有一个处于 active 状态,即只有一个正在处理客户端提交的请求,。而在Thread Cache池中共缓存了0个连接线程。

Thread Cache 命中率:

Thread_Cache_Hit = (Connections - Threads_created) / Connections * 100%;

一般在系统稳定运行一段时间后,Thread Cache命中率应该保持在90%左右才算正常。

摘自:《MySQL性能调优与架构优化》

阅读(2112) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~