NFS服务器与客户端的安装与配置

今天实验室需要搭建NAS,我负责的是NFS的安装与配置,现将整理的文档分享一下:

 

参考一:Linuxrpm 安装包方式安装

http://linux.chinaunix.net/techdoc/beginner/2008/03/17/983528.shtml

参考二:CentOSNFS安装与配置

http://blog.csdn.net/puwenhui/article/details/6298178

 

步骤:

一、服务器端

1安装rpm

rpm -ivh nfs4-acl-tools-0.3.3-1.el5.x86_64.rpm

rpm -ivh libgssapi-0.10-2.x86_64.rpm

rpm -ivh libgssapi-devel-0.10-2.x86_64.rpm

rpm -ivh libevent-1.1a-3.2.1.x86_64.rpm

rpm -ivh libevent-devel-1.1a-3.2.1.x86_64.rpm

rpm -ivh nfs-utils-lib-1.0.8-7.6.el5.x86_64.rpm

rpm -ivh nfs-utils-lib-devel-1.0.8-7.6.el5.x86_64.rpm

rpm -ivh portmap-4.0-65.2.2.1.x86_64.rpm

rpm -ivh nfs-utils-1.0.9-42.el5.x86_64.rpm

2创建NFS文件系统服务端目录(例:/opt/nfs),并赋予用户权限

mkdir /opt/nfs

chown nastors:storage /opt/nfs

chmod 777 /opt/nfs

3编辑配置文件/etc/exports,加入以下语句:

/opt/nfs *(rw,sync,no_root_squash)

注:①/opt/nfs为服务器挂载目录

         IP*处指定客户端IP*表示所有IP

(4启动服务

/etc/init.d/portmap start  启动RPC进程,为NFS提供端口

/etc/init.d/nfs start

/etc/init.d/nfslock start  来控制文件一致性

(5查看端口和服务

rpcinfo p localhost  看到portmapnfsmountd进程都已经开启

(6查看nfs的设置

showmount -e localhost  查看exports文件

showmount -a localhost  查看nfs与主机连接情况

(7重新修改 /etc/exports ,使用exportfs[-aruv]来使系统明白

-a :全部挂载(或卸除) /etc/exports 档案内的设定

-r :重新挂载 /etc/exports 里面的设定,此外,亦同步更新 /etc/exports

     /var/lib/nfs/xtab 的内容!

-u :卸除某一目录

-v :在 export 的时候,将分享的目录显示到屏幕上!

修改后一定记得重启nfs服务:service nfsrestart

 

二、客户端

1开启客户端的RPC

/etc/init.d/portmap start

2开启客户端的nfslock(与服务器端对应)

/etc/init.d/nfslock start

3检查一下RPC是否开启

showmount –e 222.31.76.177[S2] 

如果显示出在服务器端写的exports文件的内容,则说明成功

4进行nfs挂载

原因:①服务器端做修改后未重启服务:

exportfs -a

service nfs restart

           ②服务器配置文件/etc/exports中指定的客户端IP不对

 

测试用例:

222.31.76.177(服务器)上建了两个共享目录/opt/nfs/opt/nfs_cwn,前者是对所有IP都开放,后者只对222.31.76.195(客户端)开放。经实验,在195上能成功加载这两个共享目录,而另一台虚拟机222.31.76.48(客户端)只能挂载/opt/nfs

结论:NFS能同时存在多个共享目录,并分别指定共享范围,都在服务器配置文件/etc/exports下设定。另一方面,多个客户端也能同时使用这些共享目录。


 [S1]* rw:read-write,可擦写的权限;

 

* ro:read-only,只读的权限;

 

* sync:数据同步写入到内存与硬盘当中;

 

* async:数据会先暂存于内存当中,而非直接写入硬盘!

 

* no_root_squash:

      登入 NFS 主机使用分享目录的用户,如果是 root 的话,那么对于这个分享的目录来说,他就具有 root 的权限! 这个项目『极不安全』,不建议使用!

 

* root_squash:

      在登入 NFS 主机使用分享之目录的用户如果是 root 时,那么这个使用者的权限将被压缩成为匿名用户,通常他的 UID 与 GID 都会变成nobody(nfsnobody) 那个系统账号的身份;

 

* all_squash:

      不论登入 NFS 的使用者身份为何, 他的身份都会被压缩成为匿名用户,通常也就是nobody(nfsnobody) 啦!

 

* anonuid:

      anon 意指 anonymous (匿名者) 前面关于 *_squash 提到的匿名用户的 UID 设定值,通常为 nobody(nfsnobody),但是您可以自行设定这个 UID 的值!当然,这个 UID 必需要存在于您的 /etc/passwd 当中!

 

* anongid:同 anonuid ,但是变成 group ID 就是了!

 [S2]IP为服务器的IP

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章