Linux网络服务------NFS共享储存服务

Posted 下雨天的放羊娃

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Linux网络服务------NFS共享储存服务相关的知识,希望对你有一定的参考价值。

一.NFS概述

✪NFS是一种基于TCP/IP传输的网络文件系统协议。通过使用NFS协议,客户机可以像访问本地目录一样访问远程服务器中的共享资源。
✪对于大多数负载均衡群集来说,使用NFS协议来共享数据存储是比较常见的做法,NFS也是NAS存储设备必然支持的一种协议。但是由于NFS没有用户认证机制,而且数据在网络.上明文传输,所以安全性很差,一般只能在局域网中使用。

✪NFS服务的实现依赖于RPC (Remote Process Call, 远端过程调用)机制,以完成远程到本地的映射过程。所以需要安装nfs-utils、 rpcbind 软件包来提供NFS共享服务,前者用于NFS共享发布和访问,后者用于RPC 支持。
✪NFS 的配置文件为/etc/exports

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

二.NFS的配置过程

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

1.安装nfs-utils,rpcbind软件包

rpm -q rpcbind nfs-utils
yum -y install nfs-utils rpcbind

在这里插入图片描述

2.设置共享目录

mkdir -p /opt/bm
chmod 777 /opt/bm

vim /etc/exports
/opt/bm 192.168.121.0/24 (rw, sync,no_root_squash)

在这里插入图片描述

客户机地址可以是主机名、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
anonqid=xxx :指定NFS服务器/etc/passwd文件中匿名用户的GID

3.启动NFS服务程序

✪手动加载NFS共享服务时,应该先启动rpcbind, 再启动nfs
systemctl start rpcbind               		启动rpcbind
systemctl start nfs 						启动nfs
systemctl enable rpcbind					设置开机自启动
systemctl enable nfs 						设置开机自启动    
netstat -anpt | grep rpcbind				查看rpcbind端口是否开启,rpcbind默认使用tcp端口111

在这里插入图片描述

4.查看本机发布的NFS共享目录

exportfs -rv    			发布共享
showmount -e

在这里插入图片描述

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

1.安装nfs-utils、rpcbind软件包

rpm -q rpcbind nfs-utils								查看软件是否安装
yum -y install nfs-utils rpcbind						安装软件
systemctl start rpcbind								开启服务	
systemctl enable rpcbind							设置开机自启
showmount -e 192.168.121.152						查看NFS服务器端共享了哪些目录

在这里插入图片描述

2.手动挂载NES 共享目录

mkdir   /bl 					创建空目录
mount 192.168.121.152:/opt/bm   /bl		挂载到bl目录
mount							确认挂载结果,也可以使用df -Th

在这里插入图片描述

3.设置自动挂载

vim /etc/fstab
192.168.121.152:/opt/bm   /bl	nfs 	defaults,_ netdev    0   0
netdev :表示挂载设备需要网络

在这里插入图片描述

4.强制卸载NFS

如果服务器端NFS服务突然间停掉了,而客户端正在挂载使用时,在客户端就会出现执行df-h命令卡死的现象。这个时候直接使用umount命令是无法直接卸载的,需要加上-lf选项才能卸载。

umount -lf /bl

在这里插入图片描述

以上是关于Linux网络服务------NFS共享储存服务的主要内容,如果未能解决你的问题,请参考以下文章

Centos7 NFS共享储存服务详解

Linux 服务器之间如何进行文件目录共享

Linux网络服务——NFS共享存储服务(包含操作详解)

Linux网络——NFS共享服务原理与配置

搭建NFS服务 实现Linux与Linux之间的文件共享

Linux网络服务12——NFS共享服务