Linux下本地yum源配置及局域网yum配置
1、Linux下本地yum源配置
本地yum源依赖于python解析,首先要确保系统的python和yum源安装完成
1.1、本地yum源配置及挂载
上传ISO镜像或使用本机镜像,使用mount
命令挂载镜像到/dev/loop0设备文件(用于模拟块设备)
mount /dev/loop0 /opt/yum-iso # 报错如下
# failed to setup loop device: No such file or directory
在类 UNIX 系统里,loop 设备是一种伪设备(pseudo-device),或者说是仿真设备,我们又叫它为循环接口文件,它能使我们像块设备一样访问一个文件。在使用之前,一个 loop 设备必须要和一个文件进行连接。这种结合方式给用户提供了一个替代块特殊文件的接口。因此,如果这个文件包含有一个完整的文件系统,那么这个文件就可以像一个磁盘设备一样被 mount 起来。
这种文件格式,我们经常见到的是 CD 或 DVD 的 ISO 光盘镜像文件或者是软盘(硬盘)的 *.img 镜像文件。通过这种 loop mount (回环mount)的方式,我们可这些镜像文件 mount 到当前文件系统的一个目录下,从而读取镜像中内容。
loop 含义:对于第一层文件系统,它直接安装在我们计算机的物理设备之上;而对于这种被 mount 起来的镜像文件(它也包含有文件系统),它是建立在第一层文件系统之上,这样看来,它就像是在第一层文件系统之上再overlay了一层文件系统,所以称为 loop,而在Linux系统里,用块文件模拟了该接口,Centos上默认有0-7个这样的设备。正常系统
一般显示如下:
1.1.1、处理过程
1、手动新建,执行:
mknod -m 666 /dev/loop0 b 7 0 #实际验证无效
chown :disk /dev/loop0
#附:批量
chown :disk --reference=/dev/loop0 /dev/loop*
2、尝试手动先将镜像装入loop,在挂载loop伪设备
losetup -a #查看当前loop设备使用情况,返回当前已经使用的所有环回设备,即先查看一下哪些是空闲的
sudo losetup -f #自动查找空闲的设备,返回第一个未使用的环回设备
#新建一个loop
dd if=/dev/zero of=test.img bs=5M count=1000 #新建5g的img
losetup /dev/loop0 /opt/CentOS-7-x86_64-DVD-1810.iso
mount /dev/loop0 /opt/yum-iso
#实际等同于
mount -o loop /opt/CentOS-7-x86_64-DVD-1810.iso /opt/yum-iso
mount /opt/CentOS-7-x86_64-DVD-1810.iso /opt/yum-iso -o loop=/dev/loop0
#卸载
umount /opt/yum-iso
losetup -d /dev/loop0
1.1.2、挂在时错误解决
错误1:写保护,将以只读方式挂载
格式化分区:mkfs.ext4 /dev/sdb1
可参考标题2磁盘分区当中的格式化分区操作
重新挂载即可。
错误2:不能读取超块
可进行磁盘修复,如下:
# 磁盘目录:/dev/vdb
fsck.ext3 -B 1024 /dev/vdb
重新挂载即可。
1.2、创建本地repo文件
# 备份原*.repo文件
cp /etc/yum.repos.d/CentOS-Media.repo /etc/yum.repos.d/CentOS-Media.repo.bak
# 编辑repo文件
vim /etc/yum.repos.d/CentOS-Media.repo
输入以下内容,file后面的/yum-iso目录与上节挂载目录保持一致
[ftpYum]
name=ftpYum
baseurl=file:///opt/yum-iso
enabled=1
gpgcheck=0
配置完成后,执行以下命令
# 清除缓存
yum clean all
# 生成新缓存
yum makecache
1.3、 修改yumRepo.py文件
可暂时忽略该步骤,尝试使用yum进行安装尝试看是否成功,若不成功可使用该步骤操作后重试
yum安装测试:yum install ntp -y
根据系统python版本编辑yumRepo.py
vim /usr/lib/pythonx.x/site-packages/yum/yumRepo.py
查找(vim 进入后输入/remote,进行查找,约在1008行)以下内容
remote = url + '/' + relative
# 修改为以下内容
remote = url + '/opt/yum-iso' + relative
重新使用yum安装命令进行测试即可。
2、Linux下局域网yum配置
本例使用Cnetos7示例,其他Linux大致相同,可以参照修改。
2.1、yum服务端应安装以下软件
yum、createrepo、httpd,使用rpm -q httpd createrepo yum
检查是否安装
如果未安装可以使用rpm -ivh
或yum
安装
yum install httpd createrepo -y
2.1.1、开放防火墙80端口或关闭防火墙
可使用默认防火墙firewall或者iptables
firewall 防火墙开放端口
# 开放单个端口
firewall-cmd --zone=public --add-port=8080/tcp --permanent
# 开放多个端口
firewall-cmd --zone=public --add-port=20000-29999/tcp --permanent
# 关闭端口
firewall-cmd --zone=public --remove-port=8080/tcp --permanent
# 重启防火墙
firewall-cmd --reload
# 关闭防火墙
systemctl stop firewalld
# 查看开放端口
firewall-cmd --list-ports
iptables 防火墙开放端口
# 临时开放80端口,重启服务器后无效
iptables -A INPUT -p tcp --dport 80 -j ACCEPT
# 查看端口开放和禁用情况
iptabls -nL
2.1.2、关闭Selinux
# 编辑
vim /etc/selinux/config
将SELINUX=enforcing改为SELINUX=disabled,保存后退出重启系统生效。
2.1.3、配置发布源
本例使用web服务器提供yum安装源的发布功能,也可使用ftp来实现相同功能。
首先安装好apache web服务器(yum install httpd -y
)
在/etc/httpd/conf/httpd.conf
中进行配置(可忽略该步骤)可直接对挂载点建立软连接(且将软连接建立在web服务器的初始目录下)
2.1.3.1、对挂载点建立软连接
# 建立软连接
ln -s /opt/yum-iso/ /var/www/html/centos7
重启httpd服务:
# 重启httpd服务
systemctl restart httpd.service
# 开机自动重启
systemctl enable httpd.service
# 查看状态
systemctl status httpd.service
浏览器验证:http://ip/centos7/
以上图片表示局域网yum源服务端配置成功
2.2、yum源客户端配置
yum源客户端只需要编辑/etc/yum.repos.d/CentOS-Media.repo
文件,将原yum源替换为局域网服务端yum源即可,具体替换为以下内容即可:
vim /etc/yum.repos.d/CentOS-Media.repo
替换为以下内容:
[http]
name=http
baseurl=http://局域网yum源服务端IP/centos7/
gpgcheck=0
enabled=1
使用yum源随便安装个软件测试即可。
Linux下本地yum源配置及局域网yum配置的更多相关文章
- linux配置yum源、mount及yum命令
配置yum源: 在/mnt目录下新建一个空的目录,名为rhel. [root@localhost mnt]# mkdir rhel 然后 [root@localhost Packages]# cd ...
- CentOS7 yum源修改为阿里,配置阿里epel源
镜像下载.域名解析.时间同步请点击 阿里巴巴开源镜像站 一.概念/区分: yum源 什么是yum源: yum是一个在CentOS.RedHat和Fedora操作系统中使用的Shell前端软件包管理器. ...
- Linux下NAT模式和桥接模式的网络配置
Linux下NAT模式和桥接模式的网络配置 最近在配置linux虚拟机的时候发现有很多坑,现在记录下来以防日后又跳到坑里. 我的运行环境是:主机 windows 7 虚拟机 Virtualb ...
- Linux下jdk的安装和环境变量的配置
Linux下jdk的安装和环境变量的配置 一.jdk的下载 方式一:在官网下载 http://www.oracle.com/technetwork/java/javase/downloads/inde ...
- linux下获取软件源码包 centos/redhat, debian/ubuntu
linux下获取软件源码包 centos/redhat, debian/ubuntu centos下: 1. yum install yum-utils 主要为了获取yumdownloader 2. ...
- hadoop搭建杂记:Linux下JDK环境变量的设置(三种配置环境变量的方法)
Linux下JDK环境变量的设置(三种配置环境变量的方法) Linux下JDK环境变量的设置(三种配置环境变量的方法) ①修改/etc/profile文件 如果你的计算机仅仅作为开发使用时推荐使用这种 ...
- linux下svn(subversion)服务端添加工程及配置权限
linux下svn(subversion)服务端添加工程及配置权限 转载请注明源地址:http://www.cnblogs.com/funnyzpc/p/9010507.html 此篇我只是将所做过的 ...
- linux下nginx结合keepalived实现主从切换的配置
linux下nginx结合keepalived实现主从切换的配置 解决方法: 实现一个主nginx宕机,请求转到另一个nginx中. 1.确保两台nginx已启动,假如端口分别是192.168.0 ...
- Centos-7修改yum源为国内的yum源
以centos7为例 ,以 修改为阿里的yum源 1. 备份本地yum源 [root@localhost yum.repos.d]# cp CentOS-Base.repo CentOS-Base.r ...
- linux配置本地yum源实现在局域网中在线安装软件包
安装linux下安装软件需要安装一系列的rpm包,用rpm -ivh xx和yum install xx 如果用rpm安装软件包的时候,需要自己下载rpm安装包,如果rpm包不全总是提示依赖检查失败或 ...
随机推荐
- nginx防盗链接的使用
以 local.hyperf.com为例 nginx配置文件如下 # 至少需要一个 Hyperf 节点,多个配置多行 upstream hyperf { # Hyperf HTTP Server 的 ...
- 三、FreeRTOS学习笔记-系统配置
FreeRTOSConfig.h配置文件作用:对FreeRTOS进行功能配置和裁剪,以及API函数的使能. 系统配置文件中主要是一些宏定义 相关宏定义可分为三类: 1."INCLUDE&qu ...
- .NET9 EFcore支持早期MSSQL数据库 ROW_NUMBER()分页
前言 NET程序员是很幸福的,MS在上个月发布了NET9.0RTM,带来了不少的新特性,但是呢,我们是不是还有很多同学软硬件都还没更上,比如,自己的电脑还在跑Win7,公司服务器还在跑MSSQL200 ...
- highcharts中的环形图
环形图如下效果: 代码: that.options = { chart: { type: 'pie', backgroundColor: 'transparent', color: '#fff', / ...
- python虚拟环境管理之Pipenv
GitHub:pypa/pipenv: Python Development Workflow for Humans. (github.com) 介绍: pipenv就是把pip和virtualenv ...
- 【架构】整理了一份通用的MVP框架示例代码
最近回顾了一下MVP框架,结合阅读到的几篇不错的博客,自己整理了一份可用于实际工作的MVP框架示例代码,这里做个记录,也顺便和网友们分享一下. 代码示例演示的是一个输入员工号查询员工信息并显示的场景, ...
- Navicat Premium16激活码,亲测有效,安装及注册激活最全图文教程
前言: 网上的破解套路很雷同,但是目前官网下载的Navicat Premium16软件包已经修复了永久激活的bug(流传的激活方式不行了),这里提供未更新前的软件安装包(可以永久激活). 一.下载安装 ...
- uni-app UI效果封装
1.UI效果 2.操作提示 因为此元素背景色是白色,推荐将页面背景色设置为#f8f8f8 <view class="operation-tip">请扫描设备号</ ...
- 西门子PLC与上位机通信方案梳理
一.前言 大家好!我是付工. 西门子PLC是工控领域使用非常多的一种PLC品牌,对于上位机开发人员来说,对于西门子PLC的通信,我们一般可以采取哪些通信方式呢? 今天跟大家分享一下上位机实现与西门子P ...
- CVE-2023-32233 Linux 内核 UAF 漏洞分析与利用
Linux 内核 nftable 模块在处理匿名 set 时存在 UAF. 漏洞分析 漏洞成因是 nf_tables_deactivate_set 在释放匿名 set 时没有将 set 的标记设 ...