一 配置docker启动文件

1.1 docker 官方配置文件解释

1daemon.json文件可配置的参数表,我们在配置的过程中,只需要设置我们需要的参数即可,不必全部写出来。详细参考官网。
2下述是官网docs提供的一个示例配置,我们可以参考,选择性的配置其中的部分内容

[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":""
 }
1.2 如何配置 registry 私库相关的参数

涉及以下2个参数:
"insecure-registries": [], # 这个私库的服务地址
"registry-mirrors": [], # 私库加速器


# 示例
[root@docker2 ~]# vim /etc/docker/daemon.json
{
    "registry-mirrors": [
       "https://d8b3zdiw.mirror.aliyuncs.com"
    ],
 
    "insecure-registries": [
       "https://ower.site.com"
    ]

1.3简单配置
[root@docker2 ~]# vim /etc/docker/daemon.json 
  "exec-opts": ["native.cgroupdriver=systemd"],
  "registry-mirrors": ["https://hjvrgh7a.mirror.aliyuncs.com"],
  "log-driver": "json-file",
  "log-opts": {
    "max-size": "100m"
  },
  "storage-driver": "overlay2"
}