【配置本地仓库yum源的两种方式】

一、使用下载的rpm包搭建本地仓库yum源

​  使用自己下载的rpm包搭建本地仓库,需要用createrepo去创建仓库元数据。

1、下载需要的软件包

在一台可以联网的服务器上下载。或者通过其他方式下载自己需要的软件包。

shell 复制代码
# 下载所需工具依赖包到 /mypath
[root@test ~]# yum install --downloadonly --downloaddir=/mypath createrepo httpd [...]
  • createrepo:是一个用于创建Yum仓库的命令行工具。它用于生成Yum仓库所需的目录结构和元数据,以便Yum客户端可以通过该仓库获取和安装软件包。
  • httpd:是一个开源的Web服务器软件。

2、制作yum源(本地)

适用场景:使用yum源的是当前服务器。

shell 复制代码
# 创建一个新的目录,用于存储yum源的软件包
# 将需要的rpm软件包复制或下载到该目录中
[root@test ~]# mkdir /opt/repo
# 生成repodata目录-元数据
[root@test ~]# createrepo /opt/repo/
# 命令执行后,会在该目录下创建一个repodata目录 
[root@test ~]# ls /opt/repo/
repodata
# 更新createrepo
[root@test ~]# createrepo --update /opt/repo
# 此时就制作好了本地yum源

关于repodata

跳转:《全面解析repodata》

​  repodata包含了该仓库中每个RPM软件包的元数据。repodata包含的信息有很多,包括但不限于软件包的名称、版本、发行版、依赖关系、提供的功能等等。

shell 复制代码
[root@test ~]# ll /opt/repo/repodata
*-primary.xml.gz	# 软件包的基本信息
*-filelists.xml.gz	# 软件包中包含文件的信息
*-other.xml.gz	# 软件包其它相关信息
repomd.xml	# 提供.xml.gz下载和校验信息

3、搭建http服务(局域网)

适用场景:使用yum源的是同局域网的其他服务器。

shell 复制代码
# 搭建http服务
[root@test ~]# cd /opt/repo
[root@test repo]# yum install -y httpd
[root@test repo]# systemctl start httpd && systemctl enable httpd
# 可以做软链接也可以直接把目录mv到/var/www/html/
[root@test repo]# ln -s /opt/repo /var/www/html/

http服务的路由访问示例:

root@test www\]# tree /var/www/ /var/www/ ├── cgi-bin └── html   ├── testA # http服务访问:http://192.168.38.10/testA/   └── repo # http服务访问:http://192.168.38.10/repo/

3.1、访问yum服务器

http://192.168.38.10/repo/

4、yum配置文件

shell 复制代码
# 新建一个新的yum源配置文件
[root@test ~]# vi /etc/yum.repos.d/local.repo

# 添加以下内容
[local]
name=Local Repository
baseurl=file:///opt/repo	# 本地yum源,配置文件path
#baseurl=http://192.168.38.10/repo/	# 搭建http服务后,可配置服务url
enabled=1
gpgcheck=0	# 如果想要启用GPG校验,将gpgcheck的值设置为1 并提供相应的GPG密钥

5、验证

shell 复制代码
# 清除现有的yum缓存
[root@test ~]# yum clean all
# 查看源列表
[root@test ~]# yum repolist

二、使用镜像文件搭建本地仓库yum源

​  如果使用系统镜像文件搭建yum源,无需 createrepo去创建仓库元数据,因为在打包成iso文件前,就已经建好了。直接创建仓库文件,将路径指向关盘挂载的目录就可以了。

镜像文件目录:

  • Packages:存放rpm软件包。
  • repodata:仓库档案(元数据)。
  • isolinux:光盘引导数据。
  • RPM-GPG-KEY-xxx:签名校验密钥。

1、创建挂载目录

shell 复制代码
[root@test ~] mkdir /mnt/cdrom

2、上传镜像文件

将镜像文件上传到本地目录下,假设上传目录为:/root/CentOS-7-xxx.iso

3、挂载iso文件

shell 复制代码
# 将本地iso文件挂载到/mnt/cdrom目录
[root@test ~] mount -o loop -t iso9660  /root/CentOS-7-xxx.iso /mnt/cdrom

也可以搭建http服务,对外提供服务。

4、配置yum配置文件

shell 复制代码
[root@test ~] vim /etc/yum.repos.d/local.repo
[base]
name=RedHat
baseurl=file:///mnt/cdrom
enabled=1
gpgcheck=0
# gpgkey=file:///mnt/cdrom/RPM-GPG-KEY-xxx

# baseurl:挂载的目录,在这里是/mnt/cdrom
# enabled:一定要为1  
# gpgckeck:如果想要启用GPG校验,将gpgcheck的值设置为1 并提供相应的GPG密钥
# gpgkey:cd /mnt/cdrom/可以看到这个key,这里仅仅是个例子

5、验证

shell 复制代码
# 清除现有的yum缓存
[root@test ~]# yum clean all
# 查看源列表
[root@test ~]# yum repolist
相关推荐
IT界小黑的对象13 分钟前
virtualBox部署ubuntu22.04虚拟机 NAT+host only 宿主机ping不通虚拟机
linux·运维·服务器
SilentCodeY13 分钟前
Ubuntu 系统通过防火墙管控 Docker 容器
linux·安全·ubuntu·系统防火墙
weixin_5275504035 分钟前
Linux 环境下高效视频切帧的实用指南
linux·运维·音视频
keson要进步36 分钟前
CICD实战(一) -----Jenkins的下载与安装
运维·ci/cd·centos·自动化·jenkins
keson要进步37 分钟前
CICD实战(二)-----gitlab的安装与配置
linux·运维·gitlab
藥瓿亭1 小时前
K8S认证|CKS题库+答案| 4. RBAC - RoleBinding
linux·运维·服务器·云原生·容器·kubernetes·cks
发非人非1 小时前
Shell编程核心符号与格式化操作详解
运维
吐泡泡_1 小时前
Linux(线程控制)
linux
tasselyue2 小时前
Macbook M3 使用 VMware Fusion 安装 openEuler24.03LTS
linux
行止62 小时前
MySQL主从复制与读写分离
linux·数据库·mysql