博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
新IT运维时代 | Docker运维之最佳实践-下篇
阅读量:6866 次
发布时间:2019-06-26

本文共 1945 字,大约阅读时间需要 6 分钟。

hot3.png

上篇针对操作系统、主机配置、容器镜像、容器运行时四大方面分享一些Docker的运维经验,本篇将着重在Docker Daemon参数和权限两个方面进一步分享。(阅读上篇请点击右侧:)

 

Docker Daemon为Docker的守护进程,大致可以分为Docker Server、Engine和Job三部分。Docker Daemon可以认为是通过Docker Server模块接受Docker Client的请求,并在Engine中处理请求,然后根据请求类型,创建出指定的Job并运行。

 

以下为Docker Daemon的架构示意图:

Docker Daemon参数

 

从上图不难看出Docker Daemon的核心地位,所以它的配置也尤为重要,下文会从安全、性能方面入手,下面具体讲讲该怎么配置Docker Daemon参数:

 

  • 限制容器之间网络通信:在同一台主机上若不限制容器之间通信,容器之间就会暴露些隐私的信息,所以推荐关闭,设置参数如:docker daemon--icc=false;

  • 日志级别设置为info:这样除了debug信息外,可以捕获所有的信息,设置参数如:  docker daemon --log-level="info";

  • 允许Docker Daemon修改iptables:这样可以自动避开错误的网络配置导致的容器和外部的访问问题,设置参数如:docker daemon--iptables=true;

  • 使用安全模式访问镜像仓库:Docker Daemon支持安全模式(默认)和非安全模式(--insecure-registry)访问镜像仓库,推荐镜像仓库配置CA证书,Docker Daemon配置安全访问模式,采用TLS安全传输协议;

  • 推荐使用Overlayfs作为Docker的存储驱动:Docker支持很多种储存驱动,CentOS默认的Docker存储驱动为devicemapper,Ubuntu默认的Docker存储驱动为aufs,那Docker储存驱动该怎么选择呢,可以参考下图的对比分析:

 

  • 推荐为Docker Daemon配置TLS认证:推荐指定Docker Daemon的监听IP、端口及unix socket,并配置TLS认证,通过Docker Daemon的IP+端口访问,设置参数如:'--tlsverify' 、'--tlscacert' 、'--tlscert'、'--tlskey' ;

  • 推荐为Docker Daemon开启用户空间支持:Docker Daemon支持Linux内核的user namespace,为Docker宿主机提供了额外的安全,容器使用有root权限的用户,则这个用户亦拥有其宿主机的root权限,外部可以通过容器反向来操控宿主机,设置参数如:docker daemon --userns-remap=default;

  • 推荐为Docker Daemon配置默认的CGroup:某个程序可能会出现占用主机上所有的资源,导致其他程序无法正常运行,或者造成系统假死无法维护,这时候用 cgroups 就可以很好地控制进程的资源占用,设置参数如:docker daemon--cgroup-parent=/foobar;

  • 推荐为Docker配置集中的远程日志收集系统:Docker支持很多种日志驱动,配置集中的远程日志系统用来存储Docker日志是非常有必要的,设置参数如:docker run--log-driver=syslog --log-opt syslog-address=tcp://ip;

  • 推荐使用Docker Registry v2版本:v2版本在性能与安全性方面比v1都增强了很多,如安全性上的镜像签名,可设置参数如:docker daemon--disable-legacy-registry;

 

Docker Daemon权限

 

Docker Daemon相关文件和目录的属性及其权限关系到整个Docker运行时的安全,从运维角度来看,合理的规划好属性及其权限尤为重要,下面具体讲讲该怎么配置Docker Daemon权限。

 

1、设置Docker Daemon一些相关配置文件的属性及其权限

2、设置Docker Daemon一些相关目录的属性及其权限

/etc/docker目录保存的是容器认证及key信息, 设置目录的属性为root:root,权限为755;

/etc/docker/certs.d/目录保存的是registry证书相关的文件,设置目录的属性为root:root,权限为444。

 

本文来源:

转载于:https://my.oschina.net/cloudsoar/blog/876130

你可能感兴趣的文章
C#中生成的随机数为什么不随机?
查看>>
Linux I2C(一)之常用的几种实例化(i2c_client ) 【转】
查看>>
windows下一个,OracleServiceXXX和Oracle 关系实例
查看>>
Eclipse上传代码到GitHub
查看>>
字符串中最长不重合子串长度
查看>>
POSIX 可移植操作系统接口
查看>>
jquery+Datatables出现数据过长,表格不自动换行,columns设置width失效的办法
查看>>
MSP430学习笔记9-PS2键盘解码
查看>>
(原创)攻击方式学习之(4) - 拒绝服务(DOS/DDOS/DRDOS)
查看>>
Ubuntu修改mysql的编码集
查看>>
用原始方法解析复杂字符串,json一定要用JsonMapper么?
查看>>
数据库与数据仓库的区别(转载)
查看>>
Java关键字final、static使用总结<转>
查看>>
Excel VBA 宏,使用某模版新建文档时,某些cell自动填充
查看>>
Python天天美味(17) - open读写文件
查看>>
Web应用安全之Response Header里的敏感信息
查看>>
[51单片机] 四相五线减速比为1/64步进电机驱动设计
查看>>
使用HttpHanlder处理404: File not found
查看>>
矩形旋转一定角度后,四个点的新坐标
查看>>
NODE-WEBKIT教程(5)NATIVE UI API 之FRAMELESS WINDOW
查看>>