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

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

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

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

相关推荐

安全软件更新:OpenSSH 9.3和OpenSSL 3.1

最近开源安全软件领域也相继更新了最新版本。其中上周OpenSSL发布了最新的3.1版本,而OpenSSH则在昨天发布最新版本9.3。虽然带来的新功能不多,只是bug和漏洞方面的修复,但是作为比较重要的...

阿里云新增的轻量应用服务器(欧洲与美洲)美国(硅谷)配置方法

近期,阿里云的轻量应用服务器新增了欧洲与美洲地域,可以在美国(硅谷)部署服务器了,但是没有LAMP应用镜像,所以在配置服务器时遇到几个问题,SSH登录不了,提示【Algorithmnegotiati...

OpenSSH 10.0发布 旨在更好地抵御量子计算机的攻击

OpenSSH10.0现已支持这一广泛使用的SSH客户端/服务器实现。OpenSSH10.0包含多项改进,包括更好地防御未来量子计算机可能发起的攻击。OpenSSH10.0放弃了对过去...

腾讯云国际站: 腾讯云服务器怎麽SSH远程连接

本文由【云老大】TG@yunlaoda360撰写准备工作获取服务器的公网IP地址:在腾讯云控制台找到云服务器实例,查看其基本信息,获取公网IP地址。确保服务器已安装SSH服务:一般Linux系统默...

旧电脑改服务器,这 6 个坑能让你白忙 3 天(附实测解决办法)

前几天收到粉丝私信,说照着教程把旧电脑改成服务器,结果折腾了3天还是没成功——要么是启动后连不上网,要么是跑两天就自动关机。其实我第一次改的时候也踩了不少坑,光是让旧电脑稳定运行,就重装了6...

使用win10自带的ssh服务器

我太喜欢ssh了,因为它的功能实在太强大,而且几乎不占用啥资源。(PS:类似的软件:p7zip,tightvnc)。因此,无论是哪个系统,我总想着安装一个ssh的服务器。之前我在虚拟机中安装了个win...

Python sys模块使用教程

1.知识导图2.sys模块概述2.1模块定义与作用sys模块是Python标准库中的一个内置模块,提供了与Python解释器及其环境交互的接口。它包含了许多与系统相关的变量和函数,可以用来控制P...

满足AI时代高效办公需求 惠普战99 AI商务超能本评测

身处智能化时代的浪潮之中,人工智能正在深刻影响着我们工作和生活的方式,从聊天机器人到自动驾驶,从智能制造到药物研发,人工智能的力量无处不在。如今,随着各类AI应用逐渐占据主流计算平台,并在各种触手可及...

使用 vLLM 生产环境部署 DeepSeek,算力减半、吞吐增十倍!

需求:之前使用Ollama部署过deepseek-r1:32b模型,非常方便快捷,适合个人快速部署使用。如果作为企业生产环境应该使用什么方式部署呢?一般都采用vllm、sglang进行部署...

我把 ML 模型编译成 C 后,速度竟提升了 1000 倍!

【CSDN编者按】在本文中,我们来尝试将micrograd神经网络编译成C。具体内容如下:简单了解一下神经网络;看看micrograd如何前向传播和反向传播;复习链式法则;分析为什么mi...

这才是真·非公旗舰!索泰RTX 5080天启OC显卡评测

近年来,电脑硬件的RGB灯光逐渐成为标配,厂商在产品差异化这一方面则开拓了二次元IP形象这一新的领域,但要说哪家厂商在这一领域最吸引眼球,我想索泰应该要属独领风骚的一个。早在2020年,索泰便推出了以...

性能测试工具Iperf 验证SDN网络

1实验目的掌握Iperf在Linux环境下的安装和常用命令行参数的含义熟悉Iperf应用实例掌握SDN网络中使用Iperf测试网络带宽等2实验原理网络性能测试主要是监测网络带宽的使用率,将网络带宽...

方案 | 感受沉浸式音效的魅力:Roger和他的豪华影院

随着沉浸式音效的不断普及,诸如杜比全景声、DTS:X或Auro3D等技术不断引入到家庭影院音响系统中来,并带来了前所未有的震撼效果。也因此,越来越多的业主想要搭建一间具备沉浸式音效的影院,以享受更高...

LLVM IR入门:编写自定义优化Pass的完整教程与性能影响分析

LLVMIR:编译器优化的核心纽带LLVM作为模块化编译器框架的典范,其中间表示(IR)是连接前端(如Clang)与后端(目标架构代码生成)的桥梁。与传统编译器不同,LLVMIR具有平台无关性和...

iperf-LINUX测速工具

#iperf-测速工具安装包下载地址https://github.com/esnet/iperfhttps://downloads.es.net/pub/iperf/iperf-3.9.tar.gz官...

取消回复欢迎 发表评论: