Docker - 离线安装 docker 、docker-compose
Docker - 离线安装 docker 、docker-compose
环境:centos8 , docker25
一. 安装 Docker
1. 安装包官方地址:https://download.docker.com/linux/static/stable/x86_64/
2.解压
代码如下(示例):
tar -zxvf docker-18.06.3-ce.tgz
3.将解压出来的docker文件复制到 /usr/bin/ 目录下
注:不可修改目录,其中runc文件如已存在可不复制,或提前备份好再复盖。
代码如下(示例):
cp docker/* /usr/bin/
4.创建 docker.service文件
进入/etc/systemd/system/目录,并创建docker.service文件,内容如下,这样可以将docker注册为service服务
代码如下(示例):
[Unit] Description=Docker Application Container Engine Documentation=https://docs.docker.com After=network-online.target firewalld.service Wants=network-online.target [Service] Type=notify # the default is not to use systemd for cgroups because the delegate issues still # exists and systemd currently does not support the cgroup feature set required # for containers run by docker ExecStart=/usr/bin/dockerd --selinux-enabled=false --insecure-registry=127.0.0.1 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 the docker process if it exits prematurely Restart=on-failure StartLimitBurst=3 StartLimitInterval=60s [Install] WantedBy=multi-user.target
此处的–insecure-registry=127.0.0.1(此处改成你私服ip)设置是针对有搭建了自己私服Harbor时允许docker进行不安全的访问,否则访问将会被拒绝。
5.启动docker
给docker.service文件添加执行权限
chmod +x /etc/systemd/system/docker.service
重新加载配置文件(每次有修改docker.service文件时都要重新加载下)
systemctl daemon-reload
启动
systemctl start docker
设置开机启动
systemctl enable docker.service
查看docker服务状态
systemctl status docker
[root@localhost system]# systemctl status docker ● docker.service - Docker Application Container Engine Loaded: loaded (/etc/systemd/system/docker.service; enabled; vendor preset: disabled) Active: active (running) since Tue 2022-06-28 00:54:47 PDT; 10s ago Docs: https://docs.docker.com Main PID: 45475 (dockerd) CGroup: /system.slice/docker.service ├─45475 /usr/bin/dockerd --selinux-enabled=false --insecure-registry=10.1.20.150 └─45487 containerd --config /var/run/docker/containerd/containerd.toml --log-level info Jun 28 00:54:46 localhost.localdomain dockerd[45475]: time="2022-06-28T00:54:46.158519178-07:00" level=info msg="ccResolverWrapper: sending update to cc: {[{unix:///var/run/docker/containerd..." module=grpc Jun 28 00:54:46 localhost.localdomain dockerd[45475]: time="2022-06-28T00:54:46.158525449-07:00" level=info msg="ClientConn switching balancer to \"pick_first\"" module=grpc Jun 28 00:54:46 localhost.localdomain dockerd[45475]: time="2022-06-28T00:54:46.202943588-07:00" level=info msg="Loading containers: start." Jun 28 00:54:47 localhost.localdomain dockerd[45475]: time="2022-06-28T00:54:47.021854086-07:00" level=info msg="Default bridge (docker0) is assigned with an IP address 172.17.0.0/16. Daemon...d IP address" Jun 28 00:54:47 localhost.localdomain dockerd[45475]: time="2022-06-28T00:54:47.126281901-07:00" level=info msg="Firewalld: interface docker0 already part of docker zone, returning" Jun 28 00:54:47 localhost.localdomain dockerd[45475]: time="2022-06-28T00:54:47.244251569-07:00" level=info msg="Loading containers: done." Jun 28 00:54:47 localhost.localdomain dockerd[45475]: time="2022-06-28T00:54:47.264592112-07:00" level=info msg="Docker daemon" commit=a89b842 graphdriver(s)=overlay2 version=20.10.17 Jun 28 00:54:47 localhost.localdomain dockerd[45475]: time="2022-06-28T00:54:47.265027319-07:00" level=info msg="Daemon has completed initialization" Jun 28 00:54:47 localhost.localdomain systemd[1]: Started Docker Application Container Engine. Jun 28 00:54:47 localhost.localdomain dockerd[45475]: time="2022-06-28T00:54:47.300116789-07:00" level=info msg="API listen on /var/run/docker.sock" Hint: Some lines were ellipsized, use -l to show in full.
上图表示docker已安装成功
6.docker环境检查
docker info
[root@localhost system]# [root@localhost system]# docker info Running: 0 Paused: 0 Stopped: 0 Images: 0 Server Version: 20.10.17 Storage Driver: overlay2 Backing Filesystem: xfs Supports d_type: true Native Overlay Diff: true userxattr: false Logging Driver: json-file Cgroup Driver: cgroupfs Cgroup Version: 1 Plugins: Volume: local Network: bridge host ipvlan macvlan null overlay Log: awslogs fluentd gcplogs gelf journald json-file local logentries splunk syslog Swarm: inactive Runtimes: io.containerd.runc.v2 io.containerd.runtime.v1.linux runc Default Runtime: runc Init Binary: docker-init containerd version: 10c12954828e7c7c9b6e0ea9b0c02b01407d3ae1 runc version: v1.1.2-0-ga916309f init version: de40ad0 Security Options: seccomp Profile: default Kernel Version: 3.10.0-693.el7.x86_64 Operating System: CentOS Linux 7 (Core) OSType: linux Architecture: x86_64 CPUs: 4 Total Memory: 7.624GiB Name: localhost.localdomain ID: ZHES:U53P:FOPX:QKRO:4PQE:BIKC:OEQJ:7VUS:NBUQ:U47D:R3QO:JKKX Docker Root Dir: /var/lib/docker Debug Mode: false Registry: https://index.docker.io/v1/ Labels: Experimental: false Insecure Registries: 10.1.20.150 127.0.0.0/8 Live Restore Enabled: false Product License: Community Engine
docker version
[root@localhost system]# docker version Client: Version: 20.10.17 API version: 1.41 Go version: go1.17.11 Git commit: 100c701 Built: Mon Jun 6 22:56:42 2022 OS/Arch: linux/amd64 Context: default Experimental: true Server: Docker Engine - Community Engine: Version: 20.10.17 API version: 1.41 (minimum version 1.12) Go version: go1.17.11 Git commit: a89b842 Built: Mon Jun 6 23:01:45 2022 OS/Arch: linux/amd64 Experimental: false containerd: Version: v1.6.6 GitCommit: 10c12954828e7c7c9b6e0ea9b0c02b01407d3ae1 runc: Version: 1.1.2 GitCommit: v1.1.2-0-ga916309f docker-init: Version: 0.19.0 GitCommit: de40ad0
二. 安装 docker-compose
1. 下载docker-compose
官方地址:https://github.com/docker/compose/releases/download/v2.2.2/docker-compose-linux-x86_64
2.安装
sudo mv docker-compose-Linux-x86_64 /usr/local/bin/docker-compose sudo chmod +x /usr/local/bin/docker-compose docker-compose -v
查看版本 docker-compose version
[root@centos247 docker]# docker-compose version docker-compose version 1.24.1, build 4667896b docker-py version: 3.7.3 CPython version: 3.6.8 OpenSSL version: OpenSSL 1.1.0j 20 Nov 2018
三. 在线安装
curl -sSL https://get.daocloud.io/docker | sh
四.docker挂载目录更改
4.1 首次安装
vi /etc/docker/daemon.json # 内容如下:,具体目录试自己情况而定 { "data-root": "/mnt/run/docker" }
重启 systemctl restart docker
4.2 已有运行容器
如果已经有容器进行运行了,此时需要创建好具体盘符的目录,使用如下命令进行将容器拷贝到新盘里
cp -R /var/run/docker /mnt/run
再修改目录
vi /etc/docker/daemon.json # 内容如下:,具体目录试自己情况而定 { "data-root": "/mnt/run/docker" }
重启
systemctl restart docker
最后提供一些daemon.json文件内容:
{ "registry-mirrors": ["https://b9pmyelo.mirror.aliyuncs.com"], "log-driver": "json-file", "log-opts": { "max-size": "100m" }, "storage-driver": "overlay2", "data-root": "/home/run/docker" }
如遇到docker容器中域名访问不到,但ip可以访问的问题
解决方案参考:https://www.cnblogs.com/1285026182YUAN/p/18034487
参考:https://blog.csdn.net/weixin_45107899/article/details/125503680
参考:https://blog.csdn.net/qq_28392947/article/details/126156173