Docker(十):Docker安全
1、Docker安全主要体现在如下方面
a)Docker容器的安全性
b)镜像安全性
c)Docker daemon安全性
2、安装策略
2.1 Cgroup
Cgroup用于限制容器对CPU、内存的使用。
设置容器CPU权重为100,默认为1024
docker run --rm -ti -c 100 ubuntu bash
限制容器对CPU资源的使用上限
docker run --rm -ti --cpu-period=500000 --cpu-quota=250000 ubuntu /bin/bash
表示这个容器每0.5秒最多运行0.25秒
绑定CPU运行
docker run --rm -ti --cpuset-cpus=0,1 ubuntu bash
2.2 限制内存
docker run --rm -ti -m 200M ubuntu bash
限制容器内存为200M
注意:当内存达到峰值时会使用swap分区,可通过--memory-swap限制swap分区的使用量
2.3 限制块设备I/O
测试当前写入速率
root@e977b6cb88d7:/# dd if=/dev/zero of=testfile0 bs=8k count=5000 oflag=direct
5000+0 records in
5000+0 records out
40960000 bytes (41 MB, 39 MiB) copied, 0.313395 s, 131 MB/s
在容器上查看挂载详情
root@e977b6cb88d7:/# mount | grep e977b6cb88d7
/dev/mapper/docker-253:0-2394716-e977b6cb88d7ea106beb80851728a05e26b3458cb2b05514f20d870892989171 on / type ext4 (rw,relatime,barrier=1,stripe=16,data=ordered)
在宿主机查看设备号
[root@MediaServer ~]# mount | grep e977b6cb88d7
[root@MediaServer ~]# ll /dev/mapper/docker-253\:0-2394716-e977b6cb88d7ea106beb80851728a05e26b3458cb2b05514f20d870892989171
lrwxrwxrwx 1 root root 7 10月 12 21:07 /dev/mapper/docker-253:0-2394716-e977b6cb88d7ea106beb80851728a05e26b3458cb2b05514f20d870892989171 -> ../dm-4
[root@MediaServer ~]# ll /dev/dm-4
brw-rw---- 1 root disk 253, 4 10月 12 21:07 /dev/dm-4 #253,4为设备号
限制写入速度为每秒5120000字节
echo "253:4 5120000" > /cgroup/blkio/docker/e977b6cb88d7ea106beb80851728a05e26b3458cb2b05514f20d870892989171/blkio.throttle.write_bps_device
再次测试容器写入速率
root@e977b6cb88d7:/# dd if=/dev/zero of=testfile0 bs=8k count=5000 oflag=direct
5000+0 records in
5000+0 records out
40960000 bytes (41 MB, 39 MiB) copied, 9.37702 s, 4.4 MB/s
2.4 ulimit限制
全局默认设置:
docker daemon --default-ulimit cpu=1200
单独设置:
docker run --rm -ti --ulimit cpu=1200 ubuntu bash
root@6667c7f607f8:/# ulimit -t
1200
2.6 容器+虚拟化
将容器部署在虚拟机中
2.7 日志审计
Docker daemon支持log-driver参数,目前支持的类型有:none、json-file、syslog、gelf、fluentd,默认的驱动是json-file。
除了Docker daemon指定日志驱动外,还可以对单个容器指定驱动,
#docker run --rm -ti --log-driver="syslog" ubuntu bash
然后通过docker inspect可以查看容器使用的日志驱动
#docker inspect 容器ID | grep Type
"Type": "syslog",
注意:只有json-file日志驱动才支持docker logs
2.8 监控
root@HX-StrMedia:~# docker stats container1
CONTAINER CPU % MEM USAGE / LIMIT MEM % NET I/O BLOCK I/O
container1 0.00% 5.005 MB / 33.73 GB 0.01% 1.296 kB / 648 B 7.766 MB / 0 B
CONTAINER CPU % MEM USAGE / LIMIT MEM % NET I/O BLOCK I/O
container1 0.00% 5.005 MB / 33.73 GB 0.01% 1.296 kB / 648 B 7.766 MB / 0 B
CONTAINER CPU % MEM USAGE / LIMIT MEM % NET I/O BLOCK I/O
container1 0.00% 5.005 MB / 33.73 GB 0.01% 1.296 kB / 648 B 7.766 MB / 0 B
2.9 文件系统级别防护
docker run --rm -ti --read-only --name=container1 centos bash
[root@fd582b88f6fb /]# echo "Test" > Test
bash: Test: Read-only file system
2.10 Capability
root@HX-StrMedia:~# docker run --rm -ti --cap-drop=chown centos bash
[root@6a6dc05cbced /]# chmod 777 /etc/hosts
[root@6a6dc05cbced /]# chown 2:2 /etc/hosts
chown: changing ownership of '/etc/hosts': Operation not permitted
root@HX-StrMedia:~# docker run --rm -ti --cap-drop=all centos bash
Docker(十):Docker安全的更多相关文章
- Docker(十)-Docker创建DockerFile文件
制作Docker image 有两种方式: 使用 Docker container,直接构建容器,再导出成 image 使用. 是使用 Dockerfile,将所有动作写在文件中,再 build 成 ...
- SpringCloud(十) - Docker
1.Docker安装 1.1 卸载旧版本(否者会安装出错) sudo yum remove docker \ docker-client \ docker-client-latest \ docker ...
- Docker(十六)-Docker的daemon.json的作用
docker安装后默认没有daemon.json这个配置文件,需要进行手动创建.配置文件的默认路径:/etc/docker/daemon.json 一般情况,配置文件 daemon.json中配置的项 ...
- docker 系列 - Docker 安装和Hub Mirror地址设置
======================为什么要使用Docker?======================= 容器真是个好东西, (1)容器能提供隔离性; (2)容器能打包环境, 简化部署难度 ...
- 【Docker】Docker概述、理解docker的集装箱、标准化、隔离的思想、 docker出现解决了什么问题
整理一下 慕课网 第一个docker化的java应用 Docker环境下的前后端分离项目部署与运维 课程时所做的笔记 Docker概述 docker - https://www.docker.com/ ...
- [经验交流] docker in docker 的变通实现方法
最近在做CI持续集成环境的容器化,其中一个工作是:在容器中构建容器镜像. 对于这个需求,网上有一些 Docker in Docker 的方法,具体需要修改宿主机的配置.这种方式在单机环境下.对安全要求 ...
- 【Docker】docker /var/lib/docker/aufs/mnt 目录满了,全是垃圾数据,咋搞?
命令: #!/bin/bash # 推荐方式 docker volume ls -f dangling=true | awk '{ print $2 }' | xargs docker volume ...
- jenkins和docker 使用docker作为slave
使用docker作为jenkins slave. 文章来自:http://www.ciandcd.com文中的代码来自可以从github下载: https://github.com/ciandcd 参 ...
- .NET遇上Docker - 使用Docker Compose组织Ngnix和.NETCore运行
本文工具准备: Docker for Windows Visual Studio 2015 与 Visual Studio Tools for Docker 或 Visual Studio 2017 ...
- jenkins+docker 持续构建非docker in docker jenkins docker svn maven
工欲善其事必先利其器,为了解脱程序员的,我们程序员本身发明了很多好用的工具,通过各种工具的组合来达到我们想要的结果 本文采用jenkins docker svn maven作为相关工具,项目sprin ...
随机推荐
- 用TensorFlow实现文本分析模型,做个聊天机器人
用TensorFlow实现文本分析模型,做个聊天机器人 聊天机器人的架构简图用 TensorFlow 实现 Chatbot 的模型如何准备 chatbot 的训练数据Chatbot 源码解读 1. 聊 ...
- C语言之计算log2
#include<stdio.h>int main(){int num,count=0,i=0,ret=0;scanf("%d",&num);count=num ...
- 【MAVEN】maven系列--pom.xml标签详解
pom文件作为MAVEN中重要的配置文件,对于它的配置是相当重要.文件中包含了开发者需遵循的规则.缺陷管理系统.组织.licenses.项目信息.项目依赖性等.下面将重点介绍一下该文件的基本组成与功能 ...
- 制作支持 BIOS+UEFI 的 U 盘 grub2+bootmgr 引导 + deepin_recovery + deepin_iso + win_pe
网盘下载:https://pan.baidu.com/s/1c2GXPo0 U盘为 FAT32,MBR分区表 1.下载:U盘grub2+bootmgr引导2017.12.6.2.7z 2.解压到 U盘 ...
- spring框架的一些技术总结
纵观现在互联网行业,java的地位依然不可动摇,因为java拥有着的众多开发人员和适用性广,技术与解决技术大部分开源等特点,因此java依然是众多众多开发行业作为互联网开发的首选,而说到开发,我们就不 ...
- 51Nod1136--欧拉函数
1136 欧拉函数 基准时间限制:1 秒 空间限制:131072 KB 分值: 0 难度:基础题 收藏 关注 对正整数n,欧拉函数是少于或等于n的数中与n互质的数的数目.此函数以其首名研究者欧拉命 ...
- Linux多线程编程详细解析----条件变量 pthread_cond_t
Linux操作系统下的多线程编程详细解析----条件变量 1.初始化条件变量pthread_cond_init #include <pthread.h> int pthread_cond_ ...
- UWP Flyout浮动控件
看见没,点击"Options"按钮,浮动出来一个界面,这个界面可以用xaml自定义. 如果要点击的控件又Flyout属性那么,可以直接按照下面用 <Button Conten ...
- windows 终端命令详解
打开"运行"对话框(Win+R),输入cmd,打开控制台命令窗口... 也可以通过cmd /c 命令 和 cmd /k 命令的方式来直接运行命令 注:/c表示执行完命令后关闭cmd ...
- Activiti源代码分析
ExecutionEntity内部含有parent,是一个运行树或运行路径.应该是一个流程实例的运行过程,一个实例相应一个ExecutionEntity,通过getActivity得到的是当前正在运行 ...