Docker daemon 配置和故障排除过程

启动daemon

启动daemon命令取决与你使用的操作系统:

RHEL, Centos, Fedora, Ubuntu 16.04 或者更高版本,使用systemd管理docker服务启动。

  1. $ sudo systemctl enable docker

关闭自动启动

  1. $ sudo systemctl disable docker

手动启动daemon

  1. $ dockerd

我们可以执行以下命令把当前用户加入到docker组,避免每次docker命令都要sudo。

  1. $ sudo usermod aG docker username

Docker daemon配置

加速器:

针对Docker客户端版本大于1.10的用户,您可以通过修改daemon配置文件/etc/docker/daemon.json来使用加速器:

  1. sudo mkdir /etc/docker
  2. sudo tee /etc/docker/daemon.json <<-‘EOF’
  3. {
  4.      “registry-mirrors”: [“https://5162s31v.mirror.aliyuncs.com”]
  5. }
  6. EOF
  7. sudo systemctl daemonreload
  8. sudo systemctl restart docker

daemon包含很多配置选项,在手工启动daemon的时候可以通过flags配置daemon启动参数,或者通过daemon.json配置文件更改配置。

完整的daemon.json的启动参数如下:

  1. {
  2.      “api-cors-header”: “”,
  3.      “authorization-plugins”: [],
  4.      “bip”: “”,
  5.      “bridge”: “”,
  6.      “cgroup-parent”: “”,
  7.      “cluster-store”: “”,
  8.      “cluster-store-opts”: {},
  9.      “cluster-advertise”: “”,
  10.      “debug”: true,
  11.      “default-gateway”: “”,
  12.      “default-gateway-v6”: “”,
  13.      “default-runtime”: “runc”,
  14.      “default-ulimits”: {},
  15.      “disable-legacy-registry”: false,
  16.      “dns”: [],
  17.      “dns-opts”: [],
  18.      “dns-search”: [],
  19.      “exec-opts”: [],
  20.      “exec-root”: “”,
  21.      “fixed-cidr”: “”,
  22.      “fixed-cidr-v6”: “”,
  23.      “graph”: “”,
  24.      “group”: “”,
  25.      “hosts”: [],
  26.      “icc”: false,
  27.      “insecure-registries”: [],
  28.      “ip”: “0.0.0.0”,
  29.      “iptables”: false,
  30.      “ipv6”: false,
  31.      “ip-forward”: false,
  32.      “ip-masq”: false,
  33.      “labels”: [],
  34.      “live-restore”: true,
  35.      “log-driver”: “”,
  36.      “log-level”: “”,
  37.      “log-opts”: {},
  38.      “max-concurrent-downloads”: 3,
  39.      “max-concurrent-uploads”: 5,
  40.      “mtu”: 0,
  41.      “oom-score-adjust”: 500,
  42.      “pidfile”: “”,
  43.      “raw-logs”: false,
  44.      “registry-mirrors”: [],
  45.      “runtimes”: {
  46.          “runc”: {
  47.              “path”: “runc”
  48.          },
  49.          “custom”: {
  50.              “path”: “/usr/local/bin/my-runc-replacement”,
  51.              “runtimeArgs”: [
  52.                  “–debug”
  53.              ]
  54.          }
  55.      },
  56.      “selinux-enabled”: false,
  57.      “storage-driver”: “”,
  58.      “storage-opts”: [],
  59.      “swarm-default-advertise-addr”: “”,
  60.      “tls”: true,
  61.      “tlscacert”: “”,
  62.      “tlscert”: “”,
  63.      “tlskey”: “”,
  64.      “tlsverify”: true,
  65.      “userland-proxy”: false,
  66.      “userns-remap”: “”
  67. }

更好的方法是把这些启动参数写道配置文件中:daemon.json

读取日志

docker日志的保存路径取决于操作系统的类型或者日志子系统,详见下表:

-1

启动调试

两种方式打开调试模式

推荐方式是修改daemon.json文件,debug设置为true,这种方式适用于任何平台:

daemon.json一般保存在:/etc/docker/目录下,如果不存在你可以创建该文件,如该文件为空,增加下面的内容:

  1. {
  2.      “debug”: true
  3. }

发送HUP信号给daemon,使其重新加载配置文件,linux系统命令如下:

  1. $ sudo kill SIGHUP $(pidof dockerd)

另一种方式是启动docker时,增加-D标签

强制日志输出

如该daemon长时间没反应或者反映较慢,可应通过命令发送信号强制日志追踪,具体命令如下:

linux:

  1. $ sudo kill SIGUSR1 $(pidof dockerd)

Windows:

  1. Download dockersignal.
  2. Run the executable with the flag pid=<PID of daemon>

这会强制追踪日志,而不会停止daemon的运行。

检查docker是否运行

  • 使用:docker info 命令
  • 使用系统命令:sudo systemctl is-active docker
  • 使用系统命令:sudo status docker
  • 使用系统命令:sudo service docker status
  • 使用:ps 或者 top查看dockerd进程是否运行

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

标签

发表评论