Docker&Kubernetes ❀ Docker的在线安装、离线安装、配置镜像加速、配置文件参数详解

Docker&Kubernetes ❀ Docker的在线安装、离线安装、配置镜像加速、配置文件参数详解,第1张

Docker&Kubernetes ❀ Docker的在线安装、离线安装、配置镜像加速、配置文件参数详解

文章目录

1、Docker容器技术简述2、CentOS 6安装Docker3、CentOS 7/8安装Docker

3.1 卸载旧版本Docker与其依赖关系3.2 安装Docker服务

3.2.1 安装最新版本Docker引擎和容器3.2.2 安装特定版本的Docker引擎和容器3.2.3 查看Docker版本信息3.2.4 验证Dokcer是否成功安装 4、升级Docker5、配置Docker镜像加速6、Docker配置文件7、离线安装Docker服务

1、Docker容器技术简述

是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可以移植的镜像中,然后发布到任意系统中,实现虚拟化;常用技术为 Docker;
一个完整的Docker由四个部分组成:

Client客户端Daemon守护进程Image镜像Container容器

Docker有着比虚拟机更少的抽象层,由于Docker不需要Hypervisor实现硬件资源虚拟化,运行在Docker容器上的程序直接使用宿主机的硬件资源,因此在资源的占用上Docker有明显的优势;

Docker利用的是宿主机的内核,不需要虚拟机系统,因此当创建一个容器时,Docker不需要和虚拟机一样重新加载一个 *** 作系统内核,因此创建一个Docker容器的 *** 作是秒级;

Docker部署前准备 *** 作,宿主机需要访问网络,从网络中下载对应的Docker包(也可以通过本地Yum源安装,此处不做赘述);

[root@localhost ~]# yum clean all			#清理Yum仓库
[root@localhost ~]# yum makecache 		    #建立Yum缓存,将服务器包信息下载到本地
[root@localhost ~]# yum update -y			#更新Yum仓库(更新时间较长)
2、CentOS 6安装Docker

此处不再赘述Yum源的配置与使用,参考以上内容;

[root@localhost ~]# yum install -y epel-release		    #安装依赖
[root@localhost ~]# yum install -y docker-io			#安装Docker
[root@localhost ~]# cat /etc/sysconfig/docker			#查看配置文件
~
other_args=								                #填写阿里云镜像加速链接;
~
[root@localhost ~]# service docker start				#重启服务
[root@localhost ~]# docker version					    #查看版本信息
3、CentOS 7/8安装Docker

此处不再赘述Yum源的配置与使用,参考以上内容;

3.1 卸载旧版本Docker与其依赖关系

如果没有安装过Docker则无需卸载就版本与其依赖包

[root@localhost ~]# sudo yum remove docker 
                  docker-client 
                  docker-client-latest 
                  docker-common 
                  docker-latest 
                  docker-latest-logrotate 
                  docker-logrotate 
                  docker-engine
3.2 安装Docker服务

设置Docker仓库

[root@localhost ~]# sudo yum install yum-utils -y

设置稳定Docker仓库

[root@localhost ~]# sudo yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo	                    #官方源仓库
Adding repo from: https://download.docker.com/linux/centos/docker-ce.repo
#部分仓库内容默认被禁用,可以使用下面的命令进行启用,如果不需要可以忽略此步骤
[root@localhost ~]# sudo yum-config-manager --enable docker-ce-nightly		#开启夜间存储库
[root@localhost ~]# sudo yum-config-manager --enable docker-ce-test			#开启测试通道
[root@localhost ~]# sudo yum-config-manager --disable docker-ce-nightly		#关闭夜间存储库
3.2.1 安装最新版本Docker引擎和容器
[root@localhost ~]# sudo yum install -y docker-ce docker-ce-cli containerd.io
3.2.2 安装特定版本的Docker引擎和容器

列出并排序可用的Docker版本,返回的列表取决于启用了哪些存储库,并且特定于系统版本;

[root@localhost ~]# yum list docker-ce --showduplicates | sort -r
Last metadata expiration check: 0:00:45 ago on Wed 03 Mar 2021 01:02:22 AM PST.
Installed Packages
docker-ce.x86_64               3:20.10.5-3.el8                 docker-ce-stable 
docker-ce.x86_64               3:20.10.5-3.el8                 @docker-ce-stable
docker-ce.x86_64               3:20.10.4-3.el8                 docker-ce-stable 
docker-ce.x86_64               3:20.10.3-3.el8                 docker-ce-stable 
docker-ce.x86_64               3:20.10.2-3.el8                 docker-ce-stable 
docker-ce.x86_64               3:20.10.1-3.el8                 docker-ce-stable 
docker-ce.x86_64               3:20.10.0-3.el8                 docker-ce-stable 
docker-ce.x86_64               3:19.03.15-3.el8                docker-ce-stable 
docker-ce.x86_64               3:19.03.14-3.el8                docker-ce-stable 
docker-ce.x86_64               3:19.03.13-3.el8                docker-ce-stable 
Available Packages

通过完全合格的包名安装一个特定的版本

[root@localhost ~]# sudo yum install docker-ce- docker-ce-cli- containerd.io
[root@localhost ~]# sudo yum install docker-ce-20.10.2 docker-ce-cli-20.10.2 containerd.io

启动Docker

[root@localhost ~]# sudo start dockersystemctl 
3.2.3 查看Docker版本信息
[root@localhost ~]# docker version
Client: Docker Engine - Community
 Version:           20.10.5
 API version:       1.41
 Go version:        go1.13.15
 Git commit:        55c4c88
 Built:             Tue Mar  2 20:17:04 2021
 OS/Arch:           linux/amd64
 Context:           default
 Experimental:      true

Server: Docker Engine - Community
 Engine:
  Version:          20.10.5
  API version:      1.41 (minimum version 1.12)
  Go version:       go1.13.15
  Git commit:       363e9a8
  Built:            Tue Mar  2 20:15:27 2021
  OS/Arch:          linux/amd64
  Experimental:     false
 containerd:
  Version:          1.4.3
  GitCommit:        269548fa27e0089a8b8278fc4fc781d7f65a939b
 runc:
  Version:          1.0.0-rc92
  GitCommit:        ff819c7e9184c13b7c2607fe6c30ae19403a7aff
 docker-init:
  Version:          0.19.0
  GitCommit:        de40ad0
3.2.4 验证Dokcer是否成功安装
[root@localhost ~]# docker run hello-world
Unable to find image 'hello-world:latest' locally
latest: Pulling from library/hello-world
2db29710123e: Pull complete 
Digest: sha256:cc15c5b292d8525effc0f89cb299f1804f3a725c8d05e158653a563f15e4f685
Status: Downloaded newer image for hello-world:latest

Hello from Docker!
This message shows that your installation appears to be working correctly.

To generate this message, Docker took the following steps:
 1. The Docker client contacted the Docker daemon.
 2. The Docker daemon pulled the "hello-world" image from the Docker Hub.
    (amd64)
 3. The Docker daemon created a new container from that image which runs the
    executable that produces the output you are currently reading.
 4. The Docker daemon streamed that output to the Docker client, which sent it
    to your terminal.

To try something more ambitious, you can run an Ubuntu container with:
 $ docker run -it ubuntu bash

Share images, automate workflows, and more with a free Docker ID:
 https://hub.docker.com/

For more examples and ideas, visit:
 https://docs.docker.com/get-started/


 [root@localhost ~]# docker ps -a
ConTAINER ID   IMAGE         COMMAND    CREATED          STATUS                      PORTS     NAMES
528787d4228a   hello-world   "/hello"   11 seconds ago   Exited (0) 11 seconds ago             dreamy_margulis
4、升级Docker

安装最新版本即可完成升级

5、配置Docker镜像加速

默认Docker仓库使用国外的服务器,鉴于后续下载内容的网速,推荐使用国内的源进行下载,此处更新为阿里云的镜像加速,每一个镜像加速都是不同的,需要自行去阿里云镜像服务官网获取,URL链接如下:
https://cr.console.aliyun.com/cn-qingdao/instances/mirrors

镜像加速配置方式

[root@localhost ~]# mkdir -pv /etc/docker/
[root@localhost ~]# vim /etc/docker/daemon.json 
{
	  "registry-mirrors": ["https://sta7qavr.mirror.aliyuncs.com"]
}
[root@localhost ~]# systemctl daemon-reload			#后台程序重新加载;
[root@localhost ~]# systemctl restart docker

#检测是否成功配置镜像加速

[root@localhost ~]# docker info | grep aliyun
  https://sta7qavr.mirror.aliyuncs.com/

图示如下:

6、Docker配置文件

Docker安装后默认没有daemon.json这个配置文件,需要进行手动创建。配置文件的默认路径:/etc/docker/daemon.json;如果在daemon.json文件中进行配置,需要docker版本高于1.12.6(在这个版本上不生效,1.13.1以上是生效的)

[root@Redhat8 ~]# mkdir /etc/docker/ -pv
[root@localhost ~]# vim /etc/docker/daemon.json
{
 "api-cors-header":"", 
 "authorization-plugins":[],
 "bip": "x.x.x.x/x",                  #设置docker0网卡网段,即容器部署完成后使用的IP地址范围
 "bridge":"",                         #定义桥接网卡,默认为docker0
 "cgroup-parent":"",
 "cluster-store":"",
 "cluster-store-opts":{},
 "cluster-advertise":"",
 "debug": true,                      #启用debug的模式,启用后,可以看到很多的启动信息。默认false
 "default-gateway":"",               #修改容器IPv4网关
 "default-gateway-v6":"",            #修改容器IPv6网关
 "default-runtime":"runc",
 "default-ulimits":{},
 "disable-legacy-registry":false,
 "dns": ["",""],                     #设定容器DNS的地址,在容器的 /etc/resolv.conf文件中可查看。
 "dns-opts": [],                     #容器 /etc/resolv.conf 文件,其他设置
 "dns-search": [],                   #设定容器的搜索域,当设定搜索域为 .example.com 时,在搜索一个名为 host 的 主机时,DNS不仅搜索host,还会搜索host.example.com 。 注意:如果不设置, Docker 会默认用主机上的 /etc/resolv.conf 来配置容器。

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

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

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

 "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":""
 }

修改案例:修改docker0下发容器使用网段与网关,并配置对应DNS;

[root@localhost ~]# cat /etc/docker/daemon.json 
{
	"insecure-registries": ["10.81.20.166"],
	"registry-mirrors": ["https://sta7qavr.mirror.aliyuncs.com"],
	"bip": "10.1.1.0/16",
	"default-gateway": "10.1.1.1",
	"dns": ["8.8.8.8"]
}
[root@Redhat8 ~]# ifconfig docker0 | awk 'NR==2{print()}'
10.1.1.0
[root@cb4f1de96a62 /]# ip a s eth0 | awk 'NR==3{print()}'
10.1.0.1/16
[root@cb4f1de96a62 /]# cat /etc/resolv.conf 
nameserver 8.8.8.8
[root@cb4f1de96a62 /]# exit
exit
7、离线安装Docker服务

很多情况下,内网服务器无法访问外网获取对应的服务安装包,因为Docker官网设计了离线安装方式,下面就做一个简单的介绍,离线安装包的获取地址如下(版本较多,自行下载所需版本):
https://download.docker.com/linux/static/stable/x86_64/docker-19.03.9.tgz

下载完成后,将离线包导入至Linux后台进行解压,命令如下:

[root@Redhat8 ~]# tar zxvf docker-19.03.9.tgz

将上述解压后文件(docker文件夹)全部移动至/usr/bin目录下(必须执行):

[root@Redhat8 ~]# cp -p docker/* /usr/bin/

将docker注册为service,命令如下:

[root@Redhat8 ~]# vim /usr/lib/systemd/system/docker.service
# 将下面文件内容直接负责到新创建的文件内即可
[Unit]
Description=Docker Application Container Engine
documentation=http://docs.docker.com
After=network.target docker.socket

[Service]
Type=notify
EnvironmentFile=-/run/flannel/docker
WorkingDirectory=/usr/local/bin
ExecStart=/usr/bin/dockerd 
                -H tcp://0.0.0.0:4243 
                -H unix:///var/run/docker.sock 
                --selinux-enabled=false 
                --log-opt max-size=1g
ExecReload=/bin/kill -s HUP $MAINPID
# Having non-zero Limit*s causes performance problems due to accounting overhead
# in the kernel. We recommend using cgroups to do container-local accounting.
LimitNOFILE=infinity
LimitNPROC=infinity
LimitCORE=infinity
# Uncomment TasksMax if your systemd version supports it.
# only systemd 226 and above support this version.
#TasksMax=infinity
TimeoutStartSec=0
# set delegate yes so that systemd does not reset the cgroups of docker containers
Delegate=yes
# kill only the docker process, not all processes in the cgroup
KillMode=process
Restart=on-failure

[Install]
WantedBy=multi-user.target

配置完成后重新加载Docker的配置文件,命令如下:

[root@Redhat8 ~]# systemctl daemon-reload

启动Docker服务

[root@Redhat8 ~]# systemctl start docker

设置Docker服务开机启动

[root@Redhat8 ~]# systemctl enable docker

查看Docker服务是否安装成功

[root@Redhat8 ~]# docker version

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5720309.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-18
下一篇 2022-12-17

发表评论

登录后才能评论

评论列表(0条)

保存