今天朋友问我一个Linux程序CPU占用涨停了,该如何分析,
CPU占用过高,模拟CPU占用过高的情况
先上一段代码:
1 #include <iostream>
2 #include <thread>
3 #include <vector>
4
5
6 int main(int argc, char **argv) {
7
8 std::vector<std::thread> test_threads;
9 for(int i = 0; i < 9; i++){
10 test_threads.push_back(std::thread([]{
11 while(1){
12 std::this_thread::sleep_for(std::chrono::milliseconds(500));
13 }
14 }));
15 }
16 test_threads.push_back(std::thread([]{
17 while(1){
18 std::cout<<"cpu"<<std::endl;
19 }
20 }));
21
22 for(auto &x : test_threads){
23 x.join();
24 }
25
26 return 0;
27 }
第10个线程中没有进行睡眠,会独占进程的时间片,导致CPU利用率过高,
现在就要定位到第10个
第一步:top 查看程序进程id
第二步:top -H -p 96263 定位CPU占用过高的线程id
第三步:使用pstack 96263或者strace -f -p 96263 定位线程堆栈
strace -f -p 96263