91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Container內部進程監控是怎樣的

發布時間:2021-12-20 09:22:59 來源:億速云 閱讀:189 作者:iii 欄目:網絡管理

這篇文章主要介紹“Container內部進程監控是怎樣的”,在日常操作中,相信很多人在Container內部進程監控是怎樣的問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Container內部進程監控是怎樣的”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

目前市場上的虛擬化技術種類很多,例如moby(docker)、LXC、RKT等等。在帶來方便應用部署和資源充分利用的好處的同時,如何監控相應Container及其內部應用進程成為運維人員不可避免遇到的新情況。UAV.Container從虛擬化技術的基礎原理和Linux操作系統的內核特性出發,得到Container容器和內部進程的各維度監控數據,使無論是虛擬機或物理機運維人員,還是業務運維人員角度,都能得到合適的監控維度。

虛擬化技術從基礎原理上主要是cgroups、namespace和file system的應用,而操作系統作為cgroup和namespace根節點,無論在container里啟動何種應用,從內核角度上來說,肯定在操作系統有其一定的特征和表現形式。我們需要做的就是對這些特征做加工處理,以得到相應的監控數據。

下面我們以docker技術舉例,其他虛擬化技術類似。

一、Container ID

Container ID是一個Container的唯一標識。從容器監控的角度我們需要能得到該進程在哪個Container里運行。在操作系統層面,進程的cgroup的掛載情況就能有所體現。如圖所示,我們在一個ID為3411554ff684的Container內部跑一個Tomcat進程。

Container內部進程監控是怎樣的

由于Container的pid namespace是操作系統的pid namespace的子namespace,那么該進程在操作系統級也應該有相應的pid,用docker top命令驗證一下:

Container內部進程監控是怎樣的

該容器內進程在宿主機上的進程號為1848。接下來進入/proc/1848/cgroup下看看該進程的cgroup掛載情況

Container內部進程監控是怎樣的

從cgroup文件里清楚的顯示了實現了該容器的虛擬化技術、Container ID和此container的資源掛載路徑,對比一下這里面顯示的Container ID,和創建Container時的ID完全相同。這也驗證了通過掃描宿主機進程的cgroup信息可以獲得Container ID。這樣就將pid和Container ID做了關聯。

二、CPU

雖然cgroup管控了該cgroup下所有進程的CPU使用情況,但從操作系統的角度上,不論進程是否隸屬于某個子cgroup下,仍然是共用宿主機的CPU。所以監控宿主機上該進程的CPU就能得到進程的CPU監控指標。

Linux上常用的CPU監控命令是top。top對CPU監控的原理是在time1時刻獲取CPU從啟動時的累計總時間countAll1和busy總時間countBusy1,再到time2時刻獲取CPU總時間countAll2和busy總時間countBusy2,最后用busy的時間差值減去總時間的差值得到了在time1到time2這個時間段內機器CPU的占用情況。也就是:

CPU占用率(%) = (countBusy2 - countBusy1)/(countAll2 - countAll1) * 100

進程同理,在兩個時刻分別得到每個進程的busy總時間countProcBusy1和countProcBusy2,則得到進程CPU占用率:

進程CPU占用率(%) = (countProcBusy2 - countProcBusy1)/(countProcAll2 - countProcAll1)*100

宿主機從啟動開始的CPU總時間片可以從/proc/stat下獲取:

Container內部進程監控是怎樣的

第一行是總的CPU使用情況,具體參數的意思:

所以,選擇當前為time1,3秒后為time2,countAll = user + nice + system + idle + iowait + irq + softirq + stealstolean + guest + guest_nice。countBusy為countAll減去idle的值,這樣上面第一個公式的所有需要的值就齊了,可以直接計算。

第二行、第三行是每個邏輯CPU的使用情況,這里記下有兩個邏輯CPU,CPU的邏輯核數與CPU顯示模式irix和solaris有關。

接下來是countProcBusy的計算,進程的CPU時間片位于/proc/$pid/stat下,如圖所示:

Container內部進程監控是怎樣的

這個文件里面體現了很多進程的相關信息。其中第14、15、16、17個參數與CPU有關。

所以,countProcBusy = utime + stime + cutime + cstime,該值包括其所有線程的cpu時間。而countProcAll2-countProcAll1=3s,通過兩個時刻的countProcBusy和countProcAll,進程CPU的占用率就能得到了。

其中需要注意的問題有兩點:

1) jiffies實際上指的是內核時鐘使用的節拍總數,所以這里的jiffies需要換算成秒才能應用上面的除法公式。

2) 剛剛我們談到CPU顯示模式irix和solaris,簡單來說irix模式就是機器有N個邏輯CPU,CPU顯示上限就是N*100%,solaris模式就是不管機器有多少邏輯CPU,CPU顯示上限就是100%,而/proc/$pid/stat顯示的是計算了所有邏輯CPU時間的,所以兩種顯示方式意味著計算方法稍有差異,solaris模式的結果需要在上面進程CPU占用率公式基礎之上除以邏輯核數。

三、內存

進程內存的監控有兩個維度的數據:一是物理占用內存大小,二是進程內存占用百分比的大小。

進程內存占用率(%) = 進程物理內存占用大小 / 宿主機總內存大小 * 100

與CPU類似,/proc/$pid/status文件記錄了進程物理內存使用情況,其中VmRSS即為該進程目前所占實際物理內存的大小。

Container內部進程監控是怎樣的

/proc/meminfo文件下記錄了機器內存占用情況,這個文件很長,截取其中的一部分展示一下,MemTotal就是宿主機總內存大小:

Container內部進程監控是怎樣的

這樣,這個進程的物理內存占用和機器總內存就都得到了,相應的進程內存的占用率也就得到了。

四、磁盤IO

磁盤IO獲取也很簡單,/proc/$pid/io已經幫我們把這個進程的io情況記錄下來了,但是與CPU類似,io文件里存的也是該進程從啟動到現在的io總量,那么:

磁盤I/O(bytes/秒) = (time2時刻I/O – time1時刻I/O) / (time2 – time1)

Container內部進程監控是怎樣的

其中的read_bytes和write_bytes分別為該進程從啟動到目前為止的讀取字節數和寫入字節數,分別取2個時刻的值,根據上面的公式,就得到了該進程的磁盤IO。

五、端口號和連接數

由于Network Namespace對網絡做了隔離,所以如果進程在Container內部運行,該進程的端口信息也應該是進程本身監聽的端口號,而不是真正實際對外的端口,而Container內外端口的映射機制是由應用的虛擬化技術本身控制的,這就避免不了與實現容器的虛擬化技術打交道了,那么問題就轉化成獲取容器內進程本身監聽的端口了。

/proc/$pid/net/tcp(tcp6,udp,udp6)就對端口號和連接數做了相應的歷史記錄。這些文件格式都類似,以tcp6舉例

Container內部進程監控是怎樣的

解釋幾個關鍵的key:

因為st = 0A代表listen,所以從其中挑選出st = 0A的數據,取出對應的inode號,這里這個inode號是socket號,則問題轉換為了這個進程是否還存在這個socket號代表的socket。在/proc/$pid/fd下有該進程所有的fd(file descriptor),截取一段舉個例子。

Container內部進程監控是怎樣的

每個文件描述符后面的軟鏈實際上就是打開的文件,以socket開頭的就是這個進程打開的socket,在中括號中間的部分就是socket號。拿著這個socket號和上面tcp6里獲得的inode號做一個匹配,如果對應上,那么tcp6里的st = 0A的端口就是這個進程監聽的。至于容器內外端口的映射,這就需要根據應用的虛擬化技術的映射方法來獲取了。連接數計算與端口掃描是同理的,區別只在于需要對st = 01(establish)進行掃描計數累加。

到此,關于“Container內部進程監控是怎樣的”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

隆安县| 汝州市| 永泰县| 九寨沟县| 两当县| 友谊县| 苍山县| 漾濞| 永康市| 乌兰浩特市| 杂多县| 吴旗县| 开封县| 六枝特区| 广汉市| 布尔津县| 永嘉县| 柳州市| 赤水市| 松原市| 烟台市| 松滋市| 沂源县| 古田县| 长葛市| 乌拉特后旗| 宜都市| 濉溪县| 广河县| 三门县| 龙胜| 禹州市| 乌兰察布市| 迁西县| 清涧县| 射阳县| 锡林郭勒盟| 上犹县| 楚雄市| 湖州市| 忻城县|