• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            S.l.e!ep.¢%

            像打了激速一樣,以四倍的速度運轉,開心的工作
            簡單、開放、平等的公司文化;尊重個性、自由與個人價值;
            posts - 1098, comments - 335, trackbacks - 0, articles - 1
              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            如何定位死循環或高CPU使用率(linux)

            Posted on 2012-03-14 04:43 S.l.e!ep.¢% 閱讀(2778) 評論(0)  編輯 收藏 引用 所屬分類: Unix

            如何定位死循環或高CPU使用率(linux)
            ?確定是CPU過高
            使用top觀察是否存在CPU使用率過高現象

            找出線程
            對CPU使用率過高的進程的所有線程進行排序

            ps H -e -o pid,tid,pcpu,cmd --sort=pcpu |grep xxx得到如下結果,其中線程2909使用了7.8%的CPU. 2907 2913 0.0 ./xxx 2907 2909 7.8 ./xxx也可以通過查看/proc中的信息來確定高CPU線程. 打印了4列,線程ID,線程名,用戶時間和內核時間(排名未分先后) awk '{print $1,$2,$14,$15}' /proc/2907/task/*/stat
            找出調用棧
            使用gdb attach nmsagent所在的進程,在gdb中使用 info threads顯示所有線程

            gdb
            gdb>attach 2907
            gdb>info threads
            得到如下結果,可以發現2909線程的編號是12

            ? 13 Thread 0xad5f2b70 (LWP 2908)? 0x004ef0d7 in mq_timedreceive () from /lib/tls/i686/cmov/librt.so.1
            ? 12 Thread 0xad58eb70 (LWP 2909)? 0x006e0422 in __kernel_vsyscall ()
            ? 11 Thread 0xad52ab70 (LWP 2910)? 0x006e0422 in __kernel_vsyscall ()
            ? 10 Thread 0xad4f8b70 (LWP 2911)? 0x006e0422 in __kernel_vsyscall ()
            ? 9 Thread 0xad4c6b70 (LWP 2912)? 0x006e0422 in __kernel_vsyscall ()
            ? 8 Thread 0xad3feb70 (LWP 2913)? 0x004ef0d7 in mq_timedreceive () from /lib/tls/i686/cmov/librt.so.1
            ? 7 Thread 0xace08b70 (LWP 2914)? 0x004ef0d7 in mq_timedreceive () from /lib/tls/i686/cmov/librt.so.1
            ? 6 Thread 0xac607b70 (LWP 2915)? 0x006e0422 in __kernel_vsyscall ()
            ? 5 Thread 0xac5e6b70 (LWP 2916)? 0x006e0422 in __kernel_vsyscall ()
            ? 4 Thread 0xac361b70 (LWP 2917)? 0x006e0422 in __kernel_vsyscall ()
            ? 3 Thread 0xac2fdb70 (LWP 2918)? 0x006e0422 in __kernel_vsyscall ()
            ? 2 Thread 0xac1fcb70 (LWP 2919)? 0x004ef0d7 in mq_timedreceive () from /lib/tls/i686/cmov/librt.so.1
            * 1 Thread 0xb78496d0 (LWP 2907)? 0x006e0422 in __kernel_vsyscall ()
            使用thread 切換線程,使用bt顯示線程棧

            gdb>thread 12
            gdb>bt
            得到如下線程棧

            #0? 0x006e0422 in __kernel_vsyscall ()
            #1? 0x001cca26 in nanosleep () from /lib/tls/i686/cmov/libc.so.6
            #2? 0x001fc2dc in usleep () from /lib/tls/i686/cmov/libc.so.6
            #3? 0x0806b510 in OspTaskDelay ()
            #4? 0x0805c710 in CDispatchTask::NodeMsgSendToSock() ()
            #5? 0x0805cc74 in DispatchTaskEntry ()
            #6? 0x0806a8e9 in OspTaskTemplateFunc(void*) ()
            #7? 0x00d4780e in start_thread () from /lib/tls/i686/cmov/libpthread.so.0
            ?#8? 0x002027ee in clone () from /lib/tls/i686/cmov/libc.so.6
            ?ps + strace
            得到進程ID 21465

            ps -e |grep cmu
            ?4996 ???????? 00:00:25 cmu_fjga_sp3
            21465 pts/5??? 00:08:10 cmu
            得到線程時間, 其中最占CPU的是 EpollRecvTask 21581

            ps -eL |grep 21465 21465 21579 pts/5 00:00:00 CamApp 21465 21580 pts/5 00:00:00 TimerMan Task 21465 21581 pts/5 00:09:02 EpollRecvTask 21465 21582 pts/5 00:00:00 使用 strace -p 21581 得到線程棧

            国产精品99久久精品爆乳| 欧美日韩精品久久免费| 欧美亚洲国产精品久久蜜芽 | 欧美激情精品久久久久久久| 日韩十八禁一区二区久久| 亚洲人成伊人成综合网久久久| 色婷婷久久综合中文久久蜜桃av| 99久久人人爽亚洲精品美女| 亚洲天堂久久久| 91精品国产高清久久久久久国产嫩草| 亚洲国产成人精品久久久国产成人一区二区三区综 | 亚洲伊人久久精品影院| 国产精品日韩深夜福利久久| 无遮挡粉嫩小泬久久久久久久 | 久久免费高清视频| 国产A级毛片久久久精品毛片| 日本一区精品久久久久影院| 久久婷婷五月综合国产尤物app| 性做久久久久久久久久久| 国产精品日韩欧美久久综合| 国产精品久久久久AV福利动漫| 亚洲国产精品一区二区三区久久| 久久精品视频网| 99久久精品国产免看国产一区| 伊人久久大香线蕉亚洲五月天| 久久久久久久综合日本| 7国产欧美日韩综合天堂中文久久久久 | 手机看片久久高清国产日韩| 国产午夜精品久久久久九九电影| 久久精品国产精品国产精品污| 91视频国产91久久久| 国产成人精品白浆久久69| 亚洲精品美女久久久久99| 国产欧美久久久精品影院| 久久经典免费视频| 亚洲成色www久久网站夜月| 无码人妻久久一区二区三区免费| 日韩精品久久无码中文字幕| 色婷婷综合久久久久中文 | 狠狠色丁香婷婷久久综合| 77777亚洲午夜久久多人|