国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

docker的資源控制

這篇具有很好參考價(jià)值的文章主要介紹了docker的資源控制。希望對(duì)大家有所幫助。如果存在錯(cuò)誤或未考慮完全的地方,請(qǐng)大家不吝賜教,您也可以點(diǎn)擊"舉報(bào)違法"按鈕提交疑問。

一、CPU控制

cgroups,是一個(gè)非常強(qiáng)大的linux內(nèi)核工具,他不僅可以限制被namespace隔離起來的資源,

還可以為資源設(shè)置權(quán)重、計(jì)算使用量、操控進(jìn)程啟停等等。所以cgroups (Control groups) 實(shí)現(xiàn)了對(duì)資源的配額和度量。

cgroups有四大功能:

  1. 資源限制:可以對(duì)任務(wù)使用的資源總額進(jìn)行限制;

  2. 優(yōu)先級(jí)分配:通過分配的cpu時(shí)間片數(shù)量以及磁盤I0帶寬大小,實(shí)際上相當(dāng)于控制了任務(wù)運(yùn)行優(yōu)先級(jí);

  3. 資源統(tǒng)計(jì):可以統(tǒng)計(jì)系統(tǒng)的資源使用量,如cpu時(shí)長(zhǎng), 內(nèi)存用量等;

  4. 任務(wù)控制: cgroup可以對(duì)任務(wù)執(zhí)行掛起、恢復(fù)等操作。

1、設(shè)置CPU使用率上限

Linux通過CFS ( Completely Fair Scheduler, 完全公平調(diào)度器)來調(diào)度各個(gè)進(jìn)程對(duì)CPU的使用。CFS默認(rèn)的調(diào)度周期是100ms。

可以設(shè)置每個(gè)容器進(jìn)程的調(diào)度周期,以及在這個(gè)周期內(nèi)各個(gè)容器最多能使用多少CPU時(shí)間。

使用--cpu-period即可設(shè)置調(diào)度周期,使用--cpu-quota即可設(shè)置在每個(gè)周期內(nèi)容器能使用的CPU時(shí)間。兩者可以配合使用。

CFS周期的有效范圍是1ms~1s, 對(duì)應(yīng)的--cpu-period的數(shù)值范圍是1000~1000000。

容器的CPU 配額必須不小于1ms,即--cpu-quota 的值必須>= 1000。

查看CPU使用率

docker run -itd --name test centos:7 /bin/bash

cd /sys/fs/cgroup/cpu/docker/98804287283ce0f6abe8a19c9884c6b5149acc5a050a767e                      9f5f4bac5472ef56/

cat cpu.cfs_period_us cpu.cfs_quota_us
100000
-1

#cpu.cfs_period_us:cpu分配的周期(微秒,所以文件名中用 us 表示),默認(rèn)為100000。

#cpu.cfs_quota_us:表示該control group限制占用的時(shí)間(微秒),默認(rèn)為-1,表示不限制。 如果設(shè)為50000,表示占用50000/100000=50%的CPU。

docker的資源控制

進(jìn)行CPU壓力測(cè)試

docker exec -it 98804287283c /bin/bash
vim /cpu.sh
#!/bin/bash
i=0
while true
do
let i++
done
 
chmod +x /cpu.sh
./cpu.sh
exit
 
top  

docker的資源控制

docker的資源控制


 

設(shè)置CPU使用率

#設(shè)置50%的比例分配CPU使用時(shí)間上限
docker run -itd --name test2 --cpu-quota 50000 centos:7 /bin/bash   #可以重新創(chuàng)建一個(gè)容器并設(shè)置限額
或者
cd /sys/fs/cgroup/cpu/docker/98804287283ce0f6abe8a19c9884c6b5149acc5a050a767e9f5f4bac5472ef56
echo 50000 > cpu.cfs_quota_us
docker exec -it 98804287283c /bin/bash
./cpu.sh
exit
 
top                                                #可以看到cpu占用率接近50%,cgroups對(duì)cpu的控制起了效果

docker的資源控制

docker的資源控制

2、設(shè)置CPU資源占用比(設(shè)置多個(gè)容器時(shí)才有效)

Docker 通過--cpu-shares 指定 CPU 份額,默認(rèn)值為1024,值為1024的倍數(shù)。

#創(chuàng)建兩個(gè)容器為 c1 和 c2,若只有這兩個(gè)容器,設(shè)置容器的權(quán)重,使得c1和c2的CPU資源占比為1/3和2/3。

docker run -itd --name test1 --cpu-shares 1024 centos:7
docker run -itd --name test2 --cpu-shares 512 centos:7
 
#分別進(jìn)入容器,進(jìn)行壓力測(cè)試
docker exec -it 2e71bd7f3c4c bash
yum install -y epel-release
yum install stress -y
stress -c 4                 #產(chǎn)生四個(gè)進(jìn)程,每個(gè)進(jìn)程都反復(fù)不停的計(jì)算隨機(jī)數(shù)的平方根
 
#查看容器的運(yùn)行狀態(tài)(動(dòng)態(tài)更新)
docker stats

docker的資源控制

docker的資源控制

docker的資源控制

3、設(shè)置容器綁定指定的CPU

#先分配虛擬機(jī)4個(gè)CPU核數(shù)
docker run -itd --name test2 --cpuset-cpus 1,3 centos:7 /bin/bash
 
#進(jìn)入容器,進(jìn)行壓力測(cè)試
yum install -y epel-release
yum install stress -y
stress -c 4
exit
 
#退出容器,執(zhí)行 top 命令再按 1 查看CPU使用情況。

docker的資源控制

docker的資源控制

docker的資源控制

二、對(duì)內(nèi)存使用進(jìn)行限制

1、創(chuàng)建指定物理內(nèi)存的容器

-m(--memory=)選項(xiàng)用于限制容器可以使用的最大內(nèi)存
docker run -itd --name test4 -m 512m centos:7 /bin/bash
 
docker stats

docker的資源控制

docker的資源控制

2、創(chuàng)建指定物理內(nèi)存和swap的容器

docker run -itd --name gxd7 -m 512m --memory-swap 1g centos:7 /bin/bash
 
強(qiáng)調(diào)一下,--memory-swap是必須要與--memory一起使用的
 
正常情況下,--memory-swap的值包含容器可用內(nèi)存和可用swap
所以-m 300m --memory-swap=1g 的含義為:容器可以使用300M 的物理內(nèi)存,并且可以使用700M (1G - 300M)的swap
 
如果--memory-swap設(shè)置為0或者不設(shè)置,則容器可以使用的swap大小為-m值的兩倍
如果--memory-swap的值和-m值相同,則容器不能使用swap
如果--memory-Swap值為-1,它表示容器程序使用的內(nèi)存受限,而可以使用的swap空間使用不受限制(宿主機(jī)有多少,swap容器就可以使用多少)

docker的資源控制

3、 對(duì)磁盤IO配額控制(blkio)的限制

3.1 設(shè)置限制項(xiàng)

--device-read-bps:限制某個(gè)設(shè)備上的讀速度bps(數(shù)據(jù)量),單位可以是kb、mb(M)或者gb。
例:docker run -itd --name test1 --device-read-bps /dev/sda:1M  centos:7 /bin/bash
 
--device-write-bps : 限制某個(gè)設(shè)備上的寫速度bps(數(shù)據(jù)量),單位可以是kb、mb(M)或者gb。
例:docker run -itd --name test1 --device-write-bps /dev/sda:1mb centos:7 /bin/bash
 
--device-read-iops :限制讀某個(gè)設(shè)備的iops(次數(shù))
  
--device-write-iops :限制寫入某個(gè)設(shè)備的iops(次數(shù))

3.2 創(chuàng)建容器,并限制寫速度

docker的資源控制

3.3 通過dd來驗(yàn)證寫速度

docker exec -it test1 bash                       #進(jìn)入容器
dd if=/dev/zero of=test.out bs=1M count=50 oflag=direct #添加oflag參數(shù)以規(guī)避掉文件系統(tǒng)cache

docker的資源控制

4、清理docker占用的磁盤空間

docker system prune -a  #可以用于清理磁盤,刪除關(guān)閉的容器、無用的數(shù)據(jù)卷和網(wǎng)絡(luò)

docker的資源控制文章來源地址http://www.zghlxwxcb.cn/news/detail-482930.html

到了這里,關(guān)于docker的資源控制的文章就介紹完了。如果您還想了解更多內(nèi)容,請(qǐng)?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點(diǎn)僅代表作者本人,不代表本站立場(chǎng)。本站僅提供信息存儲(chǔ)空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請(qǐng)注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實(shí)不符,請(qǐng)點(diǎn)擊違法舉報(bào)進(jìn)行投訴反饋,一經(jīng)查實(shí),立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費(fèi)用

相關(guān)文章

  • 初探 Linux Cgroups:資源控制的奇妙世界

    Cgroups 是 linux 內(nèi)核提供的功能,由于牽涉的概念比較多,所以不太容易理解。本文試圖通過簡(jiǎn)單的描述和 Demo 幫助大家理解 Cgroups 。 如果你對(duì)云原生技術(shù)充滿好奇,想要深入了解更多相關(guān)的文章和資訊,歡迎關(guān)注微信公眾號(hào)。 搜索公眾號(hào)【 探索云原生 】即可訂閱 Cgroups 是

    2024年02月03日
    瀏覽(16)
  • 十七、Docker之Cgroup資源配置

    其實(shí)在日常的工作中,我們一般都沒有對(duì)docker容器進(jìn)行資源限制,也就是默認(rèn)情況下,可以使用宿主機(jī)的所有資源。但是如果你運(yùn)行的服務(wù)有問題,就有可能對(duì)宿主機(jī)和宿主機(jī)上的其他業(yè)務(wù)造成影響,這還是有一定的風(fēng)險(xiǎn)。那么本文會(huì)給大家介紹一下如何對(duì)容器進(jìn)行資源配置

    2024年02月16日
    瀏覽(20)
  • docker cgroup資源占用及docker的鏡像創(chuàng)建

    docker cgroup資源占用及docker的鏡像創(chuàng)建

    基本復(fù)寫了常見的資源配額和使用量控制 cgroup是controlgroup的縮寫 設(shè)置cpu使用率的上限 linux通過cfs(完全公平調(diào)度器)來調(diào)度各個(gè)進(jìn)程對(duì)cpu的使用,cfs默認(rèn)的調(diào)度周期是100ms 我們可以設(shè)置每個(gè)容器進(jìn)程的調(diào)度周期,以及再這個(gè)周期內(nèi)各個(gè)容器最多能使用cpu時(shí)間。 cpu分多少時(shí)間

    2024年02月08日
    瀏覽(25)
  • 500行代碼手寫docker-實(shí)現(xiàn)硬件資源限制cgroups

    本系列教程主要是為了弄清楚容器化的原理,紙上得來終覺淺,絕知此事要躬行,理論始終不及動(dòng)手實(shí)踐來的深刻,所以這個(gè)系列會(huì)用go語(yǔ)言實(shí)現(xiàn)一個(gè)類似docker的容器化功能,最終能夠容器化的運(yùn)行一個(gè)進(jìn)程。 本章的源碼已經(jīng)上傳到github,地址如下: 之前我們對(duì)容器的網(wǎng)絡(luò)命

    2024年02月06日
    瀏覽(21)
  • linux 內(nèi)核資源配置--cgroups詳解以及在docker中的應(yīng)用

    linux 內(nèi)核資源配置--cgroups詳解以及在docker中的應(yīng)用

    1.1、cgroups 是什么 Linux cgroup (Control Groups)是 Linux 內(nèi)核提供的一種機(jī)制, 用于限制進(jìn)程組使用的資源(如 CPU、內(nèi)存、磁盤 I/O 等) 。通過將進(jìn)程組劃分為層次結(jié)構(gòu),并將資源限制應(yīng)用于不同層次的組,可以實(shí)現(xiàn)對(duì)系統(tǒng)資源的統(tǒng)一管理和限制。 cgroup 提供了一套 API,用于創(chuàng)建

    2024年02月16日
    瀏覽(25)
  • Hadoop YARN Cgroups 資源隔離講解

    Hadoop YARN Cgroups 資源隔離講解

    Hadoop YARN (Yet Another Resource Negotiator) 使用 Cgroups (Control Groups)來進(jìn)行資源管理和隔離。 Cgroups 是 Linux 內(nèi)核提供的一種機(jī)制,用于限制、賬戶和隔離進(jìn)程組(process groups)的資源(例如 CPU、內(nèi)存、磁盤 I/O 等)。 以下是 Hadoop YARN Cgroups 的主要講解: 資源隔離和管理: Cgroups 允

    2024年02月01日
    瀏覽(46)
  • 深入剖析 Linux Cgroups 子系統(tǒng):資源精細(xì)管理

    本章主要演示以下 cgroups 下各個(gè) subsystem 的作用。 根據(jù)難易程度,依次演示了 pids 、cpu 和 memory 3 個(gè) subsystem 的使用。 注:本文所有操作在 Ubuntu20.04 下進(jìn)行。 如果你對(duì)云原生技術(shù)充滿好奇,想要深入了解更多相關(guān)的文章和資訊,歡迎關(guān)注微信公眾號(hào)。 搜索公眾號(hào)【 探索云原

    2024年02月02日
    瀏覽(21)
  • Docker資源控制

    Docker資源控制

    Docker 通過 Cgroup 來控制容器使用的資源配額,包括 CPU、內(nèi)存、磁盤三大方面, 基本覆蓋了常見的資源配額和使用量控制。 Cgroup 是 ControlGroups 的縮寫,是 Linux 內(nèi)核提供的一種可以限制、記錄、隔離進(jìn)程組所使用的物理資源(如 CPU、內(nèi)存、磁盤 IO 等等) 的機(jī)制,被 LXC、docker 等

    2024年02月08日
    瀏覽(15)
  • docker的資源控制

    docker的資源控制

    cgroups,是一個(gè)非常強(qiáng)大的linux內(nèi)核工具,他不僅可以限制被namespace隔離起來的資源, 還可以為資源設(shè)置權(quán)重、計(jì)算使用量、操控進(jìn)程啟停等等。所以cgroups (Control groups) 實(shí)現(xiàn)了對(duì)資源的配額和度量。 cgroups有四大功能: 資源限制:可以對(duì)任務(wù)使用的資源總額進(jìn)行限制; 優(yōu)先級(jí)分配

    2024年02月08日
    瀏覽(20)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請(qǐng)作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包