免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1718 | 回复: 2
打印 上一主题 下一主题

[系统] 咋一个CPU使用100%,其他的还那么闲,怎么内核不会调度吗? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2014-03-24 10:23 |只看该作者 |倒序浏览
top - 10:10:24 up 35 min,  2 users,  load average: 6.63, 5.88, 4.53
Tasks: 314 total,   6 running, 308 sleeping,   0 stopped,   0 zombie
Cpu0  :  2.0%us, 16.8%sy,  0.0%ni, 80.9%id,  0.0%wa,  0.0%hi,  0.3%si,  0.0%st
Cpu1  :  1.0%us, 16.7%sy,  0.0%ni, 81.9%id,  0.0%wa,  0.0%hi,  0.3%si,  0.0%st
Cpu2  :  2.4%us, 25.4%sy,  0.0%ni, 71.9%id,  0.0%wa,  0.0%hi,  0.3%si,  0.0%st
Cpu3  :  0.0%us, 73.2%sy,  0.0%ni,  0.0%id,  0.0%wa,  0.0%hi, 26.8%si,  0.0%st
Mem:   3334980k total,  3202088k used,   132892k free,    12832k buffers
Swap:        0k total,        0k used,        0k free,   120920k cache

都是一些内核线程使用,软中断只发生在一个CPU,一个CPU用完了,其他CPU还很闲,怎么搞的?

论坛徽章:
1
天蝎座
日期:2013-12-06 18:23:58
2 [报告]
发表于 2014-03-24 11:17 |只看该作者
这个可以调节网卡的中断配置来均衡网卡的中断。可以参考这个教程
http://www.mjmwired.net/kernel/Documentation/IRQ-affinity.txt

  1. 1        ChangeLog:
  2. 2                Started by Ingo Molnar <mingo@redhat.com>
  3. 3                Update by Max Krasnyansky <maxk@qualcomm.com>
  4. 4       
  5. 5        SMP IRQ affinity
  6. 6       
  7. 7        /proc/irq/IRQ#/smp_affinity and /proc/irq/IRQ#/smp_affinity_list specify
  8. 8        which target CPUs are permitted for a given IRQ source.  It's a bitmask
  9. 9        (smp_affinity) or cpu list (smp_affinity_list) of allowed CPUs.  It's not
  10. 10        allowed to turn off all CPUs, and if an IRQ controller does not support
  11. 11        IRQ affinity then the value will not change from the default of all cpus.
  12. 12       
  13. 13        /proc/irq/default_smp_affinity specifies default affinity mask that applies
  14. 14        to all non-active IRQs. Once IRQ is allocated/activated its affinity bitmask
  15. 15        will be set to the default mask. It can then be changed as described above.
  16. 16        Default mask is 0xffffffff.
  17. 17       
  18. 18        Here is an example of restricting IRQ44 (eth1) to CPU0-3 then restricting
  19. 19        it to CPU4-7 (this is an 8-CPU SMP box):
  20. 20       
  21. 21        [root@moon 44]# cd /proc/irq/44
  22. 22        [root@moon 44]# cat smp_affinity
  23. 23        ffffffff
  24. 24       
  25. 25        [root@moon 44]# echo 0f > smp_affinity
  26. 26        [root@moon 44]# cat smp_affinity
  27. 27        0000000f
  28. 28        [root@moon 44]# ping -f h
  29. 29        PING hell (195.4.7.3): 56 data bytes
  30. 30        ...
  31. 31        --- hell ping statistics ---
  32. 32        6029 packets transmitted, 6027 packets received, 0% packet loss
  33. 33        round-trip min/avg/max = 0.1/0.1/0.4 ms
  34. 34        [root@moon 44]# cat /proc/interrupts | grep 'CPU\|44:'
  35. 35                   CPU0       CPU1       CPU2       CPU3      CPU4       CPU5        CPU6       CPU7
  36. 36         44:       1068       1785       1785       1783         0          0           0         0    IO-APIC-level  eth1
  37. 37       
  38. 38        As can be seen from the line above IRQ44 was delivered only to the first four
  39. 39        processors (0-3).
  40. 40        Now lets restrict that IRQ to CPU(4-7).
  41. 41       
  42. 42        [root@moon 44]# echo f0 > smp_affinity
  43. 43        [root@moon 44]# cat smp_affinity
  44. 44        000000f0
  45. 45        [root@moon 44]# ping -f h
  46. 46        PING hell (195.4.7.3): 56 data bytes
  47. 47        ..
  48. 48        --- hell ping statistics ---
  49. 49        2779 packets transmitted, 2777 packets received, 0% packet loss
  50. 50        round-trip min/avg/max = 0.1/0.5/585.4 ms
  51. 51        [root@moon 44]# cat /proc/interrupts |  'CPU\|44:'
  52. 52                   CPU0       CPU1       CPU2       CPU3      CPU4       CPU5        CPU6       CPU7
  53. 53         44:       1068       1785       1785       1783      1784       1069        1070       1069   IO-APIC-level  eth1
  54. 54       
  55. 55        This time around IRQ44 was delivered only to the last four processors.
  56. 56        i.e counters for the CPU0-3 did not change.
  57. 57       
  58. 58        Here is an example of limiting that same irq (44) to cpus 1024 to 1031:
  59. 59       
  60. 60        [root@moon 44]# echo 1024-1031 > smp_affinity_list
  61. 61        [root@moon 44]# cat smp_affinity_list
  62. 62        1024-1031
  63. 63       
  64. 64        Note that to do this with a bitmask would require 32 bitmasks of zero
  65. 65        to follow the pertinent one.
复制代码

论坛徽章:
0
3 [报告]
发表于 2014-03-24 15:52 |只看该作者
回复 2# crazyhadoop
看了这个没有问题,这个好像是调节硬件中断的吧?看几个CPU分配的挺平均的。不知道为什么软中断只在一个CPU发生?

   
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP