企业入门实战- - docker之docker安全设置
一.容器内存控制
创建自定义大小的容器
docker run -m 200M -d --name demo nginx
data:image/s3,"s3://crabby-images/98a46/98a46f579836007e18059a36a13ff85f5c346aca" alt="在这里插入图片描述"
cd /sys/fs/cgroup/memory/docker/
进入 刚刚创建的id
cat memory.memsw.limit_in_bytes
data:image/s3,"s3://crabby-images/3287f/3287fe96acf65bc66dca110f3968e3d1d0a9fd13" alt="在这里插入图片描述"
设置内容写入大小
cd /sys/fs/cgroup/memory
mkdir x1
cd x1
data:image/s3,"s3://crabby-images/e7d49/e7d49104adfcad48cc7c98f6a83828d8d7624d3d" alt="在这里插入图片描述"
echo 209715200 > memory.limit_in_bytes 限制写入大小为200M
data:image/s3,"s3://crabby-images/b10eb/b10eb18b91e1ebfc64d58d92610027fe96a2769b" alt="在这里插入图片描述" 安装cgroup工具
yum install -y libcgroup-tools.x86_
data:image/s3,"s3://crabby-images/37f72/37f723b1583e291e772e954eaabe3d908abf9275" alt="在这里插入图片描述"
测试:在/dev/shm 目录下 每次测试前需要删除掉创建的bigfile
100M
free -m
cgexec -g memory:x1 dd if=/dev/zero of=bigfile bs=1M count=100
free -m
data:image/s3,"s3://crabby-images/90829/908294e065ef8dc9acc3571e88b31ba57c13b537" alt="在这里插入图片描述"
200M
free -m
cgexec -g memory:x1 dd if=/dev/zero of=bigfile bs=1M count=200
free -m
data:image/s3,"s3://crabby-images/fa9fc/fa9fc8e1e1a949786dc37268d5f62ebef493bed5" alt="在这里插入图片描述"
300M
ee -m
cgexec -g memory:x1 dd if=/dev/zero of=bigfile bs=1M count=300
free -m
data:image/s3,"s3://crabby-images/86290/862905c74030e731ab42669c99c9bd6a3b75e748" alt="在这里插入图片描述" 这时候会发现多出来的100M被放到了swap分区中
关闭swap分区测试
cd /dev/shm
rm -fr bigfile
swapoff -a
cgexec -g memory:x1 dd if=/dev/zero of=bigfile bs=1M count=300 ## 会被kill掉
data:image/s3,"s3://crabby-images/0bc1d/0bc1d1070bdeae6f04853d253c75c04e849d48af" alt="在这里插入图片描述"
打开swap分区 设置容器swap不能写入
cd /sys/fs/cgroup/memory/x1
echo 209715200 > memory.memsw.limit_in_bytes ## 最大写入200M
data:image/s3,"s3://crabby-images/1cc90/1cc90805a3a3a42fc0a218ede9d1d148c2bda231" alt="在这里插入图片描述" 测试:
cd /dev/shm
cgexec -g memory:x1 dd if=/dev/zero of=bigfile bs=1M count=300 ## 直接报错
data:image/s3,"s3://crabby-images/ab05d/ab05d2d95ff7c351ed373b98c86e1660be836857" alt="在这里插入图片描述" 虽然导入了300M但是只能写入200M data:image/s3,"s3://crabby-images/00d6e/00d6e3368f2ea5524e5a41211f952dd430d1c62f" alt="在这里插入图片描述"
二.cpu配额
这里的虚拟机只有一个cpu
cd /sys/fs/cgroup/cpu ## 进入目录
mkdir x2
cd x2/
ls
data:image/s3,"s3://crabby-images/9ac99/9ac99abbfbdca31e14b8773f741a519e3861c00f" alt="在这里插入图片描述" 设定cpu配额
cat cpu.shares
echo 100 > cpu.shares
data:image/s3,"s3://crabby-images/cf209/cf209e100e1c3188547da6fd5cb9faf8a64581ab" alt="在这里插入图片描述"
dd if=/dev/zero of=/dev/null & ## 打入后台
top 查看dd的进程号
data:image/s3,"s3://crabby-images/d54d0/d54d08a60c8a895dbf63effbb3e4b3f1db1d465e" alt="在这里插入图片描述"
cat tasks
echo 14768 > tasks ## dd命令的进程号写入task中
data:image/s3,"s3://crabby-images/e2e64/e2e64bafd17d4b88497e3a33779d54dc85563535" alt="在这里插入图片描述" 再次运行此命令
dd if=/dev/zero of=/dev/null &
top
data:image/s3,"s3://crabby-images/24f45/24f456cd397d0d41864b3815a1f179f8f2882512" alt="在这里插入图片描述" 将第二个写入命令的进程号写入task文件中
data:image/s3,"s3://crabby-images/17bd8/17bd84897bd7dd367c366112d94452b09851ee63" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/80762/807621107fedb14dfd20f1d0f220cad85b93033d" alt="在这里插入图片描述"
cpu配额1024
cd /sys/fs/cgroup/cpu/x2/
echo 1024 > cpu.shares
cat cpu.share
data:image/s3,"s3://crabby-images/b1ecb/b1ecb0f00a52ef558407f1a5a57e9c53d0e4a031" alt="在这里插入图片描述"
echo 20000>cpu.cfs quota us
cat cpu.cfs_quota_us 配额
cat cpu.cfs_period_us 最大额度
top 查看两个dd命令的cpu占用额度
data:image/s3,"s3://crabby-images/ebe22/ebe224458d76d4972f1d2b2a036077d8c2909f1a" alt="在这里插入图片描述" 20000是100000的十分之一 所以两个dd进程共所占10% data:image/s3,"s3://crabby-images/547a5/547a599c2b0226471a306c9ba6461985ef8feada" alt="在这里插入图片描述"
三.Block IO
–device-write-bps限制写设备的bps
docker run -it --rm --device-write-bps /dev/vda:30MB rhel7 bash
bash-4.2# dd if=/dev/zero of=bigfile bs=1M count=200
200+0 records in
200+0 records out
209715200 bytes (210 MB) copied, 0.189837 s, 1.1 GB/s
bash-4.2# dd if=/dev/zero of=bigfile bs=1M count=200 oflag=direct
200+0 records in
200+0 records out
209715200 bytes (210 MB) copied, 6.82782 s, 30.7 MB/s
两个的再入速度不一样 data:image/s3,"s3://crabby-images/87af7/87af706426ce2e98b038f8b7b121bbc994e47a1b" alt="在这里插入图片描述"
四.docker安全加固
利用LXCFS增强docker容器隔离性和资源可见性 安装lxcf插件
yum install lxcfs-2.0.5-3.el7.centos.x86_64.rpm -y
data:image/s3,"s3://crabby-images/6e6ed/6e6ed7faa57f7b2fde1666c4d255c729fbce9de7" alt="在这里插入图片描述"
lxcfs /var/lib/lxcfs/ &
ps ax
data:image/s3,"s3://crabby-images/b5ac9/b5ac972e577d257ff0802f3f7ccbca8734b13237" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/7c855/7c8553e2863cfa2dacf8fd8effe69dfe72ff4d38" alt="在这里插入图片描述"
cd /var/lib/lxcfs/
ls
data:image/s3,"s3://crabby-images/1fdc2/1fdc2289ed9ba6025ec399d3e4984f0fa4a152ea" alt="在这里插入图片描述"
docker run -it -m 256m \
-v /var/lib/lxcfs/proc/cpuinfo:/proc/cpuinfo:rw \
-v /var/lib/lxcfs/proc/diskstats:/proc/diskstats:rw \
-v /var/lib/lxcfs/proc/meminfo:/proc/meminfo:rw \
-v /var/lib/lxcfs/proc/stat:/proc/stat:rw \
-v /var/lib/lxcfs/proc/swaps:/proc/swaps:rw \
-v /var/lib/lxcfs/proc/uptime:/proc/uptime:rw \
ubuntu
free -m
data:image/s3,"s3://crabby-images/e0565/e0565cf298b02a00a5e0215239425fccde528518" alt="在这里插入图片描述"
docker run -it --rm busyboxplus
ip addr
ip link set down eth0 会报没有权限
data:image/s3,"s3://crabby-images/3e3b8/3e3b81b062e77ff5f024f00cb60ae688503ea091" alt="在这里插入图片描述" 设置特权级运行的容器:–privileged=true 默认为false
docker run-it--rm--privileged busyboxplus 设置特权级运行的容器
ip link set down eth0
data:image/s3,"s3://crabby-images/a8fe0/a8fe07a35aa7d25b0deb0f2f37a701102eb4e919" alt="在这里插入图片描述" 设置容器白名单:–cap-add
docker run -it --rm --cap-add=NET_ADMIN busyboxplus 添加容器运行白明单
ip addr
ip addr add 172.25.0.100/24 dev eth0
ip addr del 172.25.0.100/24 dev eth0
data:image/s3,"s3://crabby-images/d46f0/d46f0192d28ec119afc64a8c43f16186edce5496" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/36740/367404e87b224628091feee8f7d526bd5481fb73" alt="在这里插入图片描述"
|