一、依赖的基础环境

 • 64位cpu
 • 内核3.10+
 • 内核组+命名空间

docker安装pgloader 并使用 docker19.03安装_docker

 

二、docker配置文件

  环境配置文件
    /etc/sysconfig/docker.network
    /etc/sysconfig/docker.storage
    /etc/sysconfig/docker  #可以配置私有镜像仓库域名
  Unit file
    /usr/lib/systemd/system/docker.service  #服务启动文件
  Docker Registry 配置文件
    /etc/registries.conf
  Docker-ce配置文件
    /etc/docker/daemon.json  #配置一个私有镜像仓库,就可以在/etc/sysconfig/docker文件里添加,也可以在/etc/docker/daemon.json文件里添加。特别的,这两个文件里的格式还不一样

 

感觉对于docker的配置文件有点搞不定,一会是/etc/sysconfig/docker,一会是/etc/docker/daemon.json,一会是/etc/systemd/system/docker.service.d目录下,更有甚者是/usr/lib/systemd/system/docker.service。

比如配置一个INSECURE-REGISTRY,就可以在/etc/sysconfig/docker文件里添加,也可以在/etc/docker/daemon.json文件里添加。特别的,这两个文件里的格式还不一样!!

这些配置文件到底是什么关系呢?是怎么被docker加载生效的呢?下文简单讲述他们之间的关系及docker的一些配置文件规划。

  • 拿到一台主机,用systemctl status docker查看docker的运行状态:

docker安装pgloader 并使用 docker19.03安装_配置文件_02

可以看到,加载的其实是/usr/lib/systemd/system/docker.service这个文件。

docker安装pgloader 并使用 docker19.03安装_docker_03

  • 个人认为docker也发现自己的配置文件太分散了,所以搞了一个/etc/docker/daemon.json,但是这个文件默认是不存在的,需要我们手动的去创建(不知道为什么不默认帮我们创建好,就算帮用户创建一个空的文件也行啊!)

 有了这个文件,我们一些常规的配置,都可以统一在这个文件里进行设置了,如下是/etc/docker/daemon.json的所有配置项:

[root@docker2 ~]# vim /etc/daemon.json
 {
 "api-cors-header":"", 
 "authorization-plugins":[],
 "bip": "",
 "bridge":"",
 "cgroup-parent":"",
 "cluster-store":"",
 "cluster-store-opts":{},
 "cluster-advertise":"",
  #  启用debug的模式,启用后,可以看到很多的启动信息。默认false
 "debug": true,                     
 "default-gateway":"",
 "default-gateway-v6":"",
 "default-runtime":"runc",
 "default-ulimits":{},
 "disable-legacy-registry":false,
 #  设定容器DNS的地址,在容器的 /etc/resolv.conf文件中可查看。
 "dns": ["192.168.1.1"],
 #  容器 /etc/resolv.conf 文件,其他设置             
 "dns-opts": [],   
 # 设定容器的搜索域,当设定搜索域为 .example.com 时,在搜索一个名为 host 的 主机时,    
 # DNS不仅搜索host,还会搜索host.example.com 。 注意:如果不设置, 
 # Docker 会默认用主机上的 /etc/resolv.conf 来配置容器。             
 "dns-search": [],                  
                                          

"exec-opts": [],
 "exec-root":"",
 "fixed-cidr":"",
 "fixed-cidr-v6":"",
 # 已废弃,使用data-root代替,这个主要看docker的版本
 "graph":"/var/lib/docker", 
 #  Docker运行时使用的根路径,根路径下的内容稍后介绍,默认/var/lib/docker        
 "data-root":"/var/lib/docker",   
 # Unix套接字的属组,仅指/var/run/docker.sock  
 "group": "",  
 # 设置容器hosts                     
 "hosts": [],                        
 "icc": false,
 # 配置docker的私库地址
 "insecure-registries": [],         
 "ip":"0.0.0.0",
 "iptables": false,
 "ipv6": false,
 # 默认true, 启用 net.ipv4.ip_forward ,进入容器后使用 sysctl -a | grepnet.ipv4.ip_forward 查看
 "ip-forward": false,               

 "ip-masq":false,
 # docker主机的标签,很实用的功能,例如定义:–label nodeName=host-121
 "labels":["nodeName=node-121"],     

 "live-restore": true,
 "log-driver":"",
 "log-level":"",
 "log-opts": {},
 "max-concurrent-downloads":3,
 "max-concurrent-uploads":5,
 "mtu": 0,
 "oom-score-adjust":-500,
 # Docker守护进程的PID文件
 "pidfile": "",                    
 "raw-logs": false,
 # 镜像加速的地址,增加后在 docker info中可查看。
 "registry-mirrors":["xxxx"],      
 "runtimes": {
 "runc": {
 "path": "runc"
 },
 "custom": {
 "path":"/usr/local/bin/my-runc-replacement",
 "runtimeArgs": [
 "--debug"
 ]
 }
 },
 # 默认 false,启用selinux支持
 "selinux-enabled": false,        

 "storage-driver":"",
 "storage-opts": [],
 "swarm-default-advertise-addr":"",
 "tls": true,                      # 默认 false, 启动TLS认证开关
 "tlscacert": "",                  # 默认 ~/.docker/ca.pem,通过CA认证过的的certificate文件路径
 "tlscert": "",                    # 默认 ~/.docker/cert.pem ,TLS的certificate文件路径
 "tlskey": "",                     # 默认~/.docker/key.pem,TLS的key文件路径
 "tlsverify": true,                # 默认false,使用TLS并做后台进程与客户端通讯的验证
 "userland-proxy":false,
 "userns-remap":""
 }

 

  • 所有的涉及到配置文件修改后,需要重启docker服务,让其加载生效。

# systemctl daemon-reload

# systemctl restart docker

  • daemon.json里的内容记不住怎么办?

# man dockerd