zoukankan      html  css  js  c++  java
  • 关于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

  • 相关阅读:
    互联网公司笔试常见陷阱
    华为机试题(地铁换乘,图的应用)
    容器(vector)、数组、new创建的动态数组,你到底用哪一个(执行效率分析)
    SpringMVC全局异常
    github commit contributions无记录
    elasticSearch之查询
    nginx负载均衡策略
    docker入门
    解决centos&win安装安装elasticSearch无法运行
    2017年终总结
  • 原文地址:https://www.cnblogs.com/zhjh256/p/6294824.html
Copyright © 2011-2022 走看看