mysql如何处理一个客户端的连接

连接管理器线程处理来自网络上的请求。在所有的平台上,一个管理线程处理所有的tcp/ip请求,在unix平台上,也处理socket连接请求。管理线程将每个客户端的请求与一个专用的线程关联起来,来处理认证及这个连接的后续处理。管理进程先去线程缓存中看是否有缓存的线程可以使用,避免创建新的线程。当一个连接结束后,如果线程缓存还没有满,线程会被返回到线程缓存中。在这种模型中,存在于客户端相同数量的线程,但是当处理大量的请求连接时候就不怎么好了。需要很多的内核及服务器的资源,可能会消耗大量的内存。mysql的企业版本包含了一个线程池的插件来降低开销,这个主要是面向大量的客户端连接的。线程缓存的大小由thread_cache_size决定,默认情况下是0,没有开启缓存,为了监控线程缓存,可以监控thread_cached和thread_created状态变量。当thread stack太小的时候,这个会限制mysql能处理的sql语句的复杂性,存储过程的递归深度,还有其他的消耗内存的一些行为,可以通过–thread_stack设置该值。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值