yum仓库和NFS文件共享服务

一、yum仓库简介:

1.yum仓库简介:

yum是一个基于RPM包(是Red-Hat Package Manager红帽软件包管理器的缩写)构建的软件更新机制,能够自动解决软件包之间的依赖关系。解决了日常工作中的大量查找安装依赖包的时间 为什么会有依赖关系的发生 因为linux本身就是以系统简洁为自身优势,所以在安装操作系统的时候并没有将所有的库文件以及编译软件包进行安装,所以在linux操作系统上进行软件安装的时候会出现软件包依赖的情况。

yum由仓库和客户端组成,也就是整个yum由两部分组成,所以yum可以存放在两台服务器上。也可以存放在一台服务器上。可以有官方来提供服务,也可以由第三方来提供,比如国内的阿里云,搜狐云,还有一些非盈利组织比如学校等。官方的源一般在国外,下载速度肯定有限,手动更改成国内的云可以大幅提升下载速度。

要成功使用 YUM 机制来更新系统和软件,需要有一个包含各种 rpm 安装包文件及其依 赖软件的软件仓库(repository),提供软件仓库的服务器也称为“源”服务器。在客户机中只 要正确指定软件仓库的地址等信息,就可以通过对应的“源”服务器来安装或更新软件。

2.yum实现过程:

1.要有安装包

安装包:  光驱里自带       挂载提供软件包

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

2.yum需要依赖于环境,依赖于服务端和客户端,允许跨网络

服务器:

  • RPM包 (Packages文件夹中)

  • 元数据(repodata文件夹:目录(软件的目录),软件的依赖关系,软件的位置)

客户端的配置文件:

baseurl=地址   一定要写到到   这两个文件夹 repodata  packages  的上级目录 

最终形成两个文件夹Packages (包文件夹一般取名packages)和  repodata(元数据文件夹)

仓库类型:

- 光盘的仓库基本仓库   比较常用的
- epel扩展仓库             比较新   

3.如何实现安装服务:

元信息是一个文件 里面记录了安装包的路径  安装包的依赖关系

  1. 客户端根据配置文件找到服务端
  2. 客户端将元信息下载到本地仓库(元信息:安装包的位置,以及安装的依赖关系)
  3. 根据元信息去下载对应的安装包到本地后,然后安装
  4. 安装完成后再删除安装包

二、yum配置文件及命令:

1.yum配置文件:

1.1主配置文件:

主配置文件 : /etc/yum.conf

[root@localhost]#vim /etc/yum.conf
[main]
cachedir=/var/cache/yum/$basearch/$releasever 
//yum下载的RPM包的缓存目录 $basearch代表硬件架构 $releasever系统版本比如7
keepcache=0                        //是否保存缓存  0代表不保存,1代表保存
debuglevel=2                       //调试级别
logfile=/var/log/yum.log		   //日志文件位置
exactarch=1						   //是否允许不同版本的rpm安装
obsoletes=1						   //update 的一个参数是否可以允许旧版本的运行	
gpgcheck=1                         //验证秘钥
plugins=1                          //是否允许插件1代表可以
installonly_limit=5                //保存几个内核 5代表5个
bugtracker_url=http://bugs.centos.org/set_project.php?project_id=23&ref=http://bugs.centos.org/bug_report_page.php?category=yum
distroverpkg=centos-release
 
yum的repo配置文件中可用的变量:
$basearch:系统基础平台;i386, x86_64
$releasever: 当前OS的发行版的主版本号,如:8,7,6
$arch: CPU架构,如:aarch64, i586, i686,x86_64等
$contentdir:表示目录,比如:centos-8,centos-7
$YUM0-$YUM9:自定义变量

1.2仓库设置文件:

位置:/etc/yum.repos.d/*.repo     //yum仓库文件位置

1.3日志文件:

位置:/var/log/yum.log                  //日志文件

2.yum命令详解:

命令 不加关键字 加入关键词、软件包、软件包组
yum list 显示所有可用包 单个的可安装包
yum info 显示所有可用包的信息 单个具体的信息
yum search 模糊查找所有的相关信息
yum provides 精确查找
yum grouplist 显示所有可用包组 显示具体的包组
yum groupinfo 显示所有的包组具体信息 显示具体的包组的具体信息
yum install 安装具体软件包
yum groupinstall 安装具体软件包组
yum update 所有软件升级 具体软件升级
命令 不加关键字 加入关键词、软件包、软件包组
yum group update 所有包组升级 具体包组升级
yum remove 卸载具体软件
yum groupremove 卸载具体包组软件
yum history 查看当前yum操作历史
yum history undo 加入序号卸载序号里安装的软件
yum history redo 加入序号重新执行序号里的操作

2.1查询:

2.1.1 yum list [软件名]

显示可用的安装包,如不加软件名是显示所有的可用包

#包含httpd 的软件包

2.1.2 yum info [软件名]:

显示安装包详细信息,详情如下

 2.1.3 yum search <关键词>

根据关键字查找软件安装包,相当于你只知道这个包里的某个关键字会全部给你匹配出来

2.1.4 yum provides <关键词>:

  你知道某个命令却不知道具体的包可以用此命令查找

2.1.5 yum grouplist [包组名]:

安装包组的查询 不加包组名 就是显示所有

2.1.6  yum groupinfo  <包组名>:

不加包组名显示全部

 

2.2 yum安装升级:

2.2.1 yum install [软件名]:

安装软件包,如例子yum install安装http服务

2.2.2  yum groupinstall <包组名>:

包组安装同yum install

2.2.3  yum update:

更新包组,可以单个也可以全部 后面加具体包组名称就是单个更新,不加就是全部更新。

但是首先你要有更新的包组库否则也无法更新。

2.2.4 yum groupupdate:

组包更新和单个安装包更新

2.3 软件卸载:

2.3.1 yum remove <软件名>:

卸载已安装的软件必须加软件名

 

2.3.2  yum groupremove <包组名>:

同软件包卸载不做赘述

2.3.3 yum history:

查看历史的使用记录

2.3.4 yum history undo

加入序号卸载序号里安装的软件

可以使用yum history undo 4 进行卸载,这样对比remove好处是可以将所有的依赖都删除

如果后悔卸载可以使用两种方式

yum history redo 4 (重新安装一遍)

yum history undo 4 (反悔卸载等于重新安装一遍)

三、搭建仓库的方式:

软件仓库的提供方式:

FTP服务:ftp://ip地址/站点里路径

HTTP服务:http://域名或者ip地址/站点里的路径

本地目录:file://绝对路径 (file:///mnt 此处第三个/为根目录)

1.搭建本地yum仓库

  1.  首先将光驱中的镜像文件进行挂载
  2.  切换到yum.repo.d 目录下,将自带的仓库移走,因为多个开启仓库文件可能会造成冲突
  3.  新建yum仓库文件
  4.  测试

yum仓库配置

测试查看

 2.搭建阿里云仓库:

 

#小火车
[root@centos7 ~]#yum -y install epel-release
[root@centos7 ~]#yum -y install sl
[root@centos7 ~]#sl -a

#牛
[root@localhost ~]#yum install -y install cowsay
[root@localhost ~]#cowsay hello
 

 3.ftp方式搭建云仓库:

 服务端:

安装软件

开启服务

挂载

客户端:

客户端:

检验

4.http 方式搭建:

服务端:

下载

开启服务

挂载

客户端:

校验:

四、网络文件服务——NFS:

1.NFS简介:

NFS(Network File System 网络文件服务)

NFS(Network File System 网络文件服务) 文件系统(软件)文件的权限

NFS 是一种基于 TCP/IP 传输的网络文件系统协议,最初由 Sun 公司开发。

通过使用 NFS 协议,客户机可以像访问本地目录一样访问远程服务器中的共享资源 NFS 也是 NAS 存储 设备必然支持的一种协议

不支持默认windows

特点:

采用TCP/IP传输网络文件

安全性低

简单易操作

适合局域网环境

2.NFS原理:

NFS 它是文件系统,是操作系统内核来管理的

NFS优势:节省本地存储空间,将常用的数据如:/home 目录,存放在NFS服务器上且可以通过网络访问,将减少本地磁盘的使用率。  

通过rpcbind远程功能调用

systemctl start nfs——启动nfs服务

nfs-ustils——nfs主包

3. NFS软件介绍:

软件包:nfs-utils(包括服务器端和客户端)

相关软件包:rpcbind(必须)

nfs端口号不固定 RPC端口号111

NFS服务主要进程:

  • rpc.nfsd 最主要的NFS进程,管理客户端是否可登录

  • rpc.mountd 挂载和卸载NFS文件系统,包括权限管理

  • rpc.lockd 非必要,管理文件锁,避免同时写出错

  • rpc.statd 非必要,检查文件一致性,可修复文件

日志:/var/lib/nfs/

4. NFS配置文件:

/etc/exports——主配置文件

/etc/exports.d/*.exports

exportfs -v ——显示本机服务端的共享目录

exportfs -r ——重新加载配置文件

文件格式—— 共享目录 主机(权限)

软件名   —— nfs-utils

依赖软件 —— rpcbind

重启服务 ——systemctl restart nfs

重新加载配置—— exportfs -r

显示当前配置 ——exportfs -v

客户端显示服务端——ip showmount -e 服务端ip地址

临时挂载 ——mount 服务端ip:共享目录 挂载点

永久挂载 vim /etc/fstab 服务端ip:共享目录 挂载点 文件系统类型(nfs) 权限 _netdev 0 0

5. NFS共享配置文件格式:

文件格式:

共享目录       可以访问的主机地址(权限)

/share            *()

实验:

服务端配置:

 

 客户端配置:


 检验: 

服务端新建文件:

切换到客户端查看文件是否有:

 6.NFS权限配置:

在服务端给客户端添加权限:

在客户端 检验:

 

服务端查看

因为客户端使用root用户访问时,映射为服务端的匿名用户

 创建文件属主为root用户 ??

修改配置文件: 

 

rw    —— 表示允许读写,ro  表示为只读
sync   —— 表示同步写入到内存与硬盘中
no_root_squash    —— 表示当客户机以root身份访问时赋予本地root权限(默认是root_squash)
root_squash   ——  表示客户机用root用户访问该共享目录时,将root用户映射成匿名用户
all_squash    ——所有访问用户都映射为匿名用户或用户组
async    ——将数据先保存在内存缓冲区中,必要时才写入磁盘
subtree_check(默认)   —— 若输出目录是一个子目录,则nfs服务器将检查其父目录的权限
no_subtree_check    ——即使输出目录是一个子目录,nfs服务器也不检查其父目录的权限,这样可以提高效率
anonuid和anongid   —— 指明匿名用户映射为特定用户UID和组GID,而非nobody,可配合all_squash使用

7.工作环境:

7.1误将 rpm 软件删除:

进入急救模式

1 继续

切根

7.2 自行打包后建立元数据:

mount /dev/sr0 /mnt/
cp  /mnt/Packages/tree-1.6.0-10.el7.x86_64.rpm 
mkdir test
mv tree-1.6.0-10.el7.x86_64.rpm  test/
cd test
mkdir packages
mv tree-1.6.0-10.el7.x86_64.rpm packages/
createrepo -v test
cd /etc/yum.repos.d/
mkdir bak
mv *.repo bak/

vim tree.repo
[tree]
name=tree
baseurl=file:///data/test
gpgcheck=0

yum clean all
yum makecache
yum install tree -y

7.3 epel源 本地:

[root@localhost ~]#yum install epel-release
#安装epel源    生成epel仓库文件
[root@localhost ~]# reposync -r epel -p /root/
#下载同步epel源  根据epel仓库文件去找目录

[root@localhost ~]# yum -y install createrepo
#安装建立元数据命令
[root@localhost ~]# createrepo -v /root/epel
#建立元数据    软件目录  依赖关系  
[root@localhost ~]# ls
anaconda-ks.cfg  epel
[root@localhost ~]# cd epel/
[root@localhost epel]# ls
#查看元数据

7.4 离线安装软件

 

8.扩展:

8.1exportfs  用于管理NFS导出的文件系统 

选项:

选项 说明
-v 查看本机所有NFS共享
-r 重读配置文件,并共享目录
-a 输出本机所有的共享
-au 停止本机所有共享

8.2showmount  显示NFS服务器加载的信息:

-e 显示服务器上所有的共享目录

 8.3 mount.nfs:NFS 相关的挂载选项

fg         #(默认)前台挂载
bg       #后台挂载
hard    #(默认)持续请求
soft     #非持续请求
intr     #和hard配合,请求可中断
rsize  #和wsize 一次读和写数据最大字节数,rsize=32768
_netdev  #无网络连接不挂载
vers     #指定版本,客户端centos8默认4.2 ,centos7默认4.1 centos6默认4.0

mount -o  临时挂载

在 /etc/fstab 里面开机挂载