NFS服务端及客户端安装配置挂载

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接: https://blog.csdn.net/guopengNo1/article/details/102741830

1、准备工作

NFS 服务端需要至少安装两个软件:nfs-utils 和 rpcbind,
客户端只需要安装rpcbind

2、查看是否安装nfs服务

[root@localhost soft]# rpm -qa nfs-utils rpcbind

3、安装nfs 服务端及客户端

[root@localhost soft]# yum install -y nfs-utils
[root@localhost soft]# yum install -y rpcbind
# 查看是否安装成功
[root@localhost soft]# rpm -qa nfs-utils rpcbind
nfs-utils-1.2.3-39.el6.x86_64
rpcbind-0.2.0-11.el6.x86_64

4、服务端:配置需要共享的目录

[root@localhost nfs]# vim /etc/exports

# 添加如下内容到exports中:
/opt/nfs/ 192.168.1.1(rw,no_root_squash,async)
# 生效
[root@localhost nfs]# exportfs -arv

# exportfs参数说明:
-a 全部挂载或卸载 /etc/exports中的内容
-r 重新读取/etc/exports 中的信息 ,并同步更新/etc/exports、/var/lib/nfs/xtab
-u 卸载单一目录(和-a一起使用为卸载所有/etc/exports文件中的目录)
-v 在export的时候,将详细的信息输出到屏幕上。
# exports文件的编写格式

<输出目录> [客户端1 选项(访问权限,用户映射,其他)] [客户端2 选项(访问权限,用户映射,其他)]

# 输出目录为NFS目录,
# 客户端为要连接到NFS的客户端,
# 访问权限指客户端的操作权限,
# 用户映射可以限制用户权限

# 客户端常用的指定方式
指定ip地址的主机 192.168.0.200
指定子网中的所有主机 192.168.0.0/24
指定域名的主机 a.liusuping.com
指定域中的所有主机 *.liusuping.com
所有主机 *

# 访问权限选项
设置输出目录只读 ro
设置输出目录读写 rw

# 用户映射选项
all_squash 将远程访问的所有普通用户及所属组都映射为匿名用户或用户组(nfsnobody);
no_all_squash 与all_squash取反(默认设置);
root_squash 将root用户及所属组都映射为匿名用户或用户组(默认设置);
no_root_squash 与rootsquash取反;
anonuid=xxx 将远程访问的所有用户都映射为匿名用户,并指定该用户为本地用户(UID=xxx);
anongid=xxx 将远程访问的所有用户组都映射为匿名用 户组账户,并指定该匿名用户组账户为本地用户组账户(GID=xxx);

# 其它选项
secure 限制客户端只能从小于1024的tcp/ip端口连接nfs服务器(默认设置);
insecure 允许客户端从大于1024的tcp/ip端口连接服务器;
sync 将数据同步写入内存缓冲区与磁盘中,效率低,但可以保证数据的一致性;
async 将数据先保存在内存缓冲区中,必要时才写入磁盘;
wdelay 检查是否有相关的写操作,如果有则将这些写操作 一起执行,这样可以提高效率(默认设置);
no_wdelay 若有写操作则立即执行,应与sync配合使用;
subtree 若输出目录是一个子目录,则nfs服务器将检查其父目录的权限(默认设置);
no_subtree 即使输出目录是一个子目录,nfs服务器也不检查其父目录的权限,这样可以提高效率;

## 启动、停止、查看状态、查看挂载状态

# 启动
[root@localhost nfs]# service rpcbind start
[root@localhost nfs]# service nfs start

# 停止
[root@localhost nfs]# service rpcbind stop
[root@localhost nfs]# service nfs stop

# 查看状态
[root@localhost nfs]# service rpcbind status
[root@localhost nfs]# service nfs status
# 查看挂载情况

# 查询本机nfs共享目录情况
[root@localhost nfs]# showmount -e localhost 
# 查询本机共享目录连接情况
[root@localhost nfs]# showmount -a localhost 

5、客户端:配置需要挂载的目录

注意:挂载的时候要先把原文件夹内的内容移出去,挂载完成后再移动进来,要不然原来的文件就看不到了

挂载命令
[root@140106 opt]# mount -t nfs 192.168.140.101:/opt/nfs /opt/nfs

取消挂载命令:
[root@140106 opt]# umount -a

使用 fuser 命令需要安装以下依赖
[root@140105 opt]# yum install -y psmisc

取消挂载 umount 时目标忙的解决办法
一、第一种情况是可能你当前所在路径已经在挂载目录下,需要切换到别的目录才能umount成功。
二、第二种情况是没有在挂载目录,但是umount时,始终无法umonut,可以通过fuser查看设备被哪个进程占用,之后杀死进程,就可以顺利umount了。

[root@140105 nfs]# fuser -mv  /var/lib/ceph/osd/ceph-1
-bash: fuser: 未找到命令
yum 安装 fuser
[root@140105 opt]# yum install -y psmisc
查看占用命令:
[root@140106 opt]# fuser -mv /home/data_azkaban
杀死占用命令:
[root@140106 opt]# fuser -kv /home/data_azkaban

6、END

配置完成后可以在服务端和客户端的共享目录内创建删除文件,看看响应的客户端和服务端能不能共享

愉快的玩耍吧

猜你喜欢

转载自blog.csdn.net/guopengNo1/article/details/102741830