上次转载领导的Docker文章,有朋友问有没有离线安装的方法,我开始想的是用系统的安装镜像ISO来做yum源,进行本地安装。有时候在没有公网访问权限的场景下无法访问公共yum源来安装软件,这时通过创建本地的yum源可以解决一部分问题。方法就是通过挂载完整的系统安装ISO镜像文件,来作为本地yum源。今天简单分享一下操作方法。

首先创建存放系统镜像的目录和挂载镜像的目录。

mkdir –p /yum/iso

mkdir –p /yum/local

上传安装系统的ISO镜像文件到/yum/iso目录下。




如何基于本地镜像from 本地镜像源_anconda设置镜像源


通过以下命令将ISO镜像挂载到本地yum目录/yum/local下。

mount -o loop /yum/iso/CentOS-7-x86_64-DVD-1804.iso /yum/local/


如何基于本地镜像from 本地镜像源_如何基于本地镜像from_02


可以使用命令检查是否挂载成功。

df –h


如何基于本地镜像from 本地镜像源_如何基于本地镜像from_03


在/etc/yum.repos.d/目录下新建一个调用本地yum源的repo文件。

vi /etc/yum.repos.d/local.repo


如何基于本地镜像from 本地镜像源_如何基于本地镜像from_04


repo文件内容如下:

[local]

name=local

# baseurl就是挂载路径,我定义的路径是/yum/local

baseurl=file:///yum/local

# enabled的值为1表示启用该yum源

enabled=1

#本地挂载不涉及数字签名问题,将gpgcheck值设置为0,表示不检查数字签名

gpgcheck=0

# gpgkey的值可以进到挂载路径下进行查看,形如RPM-GPG-KEY-XXXX,我这里看到的是RPM-GPG-KEY-CentOS-7。

gpgkey=file:///mnt/cdrom/RPM-GPG-KEY-CentOS-7

这个地方还出现一个小意外,重启之后会看不到路径下的文件信息,原因是重启后挂载点丢失了,需要重新挂载。可以通过解压镜像文件或者是写一个启动运行的脚本来解决。


如何基于本地镜像from 本地镜像源_如何基于本地镜像from_05


测试使用本地yum源

先模拟一个没有公网的环境,避免干扰。本来是想用360路由器的上网黑名单功能来限制网络访问,结果发现不管用,IP加了黑名单照常能上网。好在我是学过网络的,想到绑定一个错误的ARP表项;就先把ARP信息绑定,然后改了一个错误的MAC地址,这样这台服务器就没法上网了,也就成了本地环境。


如何基于本地镜像from 本地镜像源_anconda设置镜像源_06


然后将系统自带的yum源配置文件移动至其它地方,不建议删除,万一后面用到再创建会麻烦很多。我在同路径下新建了一个history目录,用于存放这些repo文件。(注意:网上有案例是移动到了/tmp目录下,因为/tmp目录过一段时间后会自动删除早期的文件,如果是实验操作,请在操作完成后需要立即恢复或移动到其他位置)

mkdir /etc/yum.repos.d/history


如何基于本地镜像from 本地镜像源_yum源_07


mv CentOS-Base.repo CentOS-CR.repo CentOS-Debuginfo.repo CentOS-fasttrack.repo CentOS-Media.repo CentOS-Sources.repo CentOS-Vault.repo –t history


如何基于本地镜像from 本地镜像源_CentOS_08


清除服务器的yum缓存,再缓存新的yum源。

yum clean all

yum makecache


如何基于本地镜像from 本地镜像源_如何基于本地镜像from_09


再安装一下ntp服务。

yum install –y ntp


如何基于本地镜像from 本地镜像源_重启_10


安装成功。言归正传,那docker能不能安装成功呢?


如何基于本地镜像from 本地镜像源_yum源_11


可以看到,本地yum源中没有这个安装包,那就只能上网去搜了。

我搜了一下,因为依赖包比较多,我就没有测试了,大概是需要11个安装包。


如何基于本地镜像from 本地镜像源_anconda设置镜像源_12


而在线安装显示需要的依赖包更多。


如何基于本地镜像from 本地镜像源_如何基于本地镜像from_13


如果你确实有这种需求,祝你好运吧!