搭建本地yum源大概有下面三种情况:
-
- ISO镜像搭建本机使用的yum仓库
-
- ISO镜像搭建局域网使用的yum仓库
-
- 第三方镜像搭建局域网使用的yum仓库
不管怎样,核心有两点:yum包仓库搭建、repo配置url。
另外,由于包受限于选择的仓库来源,故包的版本取决于选择的仓库,极有可能不是最新版、或者不是自己想要的版本。比如ansible在本次所选择的epel源版本是2.7.2,这是老版本
- 第三方镜像搭建局域网使用的yum仓库
[root@node1 yum.repos.d]#yum list|grep ansible ansible.noarch 2.7.2-1.el7 @epel ansible.noarch 2.9.15-1.el7 epel ansible-doc.noarch 2.9.15-1.el7 epel ansible-inventory-grapher.noarch 2.4.4-1.el7 epel ansible-lint.noarch 3.5.1-1.el7 epel ansible-openstack-modules.noarch 0-20140902git79d751a.el7 epel ansible-python3.noarch 2.9.15-1.el7 epel ansible-review.noarch 0.13.4-1.el7 epel centos-release-ansible-27.noarch 1-1.el7 extras centos-release-ansible-28.noarch 1-1.el7 extras centos-release-ansible-29.noarch 1-1.el7 extras centos-release-ansible26.noarch 1-3.el7.centos extras kubernetes-ansible.noarch 0.6.0-0.1.gitd65ebd5.el7 epel python2-ansible-runner.noarch 1.0.1-1.el7 epel python2-ansible-tower-cli.noarch 3.3.9-1.el7 epel vim-ansible.noarch 3.0-1.el7 epel [root@node1 yum.repos.d]#rpm -qa|grep ansible ansible-2.7.2-1.el7.noarch环境
[root@node1 yum.repos.d]#cat /etc/redhat-release CentOS Linux release 7.5.1804 (Core) 无防火墙、selinux关闭搭建步骤
1. ISO镜像搭建本机使用的yum仓库,最简单
挂载镜像->修改repo->使用
- 假定系统识别的镜像在/dev/cdrom
mount /dev/cdrom /mnt // 挂载到mnt目录,mnt目录可以按自己习惯修改
- 备份原repo文件,创建新的repo文件
mkdir /etc/yum.repos.d/bak&&mv /etc/yum.repos.d/*repo /etc/yum.repos.d/bak cat <<EOF >yum.repo [local] name=Local_centos baseurl=file:///mnt //mnt是挂载目录 enable=1 gpcheck=0 EOF
3.使用
yum clean all //删除缓存 [root@node2 yum.repos.d]# yum repolist //查看仓库情况 已加载插件:fastestmirror Loading mirror speeds from cached hostfile 源标识 源名称 状态 local Local_centos 4,070 repolist: 4,070
yum install * //安装
2. ISO镜像搭建局域网使用的yum仓库
此步骤需要配合http服务,推荐nginx,不赘述
- nginx改局域网yum仓库的html路径。
worker_processes 1; events { worker_connections 1024; } http { include mime.types; default_type application/octet-stream; sendfile on; keepalive_timeout 65; server { listen 8080; server_name localhost; location / { autoindex on; //重要 root /mnt/; # (这里请换成你的实际目录路径) } } }
理论上加入server{}内容,nginx -t检查错语法,重启nginx即可,但是这样修改后在客户端总是404
[root@node2 yum.repos.d]# cat yum.repo //客户端已备份原有repo,创建repo配置 [centos] name=Local_centos baseurl=http://192.168.44.11/ enable=1 gpcheck=0
404报错
[root@node2 yum.repos.d]# yum makecache 已加载插件:fastestmirror Loading mirror speeds from cached hostfile http://192.168.44.11/yum/repodata/repomd.xml: [Errno 14] HTTP Error 404 - Not Found 正在尝试其它镜像。 To address this issue please refer to the below wiki article https://wiki.centos.org/yum-errors If above article doesn't help to resolve this issue please use https://bugs.centos.org/. 元数据缓存已建立
猜想原因是nginx为yum安装,/etc/nginx/nginx.conf加入的server配置其实根本没有生效,验证手段:改端口80位8081,重启服务,查看端口,发现仍旧是80。说明猜想正确。
[root@node1 yum.repos.d]#netstat -antp|grep nginx tcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN 2883/nginx: master
- 故采取了手动生成yum仓库的办法
- 进入nginx默认html目录,手动创建包仓库信息
cd /usr/share/nginx/html/ mkdir yum ln -s /mnt/Packages Packages //关键,创建包的软连接。直接拷贝过来也行 createrepo yum/ //创建仓库索引信息,createrepo可能需要安装
createrepo之后,yum的目录结构:包、html索引
[root@node1 logs]#ll /usr/share/nginx/html/yum/ 总用量 4 lrwxrwxrwx 1 root root 13 11月 26 19:08 Packages -> /mnt/Packages drwxr-xr-x 2 root root 4096 11月 26 19:10 repodata
修改客户端repo配置文件的url目录
[root@node2 yum.repos.d]# cat yum.repo //客户端已备份原有repo,创建repo配置 [centos] name=Local_centos baseurl=http://192.168.44.11/yum //比之前多了yum enable=1 gpcheck=0
客户端再次yum clean all和yum makecache不再报错
[root@node2 yum.repos.d]# yum clean all 已加载插件:fastestmirror 正在清理软件源: centos Cleaning up everything Maybe you want: rm -rf /var/cache/yum, to also free up space taken by orphaned data from disabled or removed repos Cleaning up list of fastest mirrors [root@node2 yum.repos.d]# yum makecache 已加载插件:fastestmirror Loading mirror speeds from cached hostfile centos | 2.9 kB 00:00:00 元数据缓存已建立 [root@node2 yum.repos.d]# yum repolist 已加载插件:fastestmirror Determining fastest mirrors centos | 2.9 kB 00:00:00 centos/primary_db | 3.3 MB 00:00:00 源标识 源名称 状态 centos Local_centos 4,070 repolist: 4,070
3. 第三方镜像搭建局域网使用的yum仓库,比如阿里云repo和epel
举一反三,由步骤2引出第三个方法,如果有第三方的包,那本地全部下载后重复步骤2,创建包目录、仓库索引页。这样会生成一个更全的仓库,因为毕竟centos镜像文件还是会缺包,比如nginx就没有。
参考
- 下载工具
yum install createrepo yum-utils -y //yum-utils -y包含reposync 很重要
- 备份repo,下载阿里云repo/epel
wget -O /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-7.repo wget -O /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-7.repo [root@node1 yum.repos.d]#ll 总用量 12 drwxr-xr-x 2 root root 263 11月 26 20:36 bak -rw-r--r-- 1 root root 2523 6月 16 2018 CentOS-Base.repo -rw-r--r-- 1 root root 664 5月 11 2018 epel.repo
- 同步镜像到本地,包很大,约30G。
[root@prometheus yum.repos.d]# yum clean all #清除之前的yum源缓存 [root@prometheus yum.repos.d]# yum makecache #创建缓存 [root@prometheus yum.repos.d]# yum repolist #查看当前可用的YUM源
cd ~ //切换到用户家目录 [root@prometheus ~]# reposync -r base #reposync将根据刚下载的repo下载rpm包到指定文件夹 [root@prometheus ~]# reposync -r extras [root@prometheus ~]# reposync -r updates [root@prometheus ~]# reposync -r epel
- 创建yum仓库索引
[root@prometheus ~]# cd /root/base [root@prometheus ~]# createrepo ./ [root@prometheus ~]# cd /root/extras [root@prometheus ~]# createrepo ./ [root@prometheus ~]# cd /root/updates [root@prometheus ~]# createrepo ./ [root@prometheus ~]# cd /root/epel [root@prometheus ~]# createrepo ./
此时/root/下面主要目录是下面四个,每个目录下面会有Packages和repodata两个目录,打包拷贝到现场。
9.0G ./base 748M ./extras 3.4G ./updates 16G ./epel 29G .
- 现场客户端备份、创建repo配置文件。
5.1 无nginx,只创建本机仓库 ,即本机就是客户端 。 解压包到/root/yum
[root@node1 ~]# vim /etc/yum.repos.d/base.repo [base] name=CentOS-Base baseurl=file:///root/yum/base path=/ enabled=1 #是否将该仓库做为软件包提供源 gpgcheck=0 #是否进行gpg校验 [updates] name=CentOS-Updates baseurl=file:///root/yum/updates path=/ enabled=1 gpgcheck=0 [extras] name=CentOS-Extras baseurl=file:///root/yum/extras path=/ enabled=1 gpgcheck=0 [root@node1 ~]# vim /etc/yum.repos.d/epel.repo [epel] name=CentOS-Epel baseurl=file:///root/yum/epel path=/ enabled=1 gpgcheck=0
使用前
yum clean all&&yum makecache
5.2 有nginx,此时可以搭建局域网仓库
解压包到nginx的默认html目录,如/usr/share/nginx/html/yum/
[root@node1 ~]# vim /etc/yum.repos.d/base.repo [base] name=CentOS-Base baseurl=http://192.168.44.11/base path=/ enabled=1 #是否将该仓库做为软件包提供源 gpgcheck=0 #是否进行gpg校验 [updates] name=CentOS-Updates baseurl=http://192.168.44.11/updates path=/ enabled=1 gpgcheck=0 [extras] name=CentOS-Extras baseurl=http://192.168.44.11/extras path=/ enabled=1 gpgcheck=0 [root@node1 ~]# vim /etc/yum.repos.d/epel.repo [epel] name=CentOS-Epel baseurl=http://192.168.44.11/epel path=/ enabled=1 gpgcheck=0
使用前
yum clean all&&yum makecache