线程池的优化

主要涉及调度死锁解决和大查询处理两个方面。

调度死锁解决
我们设想一个场景,A,B两个事务被分配到不同的线程组中,A已经开始执行,并且持有锁,但是由于A所在的组比较繁忙,A执行一条语句后剩余的不能立即执行;而B事务依赖A释放的锁资源,虽然B所在的组没有别的任务,但是由于A未释放锁资源,所以B仍然需要等待,这就是调度死锁。

如何解决呢?那些已经开启一部分请求的事务或者有锁资源的连接需要放入优先队列,优先执行。

大查询处理
因为大查询会导致很快到达最大线程数,后续任务无法响应。如果是业务需求,线程池本身没有办法。但是如果是dump任务,将数据拉到下游,集中在一个组内。那么,处理dump任务的线程不计入最大线程数累计值中。

线程模式控制
通过如下命令查看线程模式
SHOW variables LIKE ‘%thread_handlings%’;
有三种模式:No-Threads表示连接使用主线程处理,用于调试。One-Thread-Per-Connection一个连接创建一个进程 。 Pool-Threads就是线程池方式。

我们在客户端可以通过线程池来缓存线程,也就是连接结束不销毁线程,我们可以用thread_cache_size来设置缓存个数。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值