NFS配置
NFS的配置文件为/etc/exports
格式为:
共享的目录 位置客户机地址(权限选项)
在文件服务器使用NFS发布共享资源
安装nfs-utils、rpcbind软件包
rpm -q rpcbind nfs-utils
yum -y install nfs-utils rpcbind
设置共享目录
mkdir -p /opt/wwwroot
chmod 777 /opt/wwwroot
vim /etc/exports
/opt/wwwroot 192.168.101.0/24(rw,sync,no_root_squash)
/var/ftp/pub 192.168.108.10(ro)192.168.108.100(rw)
/share *(rw,sync)
客户机地址可以是主机名、IP地址、网段地址,允许使用“*”、“?”通配符。
"rw"表示允许读写,"ro"表示为只读。
sync:表示同步写入到内存与硬盘中。
no_root_squash:表示当客户机以root身份访问时赋予本地root权限(默认是root_squash)。
root_squash:表示客户机用root用户访问该共享目录时,将root用户映射成匿名用户。
其它常用选项
all_squash: 所有访问用户都映射为匿名用户或用户组。
async: 将数据先保存在内存缓冲区中,必要时才写入磁盘。
subtree_check(默认): 若输出目录是一个子目录,则nfs服务器将检查其父目录的权限。
no_subtree_check: 即使输出目录是一个子目录,nfs服务器也不检查其父目录的权限,这样可以提高效率。
anonuid=xxx: 指定NFS服务器/etc/passwd文件中匿名用户的UID
anongid=xxx: 指定NFS服务器/etc/passwd文件中匿名用户的GID
启动NFS服务程序
#手动加载NFS共享服务时,应该先启动rpcbind,再启动nfs
systemctl start rpcbind
systemctl start nfs
systemctl enable rpcbind
systemctl enable nfs
netstat -anpt | grep rpcbind
#查看rpcbind端口是否开启,rpcbind默认使用tcp端口111
查看本机发布的NFS共享目录
exportfs -rv #发布共享
showmount -e #查看共享
关闭防火墙和增强型安全设置
systemctl stop firewalld.service
setenforce 0
在客户机中访问NFS共享资源
安装nfs-utils、rpcbind软件包
rpm -q rpcbind nfs-utils
yum -y install nfs-utils rpcbind
systemctl start rpcbind
systemctl enable rpcbind
查看NFS服务器端共享了哪些目录
showmount -e 192.168.101.22
关闭防火墙和增强型安全设置
systemctl stop firewalld.service
setenforce 0
手动挂载NFS共享目录
mkdir /myshare
mount 192.168.101.22:/opt/wwwroot /myshare
mount #确认挂载结果,也可以使用df -Th
或者设置自动挂载
vim /etc/fstab
192.168.101.22:/opt/wwwroot /myshare nfs defaults,_netdev 0 0
_netdev:表示挂载设备需要网络
强制卸载NFS
如果服务器端NFS服务突然间停掉了,而客户端正在挂载使用时,在客户端就会出现执行 df -h命令卡死的现象。这个时候直接使用umount命令是无法直接卸载的,需要加上-lf选项才能卸载。
umount -lf /myshare
实例图解














本文详细介绍了如何在CentOS Linux系统上配置NFS服务器,包括安装必要的软件包、设置共享目录、启动服务以及在客户机上访问共享资源。同时,还提到了NFS的权限选项,如`rw`、`ro`、`sync`、`async`、`no_root_squash`等,并讲解了如何关闭防火墙和安全设置以确保NFS的正常工作。
1611

被折叠的 条评论
为什么被折叠?



