網(wǎng)站首頁 編程語言 正文
一、CPU控制
cgroups,是一個非常強大的linux內(nèi)核工具,他不僅可以限制被namespace隔離起來的資源,
還可以為資源設置權重、計算使用量、操控進程啟停等等。所以cgroups (Control groups) 實現(xiàn)了對資源的配額和度量。
cgroups有四大功能:
-
資源限制:可以對任務使用的資源總額進行限制;
-
優(yōu)先級分配:通過分配的cpu時間片數(shù)量以及磁盤I0帶寬大小,實際上相當于控制了任務運行優(yōu)先級;
-
資源統(tǒng)計:可以統(tǒng)計系統(tǒng)的資源使用量,如cpu時長, 內(nèi)存用量等;
-
任務控制: cgroup可以對任務執(zhí)行掛起、恢復等操作。
1、設置CPU使用率上限
Linux通過CFS ( Completely Fair Scheduler, 完全公平調(diào)度器)來調(diào)度各個進程對CPU的使用。CFS默認的調(diào)度周期是100ms。
可以設置每個容器進程的調(diào)度周期,以及在這個周期內(nèi)各個容器最多能使用多少CPU時間。
使用--cpu-period即可設置調(diào)度周期,使用--cpu-quota即可設置在每個周期內(nèi)容器能使用的CPU時間。兩者可以配合使用。
CFS周期的有效范圍是1ms~1s, 對應的--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 表示),默認為100000。
#cpu.cfs_quota_us:表示該control group限制占用的時間(微秒),默認為-1,表示不限制。 如果設為50000,表示占用50000/100000=50%的CPU。
進行CPU壓力測試
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
設置CPU使用率
#設置50%的比例分配CPU使用時間上限
docker run -itd --name test2 --cpu-quota 50000 centos:7 /bin/bash #可以重新創(chuàng)建一個容器并設置限額
或者
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對cpu的控制起了效果
2、設置CPU資源占用比(設置多個容器時才有效)
Docker 通過--cpu-shares 指定 CPU 份額,默認值為1024,值為1024的倍數(shù)。
#創(chuàng)建兩個容器為 c1 和 c2,若只有這兩個容器,設置容器的權重,使得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
#分別進入容器,進行壓力測試
docker exec -it 2e71bd7f3c4c bash
yum install -y epel-release
yum install stress -y
stress -c 4 #產(chǎn)生四個進程,每個進程都反復不停的計算隨機數(shù)的平方根
#查看容器的運行狀態(tài)(動態(tài)更新)
docker stats
3、設置容器綁定指定的CPU
#先分配虛擬機4個CPU核數(shù)
docker run -itd --name test2 --cpuset-cpus 1,3 centos:7 /bin/bash
#進入容器,進行壓力測試
yum install -y epel-release
yum install stress -y
stress -c 4
exit
#退出容器,執(zhí)行 top 命令再按 1 查看CPU使用情況。
二、對內(nèi)存使用進行限制
1、創(chuàng)建指定物理內(nèi)存的容器
-m(--memory=)選項用于限制容器可以使用的最大內(nèi)存
docker run -itd --name test4 -m 512m centos:7 /bin/bash
docker stats
2、創(chuàng)建指定物理內(nèi)存和swap的容器
docker run -itd --name gxd7 -m 512m --memory-swap 1g centos:7 /bin/bash
強調(diào)一下,--memory-swap是必須要與--memory一起使用的
正常情況下,--memory-swap的值包含容器可用內(nèi)存和可用swap
所以-m 300m --memory-swap=1g 的含義為:容器可以使用300M 的物理內(nèi)存,并且可以使用700M (1G - 300M)的swap
如果--memory-swap設置為0或者不設置,則容器可以使用的swap大小為-m值的兩倍
如果--memory-swap的值和-m值相同,則容器不能使用swap
如果--memory-Swap值為-1,它表示容器程序使用的內(nèi)存受限,而可以使用的swap空間使用不受限制(宿主機有多少,swap容器就可以使用多少)
3、 對磁盤IO配額控制(blkio)的限制
3.1 設置限制項
--device-read-bps:限制某個設備上的讀速度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 : 限制某個設備上的寫速度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 :限制讀某個設備的iops(次數(shù))
--device-write-iops :限制寫入某個設備的iops(次數(shù))
3.2 創(chuàng)建容器,并限制寫速度
3.3 通過dd來驗證寫速度
docker exec -it test1 bash #進入容器
dd if=/dev/zero of=test.out bs=1M count=50 oflag=direct #添加oflag參數(shù)以規(guī)避掉文件系統(tǒng)cache
4、清理docker占用的磁盤空間
docker system prune -a #可以用于清理磁盤,刪除關閉的容器、無用的數(shù)據(jù)卷和網(wǎng)絡
原文鏈接:https://blog.csdn.net/wmc995620/article/details/125751470
- 上一篇:Docker的數(shù)據(jù)管理
- 下一篇:docker基本概念及安裝
相關推薦
- 2022-06-16 Python中弱引用的神奇用法與原理詳解_python
- 2022-03-15 When allowCredentials is true, allowedOrigins cann
- 2023-02-05 解讀golang中的const常量和iota_Golang
- 2023-11-15 【深度學習】YOLOv5斷點訓練——中斷后繼續(xù)訓練
- 2022-09-24 基于Pytorch實現(xiàn)邏輯回歸_python
- 2022-06-01 python中使用正則表達式的方法詳解_python
- 2022-07-03 python類的私有屬性和公共屬性說明_python
- 2023-01-28 GoLang分布式鎖與snowflake雪花算法_Golang
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細win安裝深度學習環(huán)境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結構-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支