Skip to content

搭建 Docker 环境

概述

  记录一下在 CentOS7 环境下的 Docker 搭建过程。注意,在开始搭建 Docker 环境前,可以参考另一篇笔记[链接]来完成 CentOS7 的初始化、更新工作。

搭建步骤

配置基础环境

bash
# 由于 firewalld 防火墙与 docker 服务有冲突,因此卸载 firewalld
# 可以使用 iptables 来代替 firewalld
$ systemctl stop firewalld && systemctl disable firewalld && yum remove -y firewalld

# 安装 iptables
$ yum install -y iptables iptables-services

# 启用 iptables
$ systemctl start iptables && systemctl enable iptables

# 清空 iptables 配置
$ iptables -F && service iptables save

# 重启 iptables
$ systemctl restart iptables

# 永久禁用 SELinux
$ setenforce 0 && sed -i 's/^SELINUX=.*/SELINUX=disabled/' /etc/selinux/config

# 禁用交换分区,并写入挂载表
$ swapoff -a && sed -i '/swap/s/^/#/' /etc/fstab

# 重启生效
$ reboot

安装 Docker

bash
# 添加 Docker 源
$ yum install -y yum-utils
$ yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo

# 安装 Docker
$ yum install -y docker-ce

# 启动 Docker 服务,并添加开机自启
$ systemctl start docker && systemctl enable docker

# 安装 Docker Compose
$ curl -L "https://github.com/docker/compose/releases/download/2.16.0/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose

# 为 docker-compose 添加可执行权限
$ chmod +x /usr/local/bin/docker-compose

# 输出 docker 版本号
$ docker --version
Docker version 23.0.1, build cb74dfc

# 输出 docker-compose 版本号
$ docker-compose --version
Docker Compose version v2.16.0

使用技巧

导出/导入 Docker 镜像

  在一些生产环境,服务器是无法访问外部 Docker Registry 服务的,因此需要在本地将相关镜像下载下来,然后导出到生产环境去使用。在这种场影下,可以通过以下方法完成镜像的导出与导入。

bash
# 将 Dokcer 镜像保存为 tar 文件
# 注意,这里要用镜像名称来导出,不要用镜像的 hash 来导出
$ docker save sonatype/nexus3:3.47.1 -o nexus3-3.47.1.tar

# 将导出来的镜像文件复制到指定的服务器,用以下命令即可导入镜像
$ docker load -i nexus3-3.47.1.tar

# 查看是否导入成功
$ docker images
REPOSITORY        TAG       IMAGE ID       CREATED        SIZE
sonatype/nexus3   3.47.1    d2fd210c6f4c   3 months ago   545MB

访问 Dokcer 私库

  我们搭建 Docker Registry 私库之后,如果你没有办法为其配置 HTTPS 访问,那么就需要配置 Docker,使其允许以不安全的方式(以 http 的方式)访问 Registry 私库。

bash
# 查看当前 Docker 信息
$ docker info
...
 Insecure Registries:
  127.0.0.0/8
 Live Restore Enabled: false

# 创建 Docker 配置文件,添加 insecure-registries 选项
# 注意,如果 insecure-registries 只添加域名,在正常情况下是能正常使用私库的
# 但是发现有时在编译镜像时,Docker 还是以 https 去访问私库
# 此时可以在 insecure-registries 再加上 http://<domain> 选项即可
$ vi /etc/docker/daemon.json

{
    "insecure-registries": [
        "mirror.cluster.k8s",
        "http://mirror.cluster.k8s"
    ]
}

# 重启 Docker 服务
$ systemctl daemon-reload
$ systemctl restart docker

# 再次查看 Docker 信息,发现 Insecure Registries 已经添加上去了
$ docker info
...
 Insecure Registries:
  registry.cluster.k8s
  mirror.cluster.k8s
  127.0.0.0/8
 Live Restore Enabled: false

添加 Docker 镜像加速服务

  在没有网络的环境,或者我们需要做镜像加速时,可以通过修改 Docker 的配置文件,使其优先从镜像加速服务中拉取镜像。

bash
# 查看当前 Docker 信息
$ docker info
...
 Insecure Registries:
  127.0.0.0/8
 Live Restore Enabled: false

# 创建 Docker 配置文件,添加 registry-mirrors 选项
# 如果你的镜像加速服务是以 http 协议提供的,那么还需要添加 insecure-registries 选项
$ vi /etc/docker/daemon.json

{
    "insecure-registries": [
        "mirror.cluster.k8s"
    ],
    "registry-mirrors": [
        "http://mirror.cluster.k8s"
    ]
}

# 重启 Docker 服务
$ systemctl daemon-reload
$ systemctl restart docker

# 再次查看 Docker 信息,发现 Registry Mirrors 已经添加上去了
$ docker info
...
 Insecure Registries:
  mirror.cluster.k8s
  127.0.0.0/8
 Registry Mirrors:
  http://mirror.cluster.k8s/
 Live Restore Enabled: false

设置网络代理

  Docker 进程是由 systemd 启动的,因此我们可以通过修改 systemd 的配置文件来设置代理。

bash
$ nano /lib/systemd/system/docker.service

# 一些 Linux 发行版可能存放在这里
$ nano /etc/systemd/system/docker.service

  在 [Service] 节中添加以下内容:

ini
[Service]
Environment="HTTP_PROXY=http://<server>:<port>/"
Environment="HTTPS_PROXY=http://<server>:<port>/"
Environment="ALL_PROXY=socks5://<server>:<port>/"
Environment="NO_PROXY=localhost,127.0.0.1"

  完成配置后,重启 Docker 进程以生效。

bash
$ systemctl daemon-reload
$ systemctl restart docker

优化日志存储

  Docker 默认将容器运行时产生的日志保存在 /var/lib/docker/<container>/<container>-json.log 文件,并且默认不滚动。也就是说,在容器未销毁前,这个容器产生的日志会一直保存在这个文件下。长期运行时,这个日志文件就会越滚越大,最终将磁盘占满。

  为了解决这个问题,可以修改 Docker 的配置文件来优化日志的存储方式。

bash
# 修改配置文件,添加日志选项
# 单个文件最大 10m,保留最近 10 个文件
# 这样就可以限制单个容器的日志最多占用磁盘 100m 空间了
$ vi /etc/docker/daemon.json

{
    "log-driver": "json-file",
    "log-opts": {
        "max-size": "10m",
        "max-file": "10"
    }
}

# 重启 Docker 以生效
$ systemctl restart docker

  查看以下文档,获取更多关于日志的配置选项:

提示

  虽然通过 systemctl restart docker 使配置生效了,但是新配置对已创建的容器是不生效的,因此需要重新创建这些容器。


Released under the MIT license.