欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Docker底層技術Namespace Cgroup應用詳解

 更新時間:2019年10月29日 08:20:00   作者:51cto  
在本篇文章里小編給大家整理的是關于Docker底層技術Namespace Cgroup應用的相關知識點,需要的朋友們學習下。

Docker底層技術:

docker底層的2個核心技術分別是Namespaces和Control groups

Namespace:是容器虛擬化的核心技術,用來隔離各個容器,可解決容器之間的沖突。

主要通過以下六項隔離技術來實現(xiàn):
有兩個偽文件系統(tǒng):/proc和/sys/

  • UTS:允許每個container擁有獨立的hostname(主機名)和domainname(域名),使其在網絡上可以被視作一個獨立的節(jié)點而非Host上的一個進程。
  • IPC:contaner中進程交互還是采用linux常見的進程間交互方法,包括常見的信號量,消息隊列和共享內存。container的進程間交互實際上還是host上具有相同pid中的進程交互。
  • PID:不同用戶的進程就是通過pid namesapce隔離開的,且不同namespace中可以有相同pid。所有的LXC(linux containers)進程在docker中的父進程為docker進程,每個LXC進程具有不同的namespace。
  • NET:不同用戶的進程就是通過pidnamespace隔離開的,且不同namespace中可以有相同pid。所有的LXC進程在docker中的父進程為docker進程,每個lxc進程具有不同的namespace。
  • MNT:文件系統(tǒng)的掛載點。
  • USRE:每個container可以有不同的user和groupid,也就是說可以在container內部用container內部的用戶執(zhí)行程序而非Host上的用戶。

只要解耦了這6項,其他系統(tǒng)資源即便有共用的情況,計算機也認為是在兩個不同的系統(tǒng)中。

cgroup(控制程序對資源的占用)

實現(xiàn)cgroup是的主要目的是為不同用戶層面的資源管理,提供一個統(tǒng)一化的接口。從單個進程的資源控制到操作系統(tǒng)層面的虛擬化。

cgroup的作用:

1) 資源的限制:cgroup可以對進程組使用的資源總額進行限制。
2) 優(yōu)先級分配:通過分配的cpu時間片數(shù)量及磁盤IO帶寬大小,實際上就是相當于控制了進程運行的優(yōu)先級
3) 資源統(tǒng)計:Cgroup可以統(tǒng)計系統(tǒng)資源使用量。比如cpu使用時間,內存使用量等。
可用于按量計費。
4) 進程控制:可以對進程組執(zhí)行掛起,恢復等操作。

cgroup的應用:

1)內存和交換分區(qū)的限制:

容器內包括兩個部分:物理內存和swap

在docker中可以通過參數(shù)控制容器內存的使用:

-m或--memory:設置內存的使用限額

--memory-swap:設置swap(交換分區(qū))的使用限額

//基于centos鏡像,限制內存為200M,交換分區(qū)的內存為300M

[root@sqm-docker01 ~]# docker run -it -m 200M --memory-swap 300M centos

進入容器查看限制的內存:

[root@05a0be7b870a /]# cat /sys/fs/cgroup/memory/memory.limit_in_bytes 
209715200  #顯示的是字節(jié)

[root@05a0be7b870a /]# cat /sys/fs/cgroup/memory/memory.memsw.limit_in_bytes 
314572800

2)容器對cpu限制:

通過-c或者--cpu-shares設置容器實驗cpu的權重。如果不設置默認是1024.

//基于centos鏡像,運行一個容器,名字為containerB,cpu權重限制為512:
[root@sqm-docker01 ~]# docker run -it --name containerB -c 512 centos
[root@b2cf9f28ce1d /]# cat /sys/fs/cgroup/cpu/cpu.shares 
512

3)限制容器的Block io(磁盤的讀寫):

bps:每秒讀寫的數(shù)據(jù)量。byte per second
iops:每秒io的次數(shù)。 io per second

--device-read-bps:設置讀取設備的bps
--device-write-bps:設置寫入設備的bps

--device-read-iops:設置讀取設備的iops
--device-write-iops:設置寫入設備的iops

//創(chuàng)建一個容器名為testA,并限制該磁盤每秒寫入的數(shù)量為為30MB。
[root@sqm-docker01 ~]# docker run -it --name testA --device-write-bps /dev/sda:30MB centos

寫入數(shù)據(jù)進行測試:

參數(shù)解釋:
infile=從/dev/zero中提取
outfile=自定義一個名稱
bs=1M 文件大小為1M
count=800 總共寫800次。
oflag=direct:用來指定directory IO方式寫文件,這樣才會使--device-write-bps生效。

可以發(fā)現(xiàn)每秒寫入的數(shù)量為80M,大概用時26s。

正常寫入磁盤時:

以上就是本次介紹的關于Docker底層技術全部知識點,感謝大家的學習和對腳本之家的支持。

相關文章

  • IDEA中進行Docker項目部署的實現(xiàn)步驟

    IDEA中進行Docker項目部署的實現(xiàn)步驟

    這篇文章主要介紹了IDEA中進行Docker項目部署的實現(xiàn)步驟,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-11-11
  • docker鏡像訪問本地elasticsearch端口操作

    docker鏡像訪問本地elasticsearch端口操作

    這篇文章主要介紹了docker鏡像訪問本地elasticsearch端口操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11
  • docker安裝RabbitMQ詳細步驟

    docker安裝RabbitMQ詳細步驟

    大家好,本篇文章主要講的是docker安裝RabbitMQ詳細步驟,感興趣的同學趕快來看一看吧,對你有幫助的話記得收藏一下,方便下次瀏覽
    2022-01-01
  • centos搭建部署docker環(huán)境的詳細步驟

    centos搭建部署docker環(huán)境的詳細步驟

    Docker 將程序與程序的運行環(huán)境打包在一起,從而避免了復雜的環(huán)境配置,下面這篇文章主要給大家介紹了關于centos搭建部署docker環(huán)境的詳細步驟,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-07-07
  • 清理Docker廢棄鏡像與緩存詳細圖文教程

    清理Docker廢棄鏡像與緩存詳細圖文教程

    在使用Docker進行開發(fā)和部署過程中,我們可能會遇到需要刪除舊鏡像和容器以釋放磁盤空間或清除不再需要的緩存的情況,這篇文章主要給大家介紹了關于清理Docker廢棄鏡像與緩存的相關資料,需要的朋友可以參考下
    2024-07-07
  • 綁定Dokcer容器到主機指定網卡的方法

    綁定Dokcer容器到主機指定網卡的方法

    這篇文章主要介紹了綁定 Dokcer 容器到主機指定網卡的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-03-03
  • Docker搭建 Nginx+PHP+MySQL 環(huán)境并部署WordPress實踐

    Docker搭建 Nginx+PHP+MySQL 環(huán)境并部署WordPress實踐

    本文給大家分享的是作者基于Docker搭建 Nginx+PHP+MySQL 環(huán)境并部署WordPress的詳細過程,非常的全面,有需要的小伙伴可以參考下
    2017-02-02
  • Docker如何查看正在運行的容器目錄

    Docker如何查看正在運行的容器目錄

    這篇文章主要介紹了Docker如何查看正在運行的容器目錄問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • 一文帶你快速了解和使用Docker

    一文帶你快速了解和使用Docker

    本文對 Docker 進行全面闡述,詳細介紹 Docker 的作用、其基本使用,如常用命令、Dockerfile 的作用及使用、Docker Compose 的作用及使用,感興趣的同學跟著小編一起來學習吧
    2023-05-05
  • docker 文件存放路徑, 修改端口映射操作方式

    docker 文件存放路徑, 修改端口映射操作方式

    這篇文章主要介紹了docker 文件存放路徑, 修改端口映射操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-03-03

最新評論