docker cgroup 資源監(jiān)控的詳解
更新時間:2017年10月29日 14:14:15 作者:l6807718
這篇文章主要介紹了docker cgroup 資源監(jiān)控的詳解的相關(guān)資料,希望通過本文能幫助到大家,讓大家理解掌握這部分內(nèi)容,需要的朋友可以參考下
docker cgroup 資源監(jiān)控的詳解
1.cgroup術(shù)語解析:
blkio: 這個subsystem可以為塊設(shè)備設(shè)定輸入/輸出限制,比如物理驅(qū)動設(shè)備(包括磁盤、固態(tài)硬盤、USB等)。 cpu: 這個subsystem使用調(diào)度程序控制task對CPU的使用。 cpuacct: 這個subsystem自動生成cgroup中task對CPU資源使用情況的報告。 cpuset: 這個subsystem可以為cgroup中的task分配獨立的CPU(此處針對多處理器系統(tǒng))和內(nèi)存。 devices 這個subsystem可以開啟或關(guān)閉cgroup中task對設(shè)備的訪問。 freezer 這個subsystem可以掛起或恢復(fù)cgroup中的task。 memory 這個subsystem可以設(shè)定cgroup中task對內(nèi)存使用量的限定,并且自動生成這些task對內(nèi)存資源使用情況的報告。 perfevent 這個subsystem使用后使得cgroup中的task可以進行統(tǒng)一的性能測試。{![perf: Linux CPU性能探測器,詳見https://perf.wiki.kernel.org/index.php/MainPage]} *net_cls 這個subsystem Docker沒有直接使用,它通過使用等級識別符(classid)標記網(wǎng)絡(luò)數(shù)據(jù)包,從而允許 Linux 流量控制程序(TC:Traffic Controller)識別從具體cgroup中生成的數(shù)據(jù)包。
2.資源監(jiān)控的關(guān)鍵目錄:cat讀出
已使用內(nèi)存:
/sys/fs/cgroup/memory/docker/應(yīng)用ID/memory.usage_in_bytes
分配的總內(nèi)存:
/sys/fs/cgroup/memory/docker/應(yīng)用ID/memory.limit_in_bytes
已使用的cpu:單位納秒
/sys/fs/cgroup/cpuacct/docker/應(yīng)用ID/cpuacct.usage
系統(tǒng)當前cpu:
$ cat /proc/stat | grep 'cpu '(周期/時間片/jiffies) #得到的數(shù)字相加/HZ(cat /boot/config-`uname -r` | grep '^CONFIG_HZ=' ubuntu 14.04為250)就是系統(tǒng)時間(秒) #再乘以10*9就是系統(tǒng)時間(納秒)
例子
[~]$ cat /proc/stat cpu 432661 13295 86656 422145968 171474 233 5346 cpu0 123075 2462 23494 105543694 16586 0 4615 cpu1 111917 4124 23858 105503820 69697 123 371 cpu2 103164 3554 21530 105521167 64032 106 334 cpu3 94504 3153 17772 105577285 21158 4 24 intr 1065711094 1057275779 92 0 6 6 0 4 0 3527 0 0 0 70 0 20 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ctxt 19067887 btime 1139187531 processes 270014 procs_running 1 procs_blocked 0 輸出解釋 CPU 以及CPU0、CPU1、CPU2、CPU3每行的每個參數(shù)意思(以第一行為例)為: 參數(shù) 解釋 user (432661) 從系統(tǒng)啟動開始累計到當前時刻,用戶態(tài)的CPU時間(單位:jiffies) ,不包含 nice值為負進程。 nice (13295) 從系統(tǒng)啟動開始累計到當前時刻,nice值為負的進程所占用的CPU時間(單位:jiffies) system (86656) 從系統(tǒng)啟動開始累計到當前時刻,核心時間(單位:jiffies) idle (422145968) 從系統(tǒng)啟動開始累計到當前時刻,除硬盤IO等待時間以外其它等待時間(單位:jiffies) iowait (171474) 從系統(tǒng)啟動開始累計到當前時刻,硬盤IO等待時間(單位:jiffies) , irq (233) 從系統(tǒng)啟動開始累計到當前時刻,硬中斷時間(單位:jiffies) softirq (5346) 從系統(tǒng)啟動開始累計到當前時刻,軟中斷時間(單位:jiffies)
cpu使用率: (已使用2-已使用1)/(系統(tǒng)當前2-系統(tǒng)當前1)*100%
如有疑問請留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關(guān)文章
docker容器與centos宿主機時間一致設(shè)置方法
這篇文章主要介紹了docker容器與centos宿主機時間一致設(shè)置方法,本文給大家介紹的非常詳細,感興趣的朋友跟隨小編一起看看吧2024-05-05docker實現(xiàn)導(dǎo)出、導(dǎo)入和數(shù)據(jù)搬遷
本篇文章主要介紹了docker實現(xiàn)導(dǎo)出、導(dǎo)入和數(shù)據(jù)搬遷,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-07-07Docker如何給Springboot項目動態(tài)傳參的實現(xiàn)方法
這篇文章主要介紹了Docker如何給Springboot項目動態(tài)傳參的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-11-11