yum仓库及NFS共享

这篇具有很好参考价值的文章主要介绍了yum仓库及NFS共享。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

一、yum仓库

(一)yum仓库简介

(二)实现过程

(三)yum命令

(四)搭建内网yum仓库

1.FTP服务搭建yum仓库

①服务端操作

②客户端操作

2.http服务搭建yum仓库

①服务端操作

②客户端操作

二、NFS文件共享

(一)NFS基本信息

(二)实验操作

1.创建共享目录

2.启动服务

3.配置NFS客户端

4.使用权限

(三)搭建一台NFS共享服务器

1.服务端开启NFS服务

2.创建共享文件

3.挂载使用


一、yum仓库

(一)yum仓库简介

Yum仓库(Yum Repository)是基于RPM包管理的Linux操作系统中用于存储和管理软件包的一个集中式资源库。在使用yum作为包管理器的系统(如CentOS、RHEL等)中,用户可以方便地通过yum工具从预先配置好的仓库中搜索、安装、更新或卸载软件包。

主要特点:

自动解决依赖关系: 相对于rpm来说,当用户尝试安装某个软件包时,yum会自动分析该软件包的依赖关系,并从仓库中下载所有必需的依赖包,确保软件能够正确安装和运行。

版本管理和更新: yum仓库中维护着软件包的不同版本,可以根据策略选择安装最新的稳定版或者指定特定版本的软件包。此外,yum还提供软件更新功能,可以检测并自动升级系统中的过期软件包到最新可用版本。

多个仓库支持: 用户可以在系统中配置多个yum仓库,这样可以从不同的来源获取软件包,例如官方仓库、社区仓库、私有仓库等。

GPG签名验证: yum支持对仓库内容进行GPG签名验证,以确保从仓库下载的软件包未被篡改和保证其来源可信。

缓存机制: yum具有本地缓存功能,它可以将已下载过的软件包元数据和文件保存在本地,从而提高后续操作的速度,减少网络传输。

(二)实现过程

先在yum服务器上创建 yum repository(仓库),在仓库中事先存储了众多rpm包,以及包的相关的元数据文件(放置于特定目录repodata下),当yum客户端利用yum/dnf工具进行安装时包时,会自动下载repodata中的元数据,查询远数据是否存在相关的包及依赖关系,自动从仓库中找到相关包下载并安装。

yum实现安装服务的过程

yum仓库及NFS共享,服务器,网络,运维

查看yum的配置文件

yum仓库及NFS共享,服务器,网络,运维

[main]     #全局配置
cachedir=/var/cache/yum/$basearch/$releasever
#这行定义了yum下载和存储软件包元数据以及临时文件的缓存目录位置。其中 $basearch 表示系统的基本架构(如x86_64、i386等), $releasever 表示操作系统的发行版版本号。
keepcache=0
#当设置为0时,表示在安装或更新软件包后自动清理缓存中的软件包文件。如果改为1,则会保留所有已下载的软件包文件。
debuglevel=2
#设置yum运行时的调试级别。数字越高,输出的日志信息越详细。
logfile=/var/log/yum.log
#指定yum日志文件的位置,所有yum的操作记录都会写入这个文件。
exactarch=1
#当值为1时,yum将只安装与系统架构精确匹配的软件包。
obsoletes=1
#启用此选项意味着yum在执行更新操作时,会处理那些可能使其他已安装软件包变得过时(obsolete)的新软件包。
gpgcheck=1
#如果设置为1,yum会在安装软件包前验证其签名,确保软件包来源可信且未被篡改。
plugins=1
#启用yum插件功能,允许通过插件扩展yum的功能。
installonly_limit=5
#限制yum保留的最大旧版本数量,对于某些只能安装一个实例的软件包,yum最多只会保留最近的5个旧版本。
bugtracker_url=http://bugs.centos.org/set_project.php?project_id=23&ref=http://bugs.centos.org/bug_report_page.php?category=yum
#提供了一个链接地址,当遇到yum相关的问题时,可以提交bug报告到CentOS官方的bug追踪系统。
distroverpkg=centos-release
#定义了用来检测和确定当前操作系统版本的关键软件包名称,对于CentOS系统来说,就是centos-release包。

这里的配置文件基本默认就可以,不需要我们去修改

(三)yum命令

yum repolist all 列出所有仓库
yum list all 列出仓库中所有软件包
yum  info  软件包名称 查看软件包信息
yum  install  软件包名称 安装软件包
yum reinstall 软件包名称 重新安装软件包
yum update 软件包名称 升级软件包
yum remove  软件包 移除软件包
yum clean all 清除所有仓库缓存
yum check-update 检查可更新的软件包
yum grouplist 查看系统中已经安装的软件包组
yum groupinstall 软件组 安装指定的软件包组
yum groupremove 软件包组 移除指定的软件包组
yum groupinfo 软件包组 查询指定的软件包组信息
yum remove 卸载具体软件
yum provides 精确查找
yum history 查看当前yum操作历史
yum history undo 加入序号卸载序号里安装的软件
yum history redo 加入序号重新执行序号里的操作

(四)搭建内网yum仓库

服务端 192.168.83.30
客户端     192.168.83.40                    

检查两台机器防火墙与核心防护是否关闭,如果没有关闭执行systemctl  stop  firewalld   与setenforce  0 命令

yum仓库及NFS共享,服务器,网络,运维

1.FTP服务搭建yum仓库

①服务端操作

下载vsftpd软件,提供服务 :yum  install vsftpd  -y

yum仓库及NFS共享,服务器,网络,运维

开启vsftpd服务:systemctl  start  vsftpd

yum仓库及NFS共享,服务器,网络,运维

在ftp程序用户的家目录下新建一个目录

yum仓库及NFS共享,服务器,网络,运维

将光盘挂载到新建目录,为ftp用户提供安装包

yum仓库及NFS共享,服务器,网络,运维

②客户端操作

切换到yum程序目录:cd  /etc/yum.repos.d而后,创建一个目录mkdir  kysw

而后将yum的相关文件移动到新建目录中,防止信息干扰mv *.repo   kysw

yum仓库及NFS共享,服务器,网络,运维
新建一个仓库文件,以.repo结尾:vim  ftp.repo

yum仓库及NFS共享,服务器,网络,运维

[ftp]                                #仓库描述
name=ftp                             #仓库名称
baseurl=ftp://192.168.83.30/kysw     #安装包来源。通过ftp服务,连接到192.168.83.30
                                      的服务端.IP地址后面的“/”。相当于ftp程序用户的
                                      家目录/var/ftp
gpgcheck=0                           #不启用验证。0为不启用,1为启用

#gpgkey=file://公钥文件地址           #若启用验证需要指定公钥文件地址         

清理缓存、下载元信息:yum  clean all  &  yum  makecache

yum仓库及NFS共享,服务器,网络,运维

yum  install  tree  -y  验证一下

yum仓库及NFS共享,服务器,网络,运维

2.http服务搭建yum仓库

①服务端操作

下载httpd服务软件,yum  install httpd  -y  并开启

yum仓库及NFS共享,服务器,网络,运维

在/var/www/html/下新建一个文件夹,并将光盘挂下到该目录下mkdir   /var/www/html/http

yum仓库及NFS共享,服务器,网络,运维

②客户端操作

操作流程与FTP服务搭建yum仓库基本一致

切换到yum程序目录:cd  /etc/yum.repos.d而后,创建一个目录mkdir  http

而后将yum的相关文件移动到新建目录中,防止信息干扰mv *.repo   http

yum仓库及NFS共享,服务器,网络,运维

新建一个仓库文件,以.repo结尾:vim http.repo

yum仓库及NFS共享,服务器,网络,运维

注释:这里的baseurl信息中的IP地址后面的"/"就是/var/www/html,其它信息与ftp服务搭建yum仓库一致

清理缓存、下载元信息:yum  clean all  &  yum  makecache

yum仓库及NFS共享,服务器,网络,运维

下载软件验证一下  

yum仓库及NFS共享,服务器,网络,运维

二、NFS文件共享

早期网络想要在不同主机之间共享文件大多要用 FTP 协议来传输,但FTP 协议仅能做到传输文件却不能直接修改对方主机的资料数据,这样确实不太方便,于是便出现了NFS 开源文件共享程序:NFSINetworkFile Svstem)是一个能够将多台Linux 的远程主机数据挂载到本地目录的服务,属于轻量级的文件共享服务,不支持Linux与 Windows 系统间的文件共享

(一)NFS基本信息

NFS(Network File System)是一种分布式文件系统协议,允许网络中的不同计算机之间共享和访问文件资源。在Linux环境中,通过配置NFS服务,可以将一台服务器上的目录作为共享资源提供给其他客户端挂载和使用,实现跨主机的文件共享。

实现过程:

NFS 服务的实现依赖于 RPC(Remote Process Call,远端过程调用)机制,通过使用 NFS 协议,客户机可以像访问本地目录一样访问远程服务器中的共享资源。(远端过程调用:自己没有这种功能,调用别人的功能)

NFS 也是 NAS 存储 设备必然支持的一种协议 以完成远 程到本地的映射过程。在 CentOS 7 系统中,需要 nfs-utils、rpcbind 软件包来提供 NFS 共享服务, 前者用于 NFS 共享发布和访问,后者用于 RPC 支持。

手动加载 NFS 共享服务时,应该先启动 rpcbind,再启动 nfs

(二)实验操作

准备两台机器

NFS服务端 192.168.83.30
NFS客户端     192.168.83.40                    

在centos7中,NFS服务的工具是默认安装了的

yum仓库及NFS共享,服务器,网络,运维

1.创建共享目录

先创建连个文件夹,在输入一些内容供NFS客户端读取

yum仓库及NFS共享,服务器,网络,运维

修改配置文件,定义要共享的目录及相应权限

这个配置文件位置在/etc/exports

配置内容格式为:共享目录    可以访问的主机地址(权限)

权限分类有以下几种

参数 作用
ro 只读模式(默认)
rw 读写模式
root_squash 当NFS 客户端使用 root 用户访问时,映射为 NFS 服务端的匿名用户
no_root_squash 当NFS客户端使用 root 用户访问时,映射为NFS 服务端的 root 用户
all_squash 不论 NFS 客户端使用任何帐户,均映射为 NFS 服务端的匿名用户
sync 同时将数据写入到内存与硬盘中,保证不丢失数据。
async 优先将数据保存到内存,然后再写入硬盘,效率更高,但可能造成数据丢失

下面我们来编辑配置文件,添加以下内容

yum仓库及NFS共享,服务器,网络,运维

2.启动服务

配置好文件后启动服务和配置文件

yum仓库及NFS共享,服务器,网络,运维

3.配置NFS客户端

客户端如果也是centos7的话,那么应该也是安装了nfs-utils工具包的(字符界面可能需要手动安装),直接挂载共享就可以了

挂载之前,先使用jshowmount 命令查看以下服务端的共享信息

-a :显示 NFS 服务端的共享列表
-e:显示本机挂载 NFS 资源的情况
-v:显示版本号

yum仓库及NFS共享,服务器,网络,运维

下一步,我们来进行挂载

使用mount命令

mount   对方IP地址:共享文件夹    挂载点

yum仓库及NFS共享,服务器,网络,运维

非指定用户是无法使用共享文件的

yum仓库及NFS共享,服务器,网络,运维

如果想永久挂载需要写道/etc/fstab文件中

yum仓库及NFS共享,服务器,网络,运维

192.168.83.30:/data           /opt             nfs                  defaults     _netdev           0            0
#IP地址:/共享文件名       #挂在点       #文件类型      #权限         #没网不加载   #不备份  #不检查

4.使用权限

此时,我们是有读写权限的

yum仓库及NFS共享,服务器,网络,运维

但是,我们创建文件的时候为什么还会显示失败呢?

那是因为对/data文件目录还没有权限。之前在介绍FTP服务的时候说过,我们的服务已经添加了相应的权相,但是对文件本身还没有权限,虽然我们是在客户端的root用户,但是,我们现在访问的是服务端的文件夹,root用户的超级管理员身份在服务端并没有效果,所以,还需要修改一下服务端的文件的权限

yum仓库及NFS共享,服务器,网络,运维

现在再去客户端创建文件就可以了

yum仓库及NFS共享,服务器,网络,运维

我们又发现,创建的文件属主和属组是一个陌生的用户nfsnobody,这就是之前说的

root_squash权限:当NFS 客户端使用 root 用户访问时,映射为 NFS 服务端的匿名用户

细心的人,在启动服务的时候就会发现后面有一排的权限

yum仓库及NFS共享,服务器,网络,运维

如何创建文件属主为root用户呢?很简单,修改一下权限就可以了

yum仓库及NFS共享,服务器,网络,运维

保存退出后需要重新加载一下配置文件,如果直接重启服务的话,正在操作的用户可能会中断,所以我们需要用exprotfs  -r  命令来刷新文件

yum仓库及NFS共享,服务器,网络,运维

可以看到,配置权限已经生效了,这个时候再来创建文件试试看

yum仓库及NFS共享,服务器,网络,运维

可以看到新建的文件属主还是root

那么如何将所有客户端新建文件都指定一个用户呢,需要设置anonuid和anongid权限

指明匿名用户映射为特定用户UID和组GID,而非nobody,可配合all_squash使用

首先在服务端上新建一个用户并指定uid号

yum仓库及NFS共享,服务器,网络,运维

修改配置文件,并刷新使其生效

yum仓库及NFS共享,服务器,网络,运维

这个时候我们再去创建文件

yum仓库及NFS共享,服务器,网络,运维

我们在服务端查看就可以发现,文件属主就是指定的用户

yum仓库及NFS共享,服务器,网络,运维

(三)搭建一台NFS共享服务器

准备三台机器

NFS服务端 192.168.83.30
NFS客户端 192.168.83.40
NFS客户端 192.168.83.20

开始实验之前,还是确定防火墙和核心防护是否关闭,如果没有关闭需要手动关闭

1.服务端开启NFS服务

yum仓库及NFS共享,服务器,网络,运维

2.创建共享文件

先创建一个共享文件夹,再去写配置文件yum仓库及NFS共享,服务器,网络,运维

添加一些内容供客户端读取

yum仓库及NFS共享,服务器,网络,运维

在这里注意修改文件夹权限:chmod   777  /data

配置完后刷新一下配置文件

yum仓库及NFS共享,服务器,网络,运维

在另外两台机器上下载并开启httpd服务

yum仓库及NFS共享,服务器,网络,运维

yum仓库及NFS共享,服务器,网络,运维

3.挂载使用

yum仓库及NFS共享,服务器,网络,运维

yum仓库及NFS共享,服务器,网络,运维

这个时候再去访问这两个网址就会得到相同的NFS服务器上的信息

yum仓库及NFS共享,服务器,网络,运维文章来源地址https://www.toymoban.com/news/detail-794798.html

到了这里,关于yum仓库及NFS共享的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • centos中安装nfs实现服务器文件共享

    如果一个服务使用集群方式部署,在文件读写时就需要考虑多个服务之间文件共享的问题,在共享文件时可以考虑部署一个单独的文件服务器,比如hdfs、minio、fastdfs等,也可以使用简单的文件目录共享方式实现,比如nfs。下面就介绍nfs简单安装使用: 一、nfs服务端安装 nfs服

    2024年01月22日
    浏览(36)
  • Linux - 进阶 NFS 服务器 NFS文件权限与共享目录权限主次问题

            #    NFS 的权限本身没有用户密码和账户验证登录过程               ( 你可以回忆下,我们前面访问远程共享目录的时候,是没有输入账户,密码啥的,是没                 有这个步骤的)              所以客户端登录到服务器后,会把客户端的

    2024年02月04日
    浏览(36)
  • haproxy服务器对nginx服务器web服务调度负载均衡、用nfs做共享目录(脚本部署)

    目录 一、准备 二、在作为haproxy的服务器上导入以下shell执行haproxy安装 三、由于nginx服务需要用的nfs共享目录,先部署nfs 四、nginx服务器1部署 五、nginx服务器2部署同上 六、测试 一、准备 四台服务器 系统 IP 搭建服务器 centos7 192.168.1.12 haproxy centos7 192.168.1.132 nfs(rpcbind) ce

    2024年02月09日
    浏览(35)
  • 【操作系统】Centos7搭建nfs文件共享服务器实战

    1.NFS介绍 2.环境准备 3.在A服务端机器安装nfs-utils和rpcbind包 4.启动rpcbind检查是否启动了rpcbind服务并监听111端口 5.配置NFS服务的配置文件,参数配置:vi /etc/exports 数据同步与数据异步的区别 数据同步:当系统从内存中向磁盘中持久化数据时,同步发送表示只有当内存中的数据

    2024年02月07日
    浏览(44)
  • Proxmox VE进行磁盘分区并配置NFS服务器实现文件共享

    有2个服务器,服务器都是PVE8.1,并处于一个集群中。为了节约空间,想在服务器A中配置一个NFS服务器实现文件共享。现在服务器A有一个500G的盘,分出400G用来当共享文件夹。 查看设备挂载情况  发现500G盘为 /dev/sdd 或者通过GUI查询 使用 fdisk /dev/sdd 开始分区 分区完成    P

    2024年01月22日
    浏览(42)
  • 自建mysql的yum服务器+本地仓库分发

    1.安装FTP 2.准备ftp主目录 3.官网下载yum仓库的包 mysql repo官网 4.仅下载不安装mysql 5.把下载的mysql安装包复制到 /var/ftp/mysql80下面 6.创建依赖关系 另外再开一台虚拟机作为客户端操作 1.自建yum仓库 2.清空yum源 更新yum源 可以看到mysql80 yum仓库已经建好并可以使用了 3.安装mysql5.7试

    2024年02月13日
    浏览(30)
  • UOS服务器操作系统搭建离线yum仓库

    首先需要有everything镜像文件 服务端操作流程 1、挂载everything镜像并同步 2、配置本地仓库 3、配置nginx发布离线源 客户端端操作流程

    2024年01月16日
    浏览(37)
  • NFS客户端挂载nfs服务器共享目录时的报错及解决办法:mount.nfs: access denied by server while mounting

    客户端挂载nfs共享目录时的报错信息:mount.nfs: access denied by server while mounting 192.168.41.191:/nfsfile NFS服务器 1、我原来nfs配置文件exports里面的内容如下 2、重启rpcbind和nfs-server服务;查看了一下nfs-server服务,上面显示“Active: active (exited) \\\",意思是“活动:活动(已退出)”,这是

    2024年02月05日
    浏览(36)
  • 在 CentOS 7上创建本地 YUM 仓库,并且提供给其它服务器做yum源

    在 CentOS 7.6 上创建本地 YUM 仓库的步骤如下: 上传 CentOS 镜像文件 : 确保你已经将 CentOS 7.6 的 ISO 镜像文件上传到了服务器上。例如,假设你已经上传到 /path/to/your/iso 路径。 挂载 ISO 镜像 : 你需要将 ISO 镜像文件挂载到一个目录中,以便访问其中的内容。例如,创建一个挂

    2024年02月01日
    浏览(45)
  • NFS网络共享服务存储

    目录 一、NFS简介 1、NFS定义: 2、NFS的特点 3、NFS的优缺点 4、NFS的原理图示 二、服务端NFS配置文件:/etc/exports 三、实验:NFS共享存储服务配置 1、服务端安装nfs-utils与rpcbind软件包 2、服务端新建共享文件夹目录并赋予权限 3、服务端编辑配置文件/etc/exports:设置共享目录的相关

    2024年01月17日
    浏览(27)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包