一、NFS服务简介
NFS 是Network File System的缩写,即网络文件系统。一种使用于分散式文件系统的协定,由Sun公司开发,于1984年向外公布。功能是通过网络让不同的机器、不同的操作系统能够彼此分享个别的数据,让应用程序在客户端通过网络访问位于服务器磁盘中的数据,是在类Unix系统间实现磁盘文件共享的一种方法。
NFS 的基本原则是“容许不同的客户端及服务端通过一组RPC分享相同的文件系统”,它是独立于操作系统,容许不同硬件及操作系统的系统共同进行文件的分享。
NFS在文件传送或信息传送过程中依赖于RPC协议。RPC,远程过程调用 (Remote Procedure Call) 是能使客户端执行其他系统中程序的一种机制。NFS本身是没有提供信息传输的协议和功能的,但NFS却能让我们通过网络进行资料的分享,这是因为NFS使用了一些其它的传输协议。而这些传输协议用到这个RPC功能的。可以说NFS本身就是使用RPC的一个程序。或者说NFS也是一个RPC SERVER。所以只要用到NFS的地方都要启动RPC服务,不论是NFS SERVER或者NFS CLIENT。这样SERVER和CLIENT才能通过RPC来实现PROGRAM PORT的对应。可以这么理解RPC和NFS的关系:NFS是一个文件系统,而RPC是负责负责信息的传输。
二、NFS搭建的准备步骤
1、查看系统是否有NFS安装包
[xiaoying@Centos6 ~]$rpm -qa | grep nfs
nfs-utils-1.2.3-64.el6.x86_64
nfs-utils-lib-1.1.5-11.el6.x86_64
若没有,可通过sudo yum install -y nfs-utils来安装。
2、修改/etc/exports配置文件
<输出目录> [客户端1 选项(访问权限,用户映射,其他)] [客户端2 选项(访问权限, 用 户映射,其他)]
a. 输出目录:输出目录是指NFS系统中需要共享给客户机使用的目录;
b. 客户端:客户端是指网络中可以访问这个NFS输出目录的计算机
客户端常用的指定方式
指定ip地址的主机:192.168.0.200
指定子网中的所有主机:192.168.0.0/24 192.168.0.0/255.255.255.0
指定域名的主机:david.bsmart.cn
指定域中的所有主机:*.bsmart.cn
所有主机:*
c. 选项:选项用来设置输出目录的访问权限、用户映射等。
NFS主要有3类选项:
(1)访问权限选项:
设置输出目录只读:ro
设置输出目录读写:rw
(2)用户映射选项:
all_squash:将远程访问的所有普通用户及所属组都映射为匿名用户或用户 组(nfsnobody);
no_all_squash:与all_squash取反(默认设置);
root_squash:将root用户及所属组都映射为匿名用户或用户组(默认设 置);
no_root_squash:与rootsquash取反;
anonuid=xxx:将远程访问的所有用户都映射为匿名用户,并指定该用户为本 地用户(UID=xxx);
anongid=xxx:将远程访问的所有用户组都映射为匿名用户组账户,并指定该 匿名用户组账户为本地用户组账户(GID=xxx);
(3)其它选项
secure:限制客户端只能从小于1024的tcp/ip端口连接nfs服务器(默认设置);
insecure:允许客户端从大于1024的tcp/ip端口连接服务器;
sync:将数据同步写入内存缓冲区与磁盘中,效率低,但可以保证数据的一致性;
async:将数据先保存在内存缓冲区中,必要时才写入磁盘;
wdelay:检查是否有相关的写操作,如果有则将这些写操作一起执行,这样可以提高效率(默认设置);
no_wdelay:若有写操作则立即执行,应与sync配合使用;
subtree:若输出目录是一个子目录,则nfs服务器将检查其父目录的权限(默认设置);
no_subtree:即使输出目录是一个子目录,nfs服务器也不检查其父目录的权限,这样可以提高效率;
[xiaoying@Centos6 ~]$sudo vim /etc/exports
/test 192.168.1.0/24(rw)
/home/test *(rw,no_root_squash)
说明:“no_root_squash” 表示:如果你是用户端,而且你是以 root 的身份登录你的 Linux 主机,那么当你 mount 上我这部主机的/home/test之後,你在该mount的目录当中,将具有root 的权限。
3.启动NFS服务
[xiaoying@Centos6 ~]$ sudo service nfs restart
Shutting down NFS daemon: [ OK ]
Shutting down NFS mountd: [ OK ]
Shutting down NFS quotas: [ OK ]
Shutting down NFS services: [ OK ]
Starting NFS services: [ OK ]
Starting NFS quotas: [ OK ]
Starting NFS mountd: [ OK ]
Starting NFS daemon: [ OK ]
[xiaoying@Centos6 ~]$ sudo service rpcbind restart
Stopping rpcbind: [ OK ]
Starting rpcbind: [ OK ]
4.设置NFS开机自启
在实际应用的系统中,每次都进行手动启动NFS是很麻烦的,我们需设置系统在指定的运行级别自动启动nfs服务。设置在35级别自启。
首先确认:
[xiaoying@Centos6 ~]$ sudo chkconfig --list nfs
[sudo] password for xiaoying:
nfs 0:off 1:off 2:off 3:off 4:off 5:off 6:off
3 5是关闭状态,接下来进行设置:
[xiaoying@Centos6 ~]$ sudo chkconfig --level 35 nfs on
[xiaoying@Centos6 ~]$ sudo chkconfig --list nfs
nfs 0:off 1:off 2:off 3:on 4:off 5:on 6:off
三、搭建的实例
1.目标:
把主机IP为192.168.122.0下的/home/test文件夹挂载到同一主机IP下的/mnt/nfs1路 径下。
2.检查安装包:
[xiaoying@Centos6 ~]$ rpm -qa | grep nfs
nfs-utils-1.2.3-64.el6.x86_64
nfs-utils-lib-1.1.5-11.el6.x86_64
3.修改/etc/exports文件:
[xiaoying@Centos6 ~]$ sudo vim /etc/exports
/test 192.168.1.0/24(rw)
/home/test *(rw,no_root_squash)
4.重启NFS服务
[xiaoying@Centos6 ~]$ sudo service nfs restart
Shutting down NFS daemon: [ OK ]
Shutting down NFS mountd: [ OK ]
Shutting down NFS quotas: [ OK ]
Shutting down NFS services: [ OK ]
Starting NFS services: [ OK ]
Starting NFS quotas: [ OK ]
Starting NFS mountd: [ OK ]
Starting NFS daemon: [ OK ]
[xiaoying@Centos6 ~]$ sudo service rpcbind restart
Stopping rpcbind: [ OK ]
Starting rpcbind: [ OK ]
5.检查自己的共享的文件
[xiaoying@Centos6 ~]$ showmount -e 192.168.122.1
Export list for 192.168.122.1:
/home/test *
/test 192.168.1.0/24
6.挂载
[xiaoying@Centos6 ~]$ sudo mount -t nfs 192.168.122.1:/home/test /mnt/nfs1/
[xiaoying@Centos6 ~]$ ls /home
xiaoying test user1 user2
[xiaoying@Centos6 ~]$ mount #查看挂载
/dev/sda2 on / type ext4 (rw)
proc on /proc type proc (rw)
sysfs on /sys type sysfs (rw)
devpts on /dev/pts type devpts (rw,gid=5,mode=620)
tmpfs on /dev/shm type tmpfs (rw,rootcontext="system_u:object_r:tmpfs_t:s0")
/dev/sda1 on /boot type ext4 (rw)
none on /proc/sys/fs/binfmt_misc type binfmt_misc (rw)
sunrpc on /var/lib/nfs/rpc_pipefs type rpc_pipefs (rw)
nfsd on /proc/fs/nfsd type nfsd (rw)
192.168.122.1:/home/test on /mnt/nfs1 type nfs (rw,vers=4,addr=192.168.122.1,clientaddr=192.168.122.1) #显示挂载已完成
注意:挂载操作过程中一定要确保挂载的文件夹、文件目录路径正确