一、yum库

1.yum概述

YUM (Yellow dog Updater Modified)是一个在Fedora和RedHat以及CentOS中的Shell前端软件包管理器。基于RPM包管理,能够从指定的服务器自动下载RPM包并且安装,可以自动处理依赖性关系,并且一次安装所有依赖的软件包,无须繁琐地一次次下载、安装。

基于RPM包构建的软件更新机制

可以自动解决依赖关系

所有软件包由集中的YUM软件仓库提供

在centos8中yum改为apt

YUM库及NFS共享服务_优先级

2.准备安装

1.软件仓库的提供方式

FTP服务: ftp:// ....

HTTP服务:http://......

本地目录: file://...

2.RPM软件包的来源

  • Centos发布的RPM包集合
  • 第三方组织发布的RPM包集合
  • 用户自定义的RPM包集合

3.构建FTP yum仓库

RPM包来自Centos 7 DVD光盘

通过FTP方式提供给客户机

在软件仓库中加入官方RPM包组

包括存在依赖关系的所有RPM包

使用createrepo工具建立仓库数据文件

为客户机指定YUM仓库位置

配置文件:/etc/yum.repos.d/centos7.repo

3.yum仓库安装

本地YUM源    baseurl=file://               只能给本机使用软件仓库
ftpYUM源 baseurl=ftp://FTP服务器地址/软件目录 能给所有能连接此ftp服务器的用户使用(注意要关闭防火墙)
在线YUM源 baseurl=http:// 通过网络在线使用软件
https://
在nfs服务器中使用LVM或者raid5设备挂载到/data目录上。用NFS服务

1.本地yum仓库

YUM库及NFS共享服务_NFS服务_02

YUM库及NFS共享服务_NFS服务_03

2.ftp yum仓库

服务主机

YUM库及NFS共享服务_服务器_04

YUM库及NFS共享服务_NFS服务_05


YUM库及NFS共享服务_NFS服务_06

YUM库及NFS共享服务_yum仓库_07

YUM库及NFS共享服务_yum仓库_08

YUM库及NFS共享服务_yum仓库_09

YUM库及NFS共享服务_服务器_10

服务主机

YUM库及NFS共享服务_NFS服务_11

其他主机 客户端

YUM库及NFS共享服务_NFS服务_12

YUM库及NFS共享服务_NFS服务_13

3.在线的yum仓库

第一步:将我们创建的local.repo文件移动到bak目录下(也可以是别的备份目录)
第二步:将可以连外网的系统打开,执行wget -O /etc/yum.repos.d/CentOS-Base.repo
https://mirrors.aliyun.com/repo/Centos-7.repo 将阿里云镜像下载到/etc/yum.repos.d/目录下
第三步:刷新缓存, yum claen all && yum makecache 清理缓存并且生成新的缓存

然后就可以直接用阿里云仓库里的软件包安装文件了,都是最新的软件包,但是必须有网的环境下才可以使用。
如果想在没有网的情况下也能使用yum仓库里的软件,就需要将阿里云仓库下载到本地,占用空间较高,

YUM库及NFS共享服务_yum仓库_14

4.yum仓库优先级

当既有本地yum源又有aliyun源的时候,我们在装软件包的时候当然希望先用本地的yum源去安装,

本地找不到可用的包时再使用aliyun源去安装软件,这里就涉及到了优先级的问题,

yum提供的插件yum-plugin-priorities.noarch可以解决这个问题

1.查看是否安装了yum-plugin优先级插件
rpm -qa |grep yum-plugin-
2.如果没有安装,就安装插件
yum -y install yum-plugin-priorities.noarch
3.查看插件是否启用
cat /etc/yum/pluginconf.d/priorities.conf
[main]:
enabled = 1 1为启动,0 为禁止
4.修改本地yum源优先使用
vi local.repo
[local]
name=local
baseurl=file:///mnt/
enabled=1
gpgcheck=1
priority=1 #数字越小优先级越高

[epel]
baseurl=https://mirrors.aliyun.com/epel/7Server/x86_64/
enabled=1
gpgcheck=0
priority=2

YUM库及NFS共享服务_NFS服务_15

YUM库及NFS共享服务_yum仓库_16

YUM库及NFS共享服务_NFS服务_17

YUM库及NFS共享服务_服务器_18

验证安装包的数量

执行yum repolist all 可显示所有仓库包

YUM库及NFS共享服务_yum仓库_19

5.yum工具

yum命令仅下载
方式一:
yum install --downloadonly mariadb
下载下来的安装包都是放在 /var/cache/yum/x86_64/7/ 目录下

方式二:
yumdownloader --destdir=/opt mariadb mariadb-server
yumdownloader 仅下载指定软件包,参数 --destdir 是用来指定存放下载的安装包的目录

YUM库及NFS共享服务_服务器_20

查询  yum list [软件名]   yum info [软件名]  yum search<关键词>  yum whatprovides<关键词>
查询软件包组 yum grouplist [包组名] yum groupinfo<包组名>
安装软件 yum install [软件名] yum groupinstall<包组名>
升级软件 yum update yum groupupdate
卸载软件包 yum remove[软件名] yum groupremove<包组名>

-y 表示自动升级

YUM的配置文件

基本设置:/etc/yum.conf

仓库设置:letclyum.repos.d/*.repo

日志文件: /varlloglyum.log

二、NFS共享存储服务

NFS共享存储服务 (文件存储设备)

NPS是一种基于TCP/IP传输的网络文件系统协议。通过使用NFS协议,客户机可以像访问本地目录一样访问远程服务器中的共享资源。

对于大多数负载均衡群集来说,使用NFS协议来共享数据存储是比较常见的做法,NFS也是NAS存储设备必然支持的一种协议。

但是由于NFS没有用户认证机制,而且数据在网络上明文传输,所以安全性很差,一般只能在局域网中使用。


NFS服务的实现依赖于RPC (Remote Process Call,远端过程调用)机制,以完成远程到本地的映射过程。

所以需要安装nfs-utils、rpcbind 软件包来提供NFS共享服务,前者用于NFS 共享发布和访问,后者用于RPC支持。

YUM库及NFS共享服务_NFS服务_21

NFS 的配置文件为/etc/exports

格式为:

共享的目录位置 客户机地址(权限选项)

1.在文件服务器使用NFS发布共享资源

1.安装nfs-utils、rpcbind软件包
rpm -q rpcbind nfs-utils
yum -y install nfs-utils rpcbind

2.设置共享目录
mkdir -p /opt/wwwroot
chmod 777 /opt/ wwwroot

vim /etc/exports (绝对路径)
/opt/wwwroot 192.168.80.0/24(rw,sync,no_root_squash)
/var/ftp/pub 192.168.4.11(ro) 192.168.4.110(rw) (多台主机用空格隔开)
/share * (rw,sync)

客户机地址可以是主机名、IP地址、网段地址,允许使用"*”、"?"通配符。
"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=xxx:指定NFS服务器/etc/passwd文件中匿名用户的UID
anongid=xxx:指定NFS服务器/etc/passwd文件中匿名用户的GID

3.启动NFS 服务程序
手动加载NFS共享服务时,应该先启动rpcbind,再启动nfs
systemctl start rpcbind
systemctl start nfs
systemctl enable rpcbind
systemctl enable nfs
netstat -anpt | grep rpcbind

4.查看本机发布的NES共享目录
exportfs -rv 发布共享
showmount -e 查看

YUM库及NFS共享服务_NFS服务_22

YUM库及NFS共享服务_优先级_23

YUM库及NFS共享服务_yum仓库_24

YUM库及NFS共享服务_NFS服务_25

netstat -anpt | grep rpcbind #查看rpcbind端口是否开启,rpcbind默 认使用tcp端口111,nfs是2049

exportfs -rv 不用重启跟新服务

2.在客户机中访问NFS共享资源

1.查看软件安装情况
rpm -q rpcbind nfs-utils
2.启动NFS 服务程序
systemctl start rpcbind
systemctl start nfs
3.查看共享
showmount -e 192.168.132.4

YUM库及NFS共享服务_NFS服务_26

1.手动挂载
在根目录创建一个目录
mkdir /gx1
挂载
mount 192.168.132.4:/opt/tyx1 /gx1
2.自动挂载
vim /etc/fstab
192.168.132.4:/opt/tyx1 /gx1 nfs defaults,_netdev 0 0

YUM库及NFS共享服务_NFS服务_27

YUM库及NFS共享服务_yum仓库_28

如果服务器出现意外,导致nfs服务停止,客户端再使用df -h会卡死,这是普通解挂是无效的,需要强制解挂

umount -lf /gx1

YUM库及NFS共享服务_NFS服务_29

!vim 编辑上一次编辑文件






















































#