2024年3月23日发(作者:)
概述
NFS(Network File System)是一种分布式文件系统,允许网络中的安装不同
操作系统的计算机间共享文件和外设,所以它的通讯协定设计与主机及作业系统
无关. 它是由SUN公司于1984年推出,使得可以本地机一样的使用另一台联
网计算机的文件和外设。NFS在文件传送或信息传送过程中依赖于RPC协议。
NFS 的当前版本是V4(RFC3010)
RPC, 远程过程调用 (remote procedure call) 是能使客户端执行其他系统
中程序的一种机制。由于使用 RPC 的程序不必了解支持通信的网络协议的情
况,因此 RPC 提高了程序的互操作性。常用于分布式客户端/服务器模型,发
出请求的程序是客户程序,而提供服务的程序是服务器。
1.安装NFS
Debian/Ubuntu上默认是没有安装NFS服务器的,首先要安装NFS服务程序:
$ sudo apt-get install nfs-kernel-server
(安装nfs-kernel-server时,apt会自动安装nfs-common和portmap)
这样,宿主机就相当于NFS Server。
同样地,目标系统作为NFS的客户端,需要安装NFS客户端程序。如果是
Debian/Ubuntu系统,则需要安装nfs-common。
$ sudo apt-get install nfs-common
nfs-common和nfs-kernel-server都依赖于portmap!
2.配置NFS
配置portmap
方法1: 编辑/etc/default/portmap, 将 -i 127.0.0.1 去掉.
方法2: $ sudo dpkg-reconfigure portmap , 对Should portmap be bound to the
loopback address? 选N.
配置/etc/
(禁止任何host(主机)能和你的NFS服务器进行NFS连接),加入:
### NFS DAEMONS
portmap:ALL
lockd:ALL
mountd:ALL
rquotad:ALL
statd:ALL
配 置/etc/
允许那些你想要的主机和你的NFS服务器建立连接。下列步骤将允许任何IP地
址以192.168.2开头的主机(连 接到NFS服务器上),也可以指定特定的IP地
址。参看man页 hosts_access(5), hosts_options(5)。加入:
### NFS DAEMONS
portmap: 192.168.2.
lockd: 192.168.2.
rquotad: 192.168.2.
mountd: 192.168.2.
statd: 192.168.2.
/etc/ 和 /etc/ 设置对portmap的访问. 采用这两个配置
文件有点类似"mask"的意思. 现在/etc/中禁止所有用户对portmap
的访问. 再在/etc/ 中允许某些用户对portmap的访问.
运行 $ sudo /etc/init.d/portmap restart 重启portmap daemon.
配置/etc/exports
NFS挂载目录及权限由/etc/exports文件定义
比如我要将将我的home目录中的/home/zp/share目录让192.168.2.*的IP共享,
则在该文件末尾添加下列语句:
/home/zp/share 192.168.2.*(rw,sync,no_root_squash)
或者:/home/zp/share 192.168.2.0/24(rw,sync,no_root_squash)
192.168.2.* 网段内的NFS客户端能够共享NFS服务器/home/zp/share目录内
容.且有读,写权限, 并且该用户进入/home/zp/share目录后的身份为root
最好加上sync, 否则 $ sudo exportfs -r 时会给出警告, sync是NFS的默认选
项.
运行 $ sudo /etc/init.d/nfs-kernel-server restart 重启nfs服务


发布评论