【配置本地仓库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
相关推荐
ac.char几秒前
在 Ubuntu 上安装 Yarn 环境
linux·运维·服务器·ubuntu
敲上瘾1 分钟前
操作系统的理解
linux·运维·服务器·c++·大模型·操作系统·aigc
长弓聊编程19 分钟前
Linux系统使用valgrind分析C++程序内存资源使用情况
linux·c++
cherub.27 分钟前
深入解析信号量:定义与环形队列生产消费模型剖析
linux·c++
梅见十柒1 小时前
wsl2中kali linux下的docker使用教程(教程总结)
linux·经验分享·docker·云原生
Koi慢热1 小时前
路由基础(全)
linux·网络·网络协议·安全
传而习乎1 小时前
Linux:CentOS 7 解压 7zip 压缩的文件
linux·运维·centos
soulteary1 小时前
突破内存限制:Mac Mini M2 服务器化实践指南
运维·服务器·redis·macos·arm·pika
我们的五年1 小时前
【Linux课程学习】:进程程序替换,execl,execv,execlp,execvp,execve,execle,execvpe函数
linux·c++·学习
IT果果日记2 小时前
ubuntu 安装 conda
linux·ubuntu·conda