百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程文章 > 正文

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

qiyuwang 2025-05-08 20:56 3 浏览 0 评论

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

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

相关推荐

centos7使用yum安装nginx+php7+mysql5.6

本文主要介绍安装在centos7下如何安装nginx+php+mysql的环境,centos7的版本自带安装源的版本无法实现PHP5.4以上的版本,数据库默认用的是mariadb,文章介绍的安装是如何...

Linux基础入门(VMWare中CentOS7配置yum)

上一章节,介绍了《Linux基础入门(CentOS7下通过命令行配置网络)》,本章将介绍如何配置yum源,方便后续在学习和使用的过程中,对所需工具的安装;...

CentOS 7搭建Nextcloud私有云(centos搭建云盘)

Nextcloud简介:对于私人网盘,其中最出名的就是seafile、owncloud和nextcloud。seafile是国人开发的,有免费和企业版,免费的功能有限;nextcloud是owncl...

分享一个docker镜像源地址,解决docker不能拉取的问题

自己搭建的代理,centos7只需要修改/etc/docker/daemon.json并输入以下内容:{"registry-mirrors":["https://next...

源支付5.18版全套开源源码客户端+云端+监控+协议三网免挂免输入

源支付5.18最新版协议去授权全套三端开源源码_客户端+云端+监控+协议三网免挂免输入(全套版)推荐系统为:CentOS7.6Linux系统环境:Nginx1.20.1+MySQL5.6....

centos7飞速搭建zabbix5.0并添加windows、linux监控

一、环境zabbix所在服务器系统为centos7,监控的服务器为windows2016和centos7。二、安装zabbix官方安装帮助页面...

CentOS上配置 Docker 使用代理服务器

hub.docker最近总被墙,国内大厂搞的docker镜像源代理被封被停,对于一个严重依赖一些海外项目的软件开发人员,简直没法干活了。docker要在CentOS上配置Docker使用代理服...

CentOS 7 (阿里云虚拟机) 安装 Docker

一、安装Docker1.使用root权限登录CentOS。确保yum包更新到最新sudoyumupdate...

Centos离线静默安装 oracle11g,步骤细验证成功

一、环境要求1.1.涉及工具及环境1)CentOS764位系统2)oracle安装包文件a)linux.x64_11gR2_database_1of2.zip...

Linux运维之制作指定软件包的YUM源

#挑战30天在头条写日记#关注我,不迷路,大家好,我是大王。--记录运维中遇到的故障及排查方法...

在CentOS 9 安装Nvidia显卡驱动详细操作步骤

今天给粉丝网友演示CentOS9系统下如何安装nvidia显卡驱动。·将下载好的显卡驱动放到文件夹中,这里以download为例,放入文件夹中开始对系统软件升级,是为了防止在安装显卡驱动时显示报错...

基于Linux系统的本地Yum源搭建与配置(ISO方式、RPM方式)

前言:由于公司业务服务器大部分都在内网环境下运行,内网环境无法直接使用yum安装升级更新软件,所以需要自建Yum源来满足目前日常工作需要。...

最新zabbix一键安装脚本(基于centos8)

一、环境准备注意:操作系统必须是centos8及以上的,因为我配的安装源是centos8的。并且必须连接互联网,脚本是基于yum安装的!!!...

CentOS7中使用yum安装Nginx的方法

1、添加源  默认情况Centos7中无Nginx的源,最近发现Nginx官网提供了Centos的源地址。因此可以如下执行命令添加源(...

Centos8出现Failed to download metadata for repo &#39;AppStream&#39;解决

大家都知道Centos8于2021年年底停止了服务,大家再在使用yum源安装时候,出现下面错误“错误:Failedtodownloadmetadataforrepo'AppStre...

取消回复欢迎 发表评论: