redhat linux NFS配置

来源:岁月联盟 编辑:exp 时间:2011-09-22

NFS 简介:

NFS 是网络文件系统的简写( network file system ),主要用在 linux 或 unix 环境中,是有 sun 公司开发,并于 1984 年推出的一个 RPC 服务系统。
NFS 功能介绍:

他可以将多个目录或者单个目录进行发布,例如我们在网刻系统的时候可以用 NFS 来共享光盘镜像, NFS 是以发布目录的方式将文件进行发布,而客户端是以挂载的方式进行访问。客户端可以节省本地空间,将数据存放在 nfs 服务器上。 NFS 也可以针对但个用户以及多用户设置不同的访问权限。
详细配置步骤:

安装 NFS 必须要开启的服务有: nfs 、 portmap 、
NFS 的配置相对于其他服务是比较简单的,我们依然还是要注意防火墙以及 SElinux


[root@huyb ~]# rpm -qa | grep nfs-utils
nfs-utils-1.0.9-16.el5
nfs-utils-lib-1.0.8-7.2 //系统默认已经安装nfs-utils;
[root@huyb ~]# rpm -qa | grep portmap
portmap-4.0-65.2.2.1 //系统默认已经安装portmap;

 

若系统没有安装所需软件,可以手工安装;
[root@huyb ~]#mount /dev/cdrom /mnt //将光盘挂在到系统的/mnt;
[root@huyb ~]#cd /mnt/Server //切换工作目录为/mnt/Server;
[root@huyb Server]#ls | grep nfs //列表跟nfs相关的软件包;
[root@huyb Server]# rpm -ivh nfs-utils-1.0.9-16.el5.i386.rpm //安装nfs-utils包;


创建或修改/etc/exports 配置文件
这个文件的内容非常简单,每一行由抛出路径,客户名列表以及每个客户名后紧跟的访问选项构成:

         [共享的目录] [主机名或IP(参数,参数)]
其中参数是可选的,当不指定参数时,nfs将使用默认选项。默认的共享选项是 sync,ro,root_squash,no_delay。
当主机名或IP地址为空时,则代表共享给任意客户机提供服务。
当将同一目录共享给多个客户机,但对每个客户机提供的权限不同时,可以这样:

         [共享的目录] [主机名1或IP1(参数1,参数2)] [主机名2或IP2(参数3,参数4)]
下面是一些NFS共享的常用参数:
 

         ro                      只读访问
        rw                      读写访问
        sync                    所有数据在请求时写入共享
        async                   NFS在写入数据前可以相应请求
        secure                  NFS通过1024以下的安全TCP/IP端口发送
        insecure                NFS通过1024以上的端口发送
        wdelay                  如果多个用户要写入NFS目录,则归组写入(默认)
        no_wdelay               如果多个用户要写入NFS目录,则立即写入,当使用async时,无需此设置。
        hide                    在NFS共享目录中不共享其子目录
        no_hide                 共享NFS目录的子目录
        subtree_check           如果共享/usr/bin之类的子目录时,强制NFS检查父目录的权限(默认)
        no_subtree_check        和上面相对,不检查父目录权限
        all_squash              共享文件的UID和GID映射匿名用户anonymous,适合公用目录。
        no_all_squash           保留共享文件的UID和GID(默认)
        root_squash             root用户的所有请求映射成如anonymous用户一样的权限(默认)
        no_root_squas           root用户具有根目录的完全管理访问权限
        anonuid=xxx             指定NFS服务器/etc/passwd文件中匿名用户的UID
        anongid=xxx             指定NFS服务器/etc/passwd文件中匿名用户的GID
配置文件/etc/exports内容如下:
 

         $ cat /etc/exports

        /home/share 192.168.102.15(rw,sync) *(ro)
配置说明: 对192.168.102.15赋予读写权限,其他机器仅有只读权限。
 
维护NFS服务的输出目录列表

命令exportfs

-a 输出在/etc/exports文件中所定义的所有目录;
-r 重新读取/etc/exports文件,不需要重起服务;
-u 停止输出某一目录;
-v 在屏幕上显示过程;

1.重新输出共享目录

[root@huyb ~]# exportfs -rv
exporting 192.168.1.0/24:/nfs/public
exporting 192.168.1.253:/nfs/huyb
exporting *.wnt.com:/nfs/users
exporting 192.168.1.*:/mnt/cdrom
exporting *.wnt.net:/nfs/root
exporting *:/nfs/public

2.查看NFS服务输出的共享目录

[root@huyb ~]# showmount -e 192.168.1.102
Export list for 192.168.1.102:
/nfs/root *.wnt.net
/mnt/cdrom 192.168.1.*
/nfs/users *.wnt.com
/nfs/huyb 192.168.1.253
/nfs/public (everyone)

3.停止输出所有共享目录

[root@huyb ~]# exportfs -auv
[root@huyb ~]# showmount -e 192.168.1.102
Export list for 192.168.1.102: //结果为空;

4.启动或停止NFS服务器

[root@huyb ~]# sevice nfs start|stop|restart

[root@huyb ~]# chkconfig --level 35 nfs on //设置NFS自动启动方式;

5.查询nfs的状态

[root@huyb ~]# service portmap status
[root@huyb ~]# service nfs status

6.查询nfs服务器的共享目录

showmount 192.168.1.111 查询指定主机的nfs共享目录
showmount 查询本地主机的

-a 显示指定的nfs服务器的所有客户端主机及其所连接的目录;
-d 显示指定的nfs服务器中已被客户端连接的所有输出目录;
-e 显示指定nfs服务器上所有输出的目录;

作者“nilm”