首页 > 代码库 > 关于linux中的上下文切换

关于linux中的上下文切换

对于linux中的上下文一直以来没有特别的关注其合理范围应该是多少(关于上下文切换的概念,网上已经有很多解释了,再次不再重复),白天偶尔注意到了一下,晚上特地看了下白天负载和和收盘后的负载如下(服务器1,8C/16GB,运行1个mysql,8个java进程,1个rabbitmq):

技术分享

相应时间段的上下文切换如下:

技术分享

总的来说,服务器空闲期间,上下文在2000-2500左右。

服务器2(1个mysql,这是我们优化行情和风控之后的负载,原来平均在45%左右):

技术分享

技术分享

服务器3(1个mysql):

技术分享

技术分享

至于负载比较忙的时间,上下文切换应该是个什么样的值,这个主要还是根据系统类型(cpu密集型或io密集型)不同而不同以及运行了多少个进程、线程有关系。

如果system%占比较高,通过taskset设置绑定进程到特定的cpu可能会有一定的缓解(taskset的作用与其说是让进程绑定在特定cpu执行,不如说设置了更高的优先级)。

system%和user%的合理cpu应该是怎么样呢?

作为一个参考或者经验总结:

  1. 对于每一个CPU来说运行队列不要超过3,例如,如果是双核CPU就不要超过6; 

  2. 如果CPU在满负荷运行,应该符合下列分布, 

  a) User Time:65%~70% 

  b) System Time:30%~35% 

  c) Idle:0%~5% 

PS:关于上下文切换的概念,可参考:http://blog.sina.com.cn/s/blog_4adc4b090102vufu.html

关于linux中的上下文切换