环境:CentOS release 6.8

server  192.168.25.100
client1 192.168.25.101
client2 192.168.25.102

1.服务端操作

1.1 安装nfs需要的包

yum install -y nfs-utils rpcbind

1.2 创建挂载路径

mkdir /nfsfile     我这里的这个路径是一个独立的磁盘,方便存储和管理

1.3 编写配置文件

vim /etc/exports

内容只有下面一行

/nfsfile 192.168.25.0/24(rw,async,no_root_squash,no_all_squash)

说明 第一部分是挂在的路径,第二部分是允许哪些网段的可以访问,我这里设置的是整个网段的,可以细粒度到指定一个IP,括号里面的内容可以写如下的内容

rw 读写 
ro 只读 
sync 同步模式,内存数据实时写入磁盘 
async 非同步模式 ,把内存总数据定期写入磁盘
no_root_squash 客户端挂载NFS共享目录后,root用户不受约束,权限很大 ,不安全,不建议使用
root_squash 与上面选项相对,客户端上的root用户受到约束,被限定成某个普通用户 
all_squash 客户端上所有用户在使用NFS共享目录时都被限定为一个普通用户 
anonuid/anongid 和上面几个选项搭配使用,定义被限定用户的uid和gid
no_all_squash 客户端上所有用户在使用NFS共享目录时不受约束,显示操作用户

--------------------小插曲------------------------------------
温馨提示,如果不开后面的两个no_权限的话,操作的时候,所有者和所属组都是匿名的操作
这是客户端进行操作的

[root@test6_102 export]# mkdir test
 [root@test6_102 export]# ll
 total 24
 drwx------ 2 root      root      16384 Aug 18 01:09 lost+found
 drwxr-xr-x 2 nfsnobody nfsnobody  4096 Aug 18 01:44 test


--------------------------------------------------------------

完成配置文件后保存退出,开启服务

service rpcbind start
service nfs start

1.4 查看一下是否启动成功

showmount -e 192.168.25.100
Export list for test100:
/nfsfile 192.168.25.0/24

1.5 分配权限:

如果磁盘想让别人可以读写的话,建议给777权限,不然只能进行读取权限

chmod 777 /nfsfile

1.6 服务端查看全部的nfs共享

exportfs -avr    //   -a 全部  -v 详细信息   -r刷新
或者:
showmount -e 127.0.0.1      //   查看本机全部nfs共享

2.客户端操作

两台服务器的操作是完全一样的,这里只说明其中一台,另一台服务器同样操作

2.1 安装nfs需要的包

yum install nfs-utils rpcbind -y

2.2 创建路径

mkdir /nfsfile

2.3 挂载nfs文件

mount 192.168.25.100:/nfsfile /nfsfile

查看是否挂载成功

df -Th
Filesystem      Type       Size  Used Avail Use% Mounted on
192.168.25.100:/nfsfile  
                nfs       2.0G   3.2M  1.9G   1% /nfsfile

挂载成功

2.4 开机自动挂载
2.4.1 客户端操作修改/etc/fstab:

vi /etc/fstab

在最后的位置添加上如下内容:

192.168.25.100:/nfsfile     /nfsfile     nfs    defaults     0  0

这样永久挂载后,每次系统启动都会自动挂载服务器端NFS,当服务端NFS没有开启时,本地客户端启动时会执行挂载任务,导致系统启动速度变慢。因此,我们可以把服务端的NFS自动挂载到本地,当我们需要时,再去访问。

2.4.2 修改系统自带配置文件

自动挂载用到的软件包automount,
一般系统都默认安装了的。如果没有安装再安装下:yum install autofs

下面进行自动挂载配置:

mkdir /nfs_mount        //先在根目录创建一个用于自动挂载的目录

vim /etc/auto.master     //编辑配置文件

添加内容:

/nfs_mount   /etc/auto.nfs    //最后一行添加(左边目录是指需要挂载的目录,右边目录是指关联到所需自动挂载路径)

 
保存退出

vim /etc/auto.nfs         //新建我们刚刚设置的自动挂载路径,添加如下信息

nfs_client    -rw,async,no_root_squash,no_all_squash      192.168.125.100/nfsfile //左边代表自动挂载目录,中间权限,sync 代表同步,右边代表所需挂载的文件路径

 

service autofs reload     //重置自动挂载map

 

df -Th
Filesystem      Type       Size  Used Avail Use% Mounted on
192.168.25.100:/nfsfile  
                nfs       2.0G   3.2M  1.9G   1% /nfsfile

这时,我们去访问我们建立的自动挂载目录,去触发自动挂载

cd /nfs_mount/
ls   --ls是没有任何文件的,但是下面的cd是可以进入路径的
cd nfs_client      //上面ls查看没有nfs_client目录,但是我们可以cd访问nfs_client目录去触发自动挂载
ls
nfsfile

df -Th
Filesystem      Type       Size  Used Avail Use% Mounted on
192.168.25.100:/nfsfile  
                nfs       2.0G   3.2M  1.9G   1% /nfsfile 

192.168.25.100:/nfsfile  
                nfs         2.0G   3.2M  1.9G   1% /nfs_mount/nfs_client

参考文档: