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

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

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

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

相关推荐

0722-6.2.0-如何在RedHat7.2使用rpm安装CDH(无CM)

文档编写目的在前面的文档中,介绍了在有CM和无CM两种情况下使用rpm方式安装CDH5.10.0,本文档将介绍如何在无CM的情况下使用rpm方式安装CDH6.2.0,与之前安装C5进行对比。环境介绍:...

ARM64 平台基于 openEuler + iSula 环境部署 Kubernetes

为什么要在arm64平台上部署Kubernetes,而且还是鲲鹏920的架构。说来话长。。。此处省略5000字。介绍下系统信息;o架构:鲲鹏920(Kunpeng920)oOS:ope...

生产环境starrocks 3.1存算一体集群部署

集群规划FE:节点主要负责元数据管理、客户端连接管理、查询计划和查询调度。>3节点。BE:节点负责数据存储和SQL执行。>3节点。CN:无存储功能能的BE。环境准备CPU检查JDK...

在CentOS上添加swap虚拟内存并设置优先级

现如今很多云服务器都会自己配置好虚拟内存,当然也有很多没有配置虚拟内存的,虚拟内存可以让我们的低配服务器使用更多的内存,可以减少很多硬件成本,比如我们运行很多服务的时候,内存常常会满,当配置了虚拟内存...

国产深度(deepin)操作系统优化指南

1.升级内核随着deepin版本的更新,会自动升级系统内核,但是我们依旧可以通过命令行手动升级内核,以获取更好的性能和更多的硬件支持。具体操作:-添加PPAs使用以下命令添加PPAs:```...

postgresql-15.4 多节点主从(读写分离)

1、下载软件[root@TX-CN-PostgreSQL01-252software]#wgethttps://ftp.postgresql.org/pub/source/v15.4/postg...

Docker 容器 Java 服务内存与 GC 优化实施方案

一、设置Docker容器内存限制(生产环境建议)1.查看宿主机可用内存bashfree-h#示例输出(假设宿主机剩余16GB可用内存)#Mem:64G...

虚拟内存设置、解决linux内存不够问题

虚拟内存设置(解决linux内存不够情况)背景介绍  Memory指机器物理内存,读写速度低于CPU一个量级,但是高于磁盘不止一个量级。所以,程序和数据如果在内存的话,会有非常快的读写速度。但是,内存...

Elasticsearch性能调优(5):服务器配置选择

在选择elasticsearch服务器时,要尽可能地选择与当前业务量相匹配的服务器。如果服务器配置太低,则意味着需要更多的节点来满足需求,一个集群的节点太多时会增加集群管理的成本。如果服务器配置太高,...

Es如何落地

一、配置准备节点类型CPU内存硬盘网络机器数操作系统data节点16C64G2000G本地SSD所有es同一可用区3(ecs)Centos7master节点2C8G200G云SSD所有es同一可用区...

针对Linux内存管理知识学习总结

现在的服务器大部分都是运行在Linux上面的,所以,作为一个程序员有必要简单地了解一下系统是如何运行的。对于内存部分需要知道:地址映射内存管理的方式缺页异常先来看一些基本的知识,在进程看来,内存分为内...

MySQL进阶之性能优化

概述MySQL的性能优化,包括了服务器硬件优化、操作系统的优化、MySQL数据库配置优化、数据库表设计的优化、SQL语句优化等5个方面的优化。在进行优化之前,需要先掌握性能分析的思路和方法,找出问题,...

Linux Cgroups(Control Groups)原理

LinuxCgroups(ControlGroups)是内核提供的资源分配、限制和监控机制,通过层级化进程分组实现资源的精细化控制。以下从核心原理、操作示例和版本演进三方面详细分析:一、核心原理与...

linux 常用性能优化参数及理解

1.优化内核相关参数配置文件/etc/sysctl.conf配置方法直接将参数添加进文件每条一行.sysctl-a可以查看默认配置sysctl-p执行并检测是否有错误例如设置错了参数:[roo...

如何在 Linux 中使用 Sysctl 命令?

sysctl是一个用于配置和查询Linux内核参数的命令行工具。它通过与/proc/sys虚拟文件系统交互,允许用户在运行时动态修改内核参数。这些参数控制着系统的各种行为,包括网络设置、文件...

取消回复欢迎 发表评论: