NFS网络文件系统安装

环境:Ubuntu16.04 64位 配置NFS服务器。

安装NFS服务器端:

apt-get install nfs-kernel-server

下载完创建NFS的文件夹

mkdir /opt/nfs_folder

配置服务器端配置:

vi /etc/exports

在最后一行写入

/opt/nfs_folder *(rw,sync,no_root_squash,no_subtree_check)

解释:

*:允许所有的网段访问,也可以使用具体的IP。

rw:挂接此目录的客户端对该共享目录具有读写权限。

sync:资料同步写入内存和硬盘。

no_root_squash:root用户具有对根目录的完全管理访问权限。

no_subtree_check:不检查父目录的权限。

// 重启rpcbind 服务。nfs是一个RPC程序,使用它前,需要映射好端口,通过rpcbind 设定。

/etc/init.d/rpcbind restart

/etc/init.d/nfs-kernel-server restart 

服务器端就配置完成了。

客户端

安装

apt-get install nfs-common

挂载服务器共享文件夹到本地

mount -t nfs 192.168.30.129:/opt/nfs_folder /opt/myfolder/

就完成了,这时候你在本地/opt/myfolder/下创建aaa文件,在服务器/opt/nfs/nfs_folder/下看到aaa。

客户端常用的指令

• 指定ip地址的主机:192.168.0.200

• 指定子网中的所有主机:192.168.0.0/24 192.168.0.0/255.255.255.0

• 指定域名的主机:david.bsmart.cn

• 指定域中的所有主机:*.bsmart.cn

• 所有主机:*

选项用来设置输出目录的访问权限、用户映射等。

NFS主要有3类选项:

访问权限选项

• 设置输出目录只读:ro

• 设置输出目录读写:rw

用户映射选项

• all_squash:将远程访问的所有普通用户及所属组都映射为匿名用户或用户组(nfsnobody);

• no_all_squash:与all_squash取反(默认设置);

• root_squash:将root用户及所属组都映射为匿名用户或用户组(默认设置);

• no_root_squash:与rootsquash取反;

• anonuid=xxx:将远程访问的所有用户都映射为匿名用户,并指定该用户为本地用户(UID=xxx);

• anongid=xxx:将远程访问的所有用户组都映射为匿名用户组账户,并指定该匿名用户组账户为本地用户组账户(GID=xxx);

其它选项

• secure:限制客户端只能从小于1024的tcp/ip端口连接nfs服务器(默认设置);

• insecure:允许客户端从大于1024的tcp/ip端口连接服务器;

• sync:将数据同步写入内存缓冲区与磁盘中,效率低,但可以保证数据的一致性;

• async:将数据先保存在内存缓冲区中,必要时才写入磁盘;

• wdelay:检查是否有相关的写操作,如果有则将这些写操作一起执行,这样可以提高效率(默认设置);

• no_wdelay:若有写操作则立即执行,应与sync配合使用;

• subtree:若输出目录是一个子目录,则nfs服务器将检查其父目录的权限(默认设置);

• no_subtree:即使输出目录是一个子目录,nfs服务器也不检查其父目录的权限,这样可以提高效率;

posted @ 2021-06-30 17:03  denfer  阅读(87)  评论(0编辑  收藏  举报