当前位置: 首页>后端>正文

搭建Yum本地仓库

三种方式:

  • 挂载镜像到本地(不支持远程访问)
  • FTP方式(支持远程)
  • HTTP方式(支持远程)
挂载镜像到本地

我这里的环境为vmware workstation,只需要在设置里将下图中的勾选即可,如果其他虚拟化环境也是如此,物理机需要插入光盘。

搭建Yum本地仓库,第1张

挂载镜像文件至media文件夹(挂在一个空目录即可),如果对挂载命令不理解的人,请移步百度.

mount /dev/cdrom /media

[图片上传失败...(image-28a703-1645598143091)]

将系统自带的yum仓库文件转移到备份文件夹里

cd /etc/yum.repos.d/
mkdir bak
mv Centos*  bak/

[图片上传失败...(image-935265-1645598143091)]

创建本地yum文件,并指向挂载的目录

cat <<EOF > /etc/yum.repos.d/zabbix.repo
[centos]
name=CentOS
baseurl=file:///media
enabled=1
gpgcheck=0
EOF

测试是否正常
通过yum repolist查看是否OK

[图片上传失败...(image-8bcc76-1645598143092)]

HTTP方式

第一种只适合本地化部署,如果需要远程访问就需要用HTTP方式。
既然是http,首先安装web服务(这里可以是apache、可以是Nginx也可以是基于Python的web,自行选择),其次安装yum-utils扩展模块及createrepo创建镜像仓库工具。

yum -y install httpd
yum -y install yum-utils createrepo

创建yum仓库的文件夹,文件夹自行创建

mkdir  /kasar

下载安装包到创建文件夹,或者把已有的rpm包移到新建的仓库文件夹下,这里下载vim包示范一下

yum -y install --downloadonly --downloaddir=/kasar vim

[图片上传失败...(image-544afe-1645598143092)]

制作yum仓库,创建仓库元数据文件

createrepo /kasar

[图片上传失败...(image-1b5fdf-1645598143092)]

修改http配置(如果用的Nginx就修改Nginx主配置文件),将根目录设置为yum仓库目录,同时修改权限和所属者,以及将welcome的文件修改掉(不然访问首页就是默认测试页),并启动。

vi /etc/httpd/conf/httpd.conf
cd /etc/httpd/conf.d/
mv welcome.conf welcome.conf.bak
chown apache:apache /kasar -R
chmod 755 /kasar -R
systemctl start httpd && systemctl enable httpd

[图片上传失败...(image-fb038c-1645598143092)]

[图片上传失败...(image-ecc7f1-1645598143092)]

[图片上传失败...(image-1b30e0-1645598143092)]

在客户机使用,同样屏蔽掉自带yum仓库

cat <<EOF > /etc/yum.repos.d/kasar.repo
[centos]
name=CentOS
baseurl=http://192.168.0.100
enabled=1
gpgcheck=0
EOF

添加rpm包yum仓库,并更新

[图片上传失败...(image-8f1b46-1645598143092)]

[图片上传失败...(image-610449-1645598143092)]

更新本地yum仓库

createrepo --update /kasar

[图片上传失败...(image-1547fb-1645598143092)]

更新完之后再下载,成功了。

[图片上传失败...(image-bf2a5f-1645598143092)]

这一种只能解决当前所需要的包,远远满足不了企业的需求,所以需要将阿里或者其他的down下来,那怎么做呢,以zabbix 阿里镜像站为例,首先安装阿里的zabbix仓库文件

cat <<EOF > /etc/yum.repos.d/zabbix.repo
[zabbix]
name=Zabbix Official Repository - $basearch
baseurl=https://mirrors.aliyun.com/zabbix/zabbix/5.2/rhel/8/$basearch/
enabled=1
gpgcheck=1
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-ZABBIX-A14FE591
[zabbix-non-supported]
name=Zabbix Official Repository non-supported - $basearch
baseurl=https://mirrors.aliyun.com/zabbix/non-supported/rhel/8/$basearch/
enabled=1
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-ZABBIX
gpgcheck=1
EOF
curl https://mirrors.aliyun.com/zabbix/RPM-GPG-KEY-ZABBIX-A14FE591 \
-o /etc/pki/rpm-gpg/RPM-GPG-KEY-ZABBIX-A14FE591
curl https://mirrors.aliyun.com/zabbix/RPM-GPG-KEY-ZABBIX \
-o /etc/pki/rpm-gpg/RPM-GPG-KEY-ZABBIX
curl https://mirrors.aliyun.com/zabbix/RPM-GPG-KEY-ZABBIX-A14FE591 \
-o /etc/pki/rpm-gpg/RPM-GPG-KEY-ZABBIX-A14FE591
curl https://mirrors.aliyun.com/zabbix/RPM-GPG-KEY-ZABBIX \
-o /etc/pki/rpm-gpg/RPM-GPG-KEY-ZABBIX

[图片上传失败...(image-ef8970-1645598143092)]

查看镜像仓库

[图片上传失败...(image-22d3a2-1645598143092)]

我们需要将数据包同步到本地,这里的名字就是repo id的前缀

reposync -r zabbix /kasar

创建repo元数据文件
createrepo /kasar/zabbix

[图片上传失败...(image-ee2e96-1645598143092)]

客户端使用,这里需要注意的是IP后需要跟zabbix的目录,因为元数据文件在zabbix目录里

cat <<EOF > /etc/yum.repos.d/kasar.repo
[centos]
name=CentOS
baseurl=http://192.168.0.100/zabbix
enabled=1
gpgcheck=0
EOF

[图片上传失败...(image-b1a77e-1645598143092)]

[图片上传失败...(image-c85c33-1645598143092)]

整个过程就完成了,ftp过程和http类似,可以举一反三,如果有疑问的小伙伴欢迎留言哦。

附录
自动更新脚本,对cron不熟悉请移步百度

vim /cron/kasar.sh #编写同步脚本
reposync -r zabbix -p /kasar -d #删除本地老旧
reposync -r base -p /kasar/

crontab -e #添加定时任务
0 0 1 * * sh /cron/repository.sh #每月1日0时更新yum仓库

原文转载自:今日头条@IT小白Kasar


https://www.xamrdz.com/backend/3pq1997658.html

相关文章: