线程池线程数和数据库连接池连接数量设置多少合适?

影响运行性能的主要因素cup  io 网络 内存
忽略io,网络的影响,单看cup的话,极端情况下面,单核cup,单线程顺序执行任务肯定比多线程轮换执行要快,为啥?
因为线程切换肯定会造成时间损耗,同理扩展到多核的情况,例如4核服务器,当线程数量为4的时候能达到最大性能;
当然实际情况不是这样的,io阻塞和网络io阻塞影响我们不能忽略,我们的数据很多时候都是放到磁盘上面的,在磁盘上面读或者写数据时需要消耗时间的,这时线程阻塞,这样在阻塞的情况下,cup空闲了,如果不利于起来,那就是浪费呀,我们必须增加线程数量才能减少cup浪费,处理其他任务,提高服务性能。

网络阻塞也是类似的情况,磁盘的读写性能对于SSD来说是比较慢,那是不是使用SSD的情况下,是不是线程数可以搞多些了,恰恰相反,io阻塞减少了,我们需要等待的时间减少了,cup空闲的情况下减少了,这时接近服务器核数线程数量会获得更好的性能。
当然增加的线程数量太多也不好,服务器资源只有那么多,太多的线程会造成线程等待的时间变多,实际往往会降低性能;太少的话cup会有空闲,造成资源浪费,性能达不到最好。
这样的话在我们进行多线程编程的时候,考虑到io阻塞和网络阻塞的情况,线程池的数量=应用服务器的cup核数*2+1时候能够最好,当然实际情况我们需要根据这个数量做调整。
我们设置数据库连接池连接数量时,也可以这样思考,接池数=数据库服务器核数*2+1,会获得更好的性能.实际情况往往比较复杂,影响因素更多,这时我们可以在这个基础根据实际情况做调整。.

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值