当前位置:首页 > 技术知识 > 正文内容

CentOS系统搭建本地源,摆脱无公网环境下的软件安装难题

maynowei6个月前 (09-09)技术知识55

在公网环境下,通过使用CentOS系统使用自带的包管理工具YUM/DNF,可以实现软件的高效安装、更新、卸载及依赖关系自动化处理。包管理工具优点是会自动检测并安装所需的依赖库,无需用户手动查找和安装每个依赖项,大大简化了安装过程。

在无公网情况下,包管理工具YUM/DNF无法访问CentOS系统默认源,安装软件包或者更新软件包,不管是使用rpm命令安装还是mark编译源代码安装,都无法避免人工处理依赖库问题。通过私有源的建设,可在无公网环境下实现高效、安全、可控的软件管理,解决软件安装难题。选择部署本地源还是私有源,可以根据实际情况选择:

1)设备数量少,各设备操作系统版本不一致,选择为设备部署本地源

2)设备数量多,各设备操作系统版本一致,选择为设备部署私有http源

1、准备工作

下载CentOS镜像

登录CentOS官方历史源,下载对应的发布版本(本文以CentOS7.6为例):

# 登录CentOS官网,选择对应的版本7.6.1810
https://vault.centos.org/7.6.1810/isos/x86_64/

# 选择要下载的iso镜像,建议选择everything版本
wget https://vault.centos.org/7.6.1810/isos/x86_64/CentOS-7-x86_64-Everything-1810.iso #下载镜像文件

# 下载iso镜像签名文件
wget https://vault.centos.org/7.6.1810/isos/x86_64/sha256sum.txt
wget https://vault.centos.org/7.6.1810/isos/x86_64/sha256sum.txt.asc

# 使用sha256sum和gpg核验iso镜像
sha256sum -c sha256sum.txt  #验证iso镜像签名
gpg --verify sha256sum.txt.asc sha256sum.txt  #验证sha256sum签名文件

2、搭建本地源

1)、将下载的iso镜像文件上传到目标服务器的/home目录下,由于单个文件大小超过8G,确保目录下有足够的空间,上传前先检查下磁盘空间;

# 查看磁盘空间
sudo df -h

2)、在/media目录下创建CentOS目录并挂载镜像文件到该目录下

# 创建挂载目录
sudo mkdir /media/CentOS

# 挂载iso镜像文件到/media/CentOS
sudo mount -o loop -t iso9660 /CentOS-7-x86_64-Everything-1810.iso /media/CentOS

参数解释:
'-o loop':镜像使用loop循环设备格式挂载
'-t iso9660':指定挂载镜像格式为iso9660格式 

3)、编辑repo文件,设置本地源信息

# 进入repo文件目录
sudo cd /etc/yum.repos.d  

# 备份默认的repo文件
sudo mkdir repo_bak #创建repo文件备份文件夹
sudo mv *.repo repo_bak #将目录下的repo文件移动到repo_bak目录
cp repo_bak/CentOS-Media.repo .. #复制CentOS-Media.repo到repo目录下

#编辑/etc/yum.repos.d/CentOS-Media.repo文件信息如下
[c7-media]
name=CentOS-$releasever - Media
baseurl=file:///media/CentOS/       # 本地介质挂载路径
#    file:///media/cdrom/           # 备用路径(可添加多个路径)
#    file:///media/cdrecorder/
gpgcheck=0                          # 是否启用 GPG 签名校验
enabled=1                           # 默认是否启用该仓库(0=禁用,1=启用)
gpgkey=file:///media/CentOS/RPM-GPG-KEY-CentOS-7  # GPG 公钥路径
保存并退出

4)、验证本地源

#清理yum默认源缓存信息
sudo yum clean all

#重建本地源缓存
sudo yum makecache

#查看本地源列表
sudo yum repolist

#安装程序测试
yum -y install 软件包

到此,已经完成本地源部署的所有操作。该配置没有做固化,设备重启就会失效,如果要永久使用,可以设置开机自动挂载:

# 将挂载命令写入/etc/rc.local
sudo echo "mount -o loop -t iso9660 /CentOS-7-x86_64-Everything-1810.iso /media/CentOS" >> /etc/rc.local

# 默认rc.local文件没有可执行权限,添加可执行权限
sudo chmod +x /etc/rc.d/rc.local

3、搭建私有源

1)、安装搭建私有源需要的程序包HTTP服务器和仓库创建工具

# 参考'2、搭建本地源'完成本地源搭建,然后安装需要的工具
sudo yum install -y httpd createrepo

2)、创建仓库目录并复制挂载后的镜像数据文件

# 创建私有源http数据目录
sudo mkdir -p /var/www/html/CentOS

# 设置目录权限
sudo chown -R apache:apache /var/www/html/CentOS
sudo chmod -R 755 /var/www/html/CentOS

# 复制镜像数据到目录下
sudo cp -av /mnt/* /var/www/html/CentOS/

# 生成仓库原始数据
sudo createrepo /var/www/html/CentOS/

3)、启动httpd服务并开启访问权限

# 启动httpd服务
sudo systemctl start httpd  #启动服务
sudo systemctl enable httpd #设置自启动

# 开放防火墙访问策略,允许访问http服务
sudo firewall-cmd --permanent --add-service=http
sudo firewall-cmd --reload

# 开放apache的selinux上下文安全规则
sudo setsebool -P httpd_read_user_content 1
sudo semanage fcontext -a -t httpd_sys_content_t "/var/www/html/CentOS(/.*)?"
sudo restorecon -Rv /var/www/html/CentOS

4)、验证http私有源配置,通过在浏览器访问http://ip/CentOS,可以正常查看目录列表,则证明本地配置权限无误,下面可以到客户端进行配置。

5)、修改客户端repo文件

# 进入repo文件目录
sudo cd /etc/yum.repos.d  

# 备份默认的repo文件
sudo mkdir repo_bak #创建repo文件备份文件夹
sudo mv *.repo repo_bak #将目录下的repo文件移动到repo_bak目录

# 创建新的repo文件local.repo
vi /etc/yum.repos.d/local.repo
添加如下内容:
[local-Base]
name=CentOS-$releasever - local
baseurl=http://<服务器IP>/CentOS/
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7
enabled=1
gpgcheck=0
保存并退出

6)、验证http私有源

#清理yum默认源缓存信息
sudo yum clean all

#重建http私有源缓存
sudo yum makecache

#查看私有源列表
sudo yum repolist

#安装程序测试
yum -y install 软件包

到此,已经完成http私有源部署的所有操作。

使用CentOS官方镜像搭建私有http源或本地源,能确保的是源仓库中的软件包经过了严格的测试和验证,兼容性和安全性有保障。避免了人工手动安装程序时从不可信的第三方仓库下载安装软件包和依赖库文件,减少安全风险和版本冲突问题引入。同时可以通过定期下载官方安全更新包方式,保持本地源同步更新,确保终端使用包管理器更新系统中的软件包及其依赖库,所使用的是最新版本的库,及时修复安全漏洞和性能问题。

通过私有源的建设,实现高效、安全、可控的软件供应链管理是重要运维实践。

相关文章

一文弄懂 GO 的 互斥锁 Mutex !(互斥锁的使用方法)

在 Go 语言并发编程中,互斥锁(Mutex)是一个非常重要的同步原语。本文将深入介绍 Mutex 的使用方法、实现原理以及最佳实践。1. 什么是 Mutex?Mutex(互斥锁)是一种用于多线程编程...

C语言编写多线程,什么时候要使用互斥锁?为什么要使用互斥锁?

在多线程编程中,当多个线程同时访问共享资源(如变量、文件等)时,会出现竞态条件(Race Condition)问题,导致程序的行为不可预测。为了避免这种问题,需要使用互斥锁来保护共享资源的访问。互斥锁...

LabVIEW实现Oracle数据库的访问(labview数据库查询界面)

1. 安装 Oracle 客户端下载:从 Oracle 官方网站下载适用于 Windows 操作系统的 Oracle 驱动程序。确保下载的版本与 LabVIEW 环境和操作系统兼容。1)以 Windo...

本地配置plsql远程连接oracle数据库

由于Oracle的庞大,有时候我们需要在只安装Oracle客户端如plsql、toad等的情况下去连接远程数据库,可是没有安装Oracle就没有一切的配置文件去支持。最后终于发现一个很有效的方法,O...

Oracle 11g安装教程完整版(oracle 11g 安装教程)

由于工作需要,将安装的经验分享给大家。第一步:首先准备安装文件包:Oralce 11.2.0.4 64bit和plsqldev1405x64如图所示:第二步:将2个文件解压到同一个目录,如图所示:第三...

Java集合框架:总结(java集合框架是什么?说出一些集合框架的优点)

Java集合框架这个系列做了一个整理,主要包括:Map系:HashMap, LinkedHashMap, TreeMap, WeakHashMap, EnumMap;List系:ArrayList,...