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服务