离线版centos8安装docker笔记
嗨嗨哈哈,已经很久没有坐下来胡编乱造一点笔记了,平时云服务器搞惯了,一个命令就安装好了docker了的,但这次生不逢时的新机房就没那么幸运了,有多不逢时超乎想象,不仅仅服务器没有外网,就连周围方圆一公里手机网络都没有,要查一个资料只能步行公里开外去搜寻网络。
不打无准备之战:我就是一名菜鸟,加上这样的环境,岂不是雪上加霜,为了能够顺利的完成部署工作,我也是拼了,哈哈哈哈,网上找了很多关于离线docker的安装资料,各种花式玩法真是百家争鸣,搜索珍藏了1 mole的资料,忐忑的去现场实施了。
看到服务器配置的第一眼,哇靠,这配置真奢侈啊,妥妥的土豪,你没看错,这只是冰山一角。就问你一句话,奢不奢侈。
初出茅庐,手忙脚乱:怀着忐忑的心开始第一次docker离线安装之旅,第一次安装稳稳的宣布失败,根据错误飞奔到公里开外去找度大娘,找完度大娘又满怀憧憬的去修复,修复旧的问题又有新的问题,这样周而复始了N个回合,docker还是顽固的起不起来。该下班了,来日再战。
重整旗鼓,来日再战:自己电脑安装一个centos8虚拟机环境,持续搜索,尝试多次,测试成功了,整理好思路,饱饱睡一觉,来日再战。
依葫画瓢,一战成功:第二天回到机房,找了一台新服务器,按照昨晚的成功经验,一战成功。同样的方法继续搞昨天未成功的服务器,还是宣告失败,成功的回不去了。还好我有一个习惯,新环境按照,我都喜欢操作一步记录一步,找到昨天的安装笔记,一步一操作回撤,最后成功回炉再造。
哈哈哈,唧唧歪歪的说了半天,还没有进入到今天的主题,嘿嘿,你们是不是为我的啰里啰唆感到着急,嗯嗯,好下面我把成功安装的笔记整理一下发出来,供有需要的你做一个参考。
1. 下载docker离线安装包
Docker离线版安装包下载很简单,直接根据下面的地址选择自己合适的版本下载即可:
https://download.docker.com/linux/static/stable/x86_64/
但是在具体版本选择的时候给点建议:不要选择太低的版本,低版本无论是性能还是其他都比理想,版本太新也不知道稳定性是否有问题,哈哈哈,是不是觉得我太保守啦,嗯嗯嗯,我的出发点就是稳定是第一要义,我建议选择19以上版本,以上纯属个人狭隘观点,如有冒犯多多包涵。
我习惯了一直用的是docker-19.03.6.tgz,这次也就选择它了。
2. 安装docker
2.1安装包上传
将上一步骤准备好的docker安装包上传到离线服务器,我习惯上传到目录:/home/installpack,具体目录木有什么要求,根据自己爱好来操作。
2.2安装包解压
首先需要进入到安装包,并执行解压,当然你用决定路径,进入安装包就多此一举了哈,我不嫌麻烦,老老实实一步一步来。分别执行以下命令
1 2 | cd /home/installpack tar xzvf docker-19.03.6.tgz |
执行完毕以后,你会看到一个docker文件夹,那就大功告成,这一步我相信大家想错都难噢,不会给你错的机会。
2.3安装
安装也很简单了,只需执行以下两个命令即可:
1 2 | cp docker/* /usr/bin/ dockerd & |
这一步也许你就没那么幸运了,如果是第一次安装,我想你还是会一如既往的顺,只要不报错,说明你就成功了。
2.4测试
测试是否成功安装,也就一句话的事,执行以下命令即可:
1 | docker info |
显示如下界面,那就真的恭喜您,第一步安装成功,黎明就在眼前了。
当然你也不需要太关心这一些内容是说明意思,或者很简单的看安装成功没得,只要没有红色的字出现就是万事大吉。
如果错了,也不要慌,下面还有呢
2.5报错回撤
无论是安装过程中报错还是测试结果报错,那都是错,如果错了请按照以下步骤来完成回撤。
首先想一想,是否还在网上找了其他大师的教程操作,如果找了,那么你首先要想一想做了哪一些操作,并全部还原回去,尤其是修改了某一些配置文件,是不是想起老师常说的好记性不如烂笔头是很有道理的啦。
接下来就做本次安装文件删除即可,分别执行以下命令:
1 2 3 4 5 6 7 8 9 10 11 | rm -rf /var/run/docker rm -rf /var/lib/docker rm -rf /var/run/docker.pid rm -rf /var/run/docker.sock 停止docker相关的进程 ps -aux | grep docker kill掉查询出来的全部进程 解除docker相关进程占用端口 netstat -nplt | grep docker |
完成以上操作后,又执行一遍安装+测试的命令即可,如果重复执行多次不爽,那我建议你可以拿出问题修复杀手锏了:重启服务器
3. 设置docker为系统服务
3.1创建配置containerd服务
在etc目录下创建containerd文件夹,并在containerd文件夹下创建containerd.service文件。相关命令如下:
1 2 3 | mkdir /etc/containerd touch /usr/lib/systemd/system/containerd.service vi /usr/lib/systemd/system/containerd.service |
其中containerd.service文件的内容填写如下内容(先不关心里面配置的什么,先跑起来才是王道,后面有时间在慢慢研究):
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | [Unit] Description=containerd container runtime Documentation=https://containerd.io After =network.target [Service] ExecStartPre=/sbin/modprobe overlay ExecStart=/usr/bin/containerd Delegate=yes KillMode=process LimitNOFILE=1048576 # Having non-zero Limit*s causes performance problems due to accounting overhead # in the kernel. We recommend using cgroups to do container- local accounting. LimitNPROC=infinity LimitCORE=infinity [Install] WantedBy=multi- user .target |
启动containerd服务,命令如下:
1 2 3 4 5 6 7 8 9 10 11 | # 重新加载配置信息 systemctl daemon-reload #设置containerd.service为开机启动 systemctl enable containerd.service #启动containerd服务 systemctl start containerd.service #查看containerd服务启动状态 systemctl status containerd.service |
依次执行以上命令,最后看到绿色的【active (running)】,那恭喜您containerd服务配置启动成功。如果服务启动失败,还是终极杀手锏来解决:先尝试重启docker,如还是不行在尝试重启服务器,反正我是没有重启
3.2创建配置docker.socket服务
在/usr/lib/systemd/system文件夹创建docker.socket文件,命令如下:
1 2 3 | groupadd docker touch /usr/lib/systemd/system/docker.socket vi /usr/lib/systemd/system/docker. socket |
其中docker.socket文件的内容填写如下内容(先不关心里面配置的什么,先跑起来才是王道,后面有时间在慢慢研究):
1 2 3 4 5 6 7 8 9 10 11 | [Unit] Description=Docker Socket for the API PartOf=docker.service [Socket] ListenStream=/var/run/docker.sock SocketMode=0660 SocketUser=root # 如果出现错误:chown socket at step GROUP : No such process, 可以修改下面的 SocketGroup=root 或创建 docker 用户组(命令 groupadd docker) SocketGroup=docker [Install] WantedBy=sockets.target |
启动containerd服务,查看是否正常,命令如下:
# 重新加载配置信息 systemctl daemon-reload #设置containerd.service为开机启动 systemctl enable containerd.service #启动containerd服务 systemctl start containerd.service #查看containerd服务启动状态 systemctl status containerd.service
依次执行以上命令,最后看到绿色的【active (running)】,那恭喜您containerd服务配置启动成功。如果服务启动失败,还是终极杀手锏来解决:先尝试重启docker,如还是不行在尝试重启服务器,反正我是没有重启
3.3创建配置docker.service服务
在/usr/lib/systemd/system文件夹创建docker.service文件,命令如下:
1 2 | touch /usr/lib/systemd/system/docker.service vi /usr/lib/systemd/system/docker.service |
其中docker.service文件的内容填写如下内容(先不关心里面配置的什么,先跑起来是王道,后面有时间在慢慢研究):
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 | [Unit] Description=Docker Application Container Engine Documentation=https://docs.docker.com BindsTo=containerd.service After =network-online.target firewalld.service containerd.service Wants=network-online.target Requires=docker.socket [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 -H fd:// --containerd=/run/containerd/containerd.sock ExecReload=/bin/kill -s HUP $MAINPID TimeoutSec=0 RestartSec=2 Restart=always # Note that StartLimit* options were moved from "Service" to "Unit" in systemd 229. # Both the old, and new location are accepted by systemd 229 and up, so using the old location # to make them work for either version of systemd. StartLimitBurst=3 # Note that StartLimitInterval was renamed to StartLimitIntervalSec in systemd 230. # Both the old, and new name are accepted by systemd 230 and up, so using the old name to make # this option work for either version of systemd. StartLimitInterval=60s # 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 # Comment TasksMax if your systemd version does not support it. # Only systemd 226 and above support this option . TasksMax=infinity # 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 [Install] WantedBy=multi- user .target |
启动docker.service服务,命令如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | #解除 systemctl unmask docker.service systemctl unmask docker.socket # 重新加载配置信息 systemctl daemon-reload #设置docker为开机启动 systemctl enable docker #启动docker服务 systemctl start docker #查看docker服务启动状态 systemctl status docker |
依次执行以上命令,最后看到绿色的【active (running)】,那恭喜您docekr.service服务配置启动成功。如果服务启动失败,还是终极杀手锏来解决:先尝试重启docker,如还是不行在尝试重启服务器,反正我是重启服务器才成功的。
当看到docker正常启动的那一刻,这次环境搭建之旅忐忑的心才算落地,实话。
4. 安装总结
走到这一步,恭喜您离线版docker搭建完成,简单回顾一下本次安装体会:
戒急戒躁:不要急于求成,跟着文档一个萝卜一个坑的走好
善于笔记:好记性不如烂笔头,记录自己的每一步操作,便于事后的回撤和总结
本次整理没有其他目的,就是一个环境部署笔记总结,正好如果您也在找,也许可以帮助到你一点什么呢,岂不是一件快事。
好了,本次记录就在此see good by。后面有时间在将docker中的相关镜像迁移也做一个整理分享。
END
为了更高的交流,欢迎大家关注我的公众号,扫描下面二维码即可关注,谢谢:
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
2019-12-28 聊聊多线程那一些事儿(task)之 一