這次由於工作中需要,在Ubuntu系統下進行了NFS服務器的配置,NFS,是Network File System的简写,即網絡文件系統。网络文件系统是FreeBSD支持的文件系统中的一种,也被称为NFS. NFS允许一个系统在网络上与他人共享目录和文件。通过使用NFS,用户和程序可以像访问本地文件一样访问远端系统上的文件。
NFS服務器配置:
1.安裝Ubuntu nfs
Ubuntu上默认是没有安装Ubuntu nfs服务器的,因此我们首先安装Ubuntu nfs服务器端:$sudo apt-get install nfs-kernel-server. 在安裝nfs-kernel-server時會根據相關性自動安裝客戶端nfs-comm和端口映射器portmap。
2.配置/etc/exports
$sudo gedit /etc/exports 在文件里添加一句/tftpboot/rootfs *(rw,sync,no_root_squash)其中:
/tftpboot/rootfs 是要共享的目錄
* 是代表允许所有的网络段访问
rw 是可讀可寫的權限
sync 是资料同步写入内存和硬盘
no_root_squash 是Ubuntu nfs客户端分享目录使用者的权限,即root用户具有根目录的完全管理访问权限
其它Ubuntu 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
3.重啟服務器
$sudo /etc/init.d/portmap restart
$sudo /etc/init.d/nfs-kernel-server restart
4.驗證
此时可以运行以下命令来显示一下共享出来的目录:$showmount -e
/tftpboot/rootfs
在/mnt 下創建nfs文件夾,用命令$sudo mount -t nfs localhost:/tftpboot/rootfs /mnt/nfs
$ls /mnt/nfs查看nfs文件夾下面是否顯示的是/tftpboot/rootfs/文件下的東西
卸載 $sudo umount /mnt/nfs