Linux部署NFS服务共享文件
nfs(网络文件系统)用于linux共享文件
第1步:配置所需要的环境
使用两台linux主机
主机名称 | 操作系统 | ip地址 |
nfs | centos7 | 192.168.218.139 |
nfsa | centos7 | 192.168.218.140 |
配置好yum源,安装nfs服务,清空nfs服务器上iptables防火墙默认策略。
[root@nfs ~]# yum install nfs-utils -y
第2步:在nfs服务器上建立用于nfs文件共享的目录,并设置足够的权限确保其他人也有写入权限。
[root@nfs ~]# mkdir /nfs
[root@nfs ~]# chmod -rf 777 /nfs
[root@nfs ~]# echo "welcome to purple" > /nfs/hello
第3步:编辑nfs服务程序的配置文件/etc/exports。
配置nfs服务程序配置文件的参数
参数 | 作用 |
ro | 只读 |
rw | 读写 |
root_squash | 当nfs客户端以root管理员访问时,映射为nfs服务器的匿名用户 |
no_root_squash | 当nfs客户端以root管理员访问时,映射为nfs服务器的root管理员 |
all_squash | 无论nfs客户端使用什么账户访问,均映射为nfs服务器的匿名用户 |
sync | 同时将数据写入内存与硬盘中,保证不丢失数据 |
async | 优先将数据保存到内存,然后再写入硬盘;这样效率更高,但可能会丢失数据 |
[root@nfs ~]# vim /etc/exports
/nfs 192.168.218.0/24(rw,sync,root_squash)
第4步:启动和启动nfs服务程序。由于在使用nfs服务进行文件共享之前,需要使用rpc(remote procedure call,远程过程调用)服务将nfs服务器的ip地址和端口信号等信息发送给客户端。
[root@nfs ~]# systemctl restart rpcbind
[root@nfs ~]# systemctl enable rpcbind
[root@nfs ~]# systemctl start nfs-server
[root@nfs ~]# systemctl enable nfs-server
created symlink from /etc/systemd/system/multi-user.target.wants/nfs-server.service to /usr/lib/systemd/system/nfs-server.service.
nfs客户端使用showmount命令查询nfs服务器的远程共享信息,其输出格式为“共享的目录名称 允许使用客户端地址”。
showmount命令中可用的参数以及作用
参数 | 作用 |
-e | 显示nfs服务器的共享列表 |
-a | 显示本机挂载的文件资源情况 |
-v | 显示版本号 |
[root@nfsa ~]# showmount -e 192.168.218.139
export list for 192.168.218.139:
/nfs 192.168.218.*
在nfs客户端创建一个挂载目录。
[root@nfsa ~]# mkdir /nfs
[root@nfsa ~]# mount -t nfs 192.168.218.139:/nfs /nfs
[root@nfsa ~]# cat /nfs/hello
welcome to purple
可以将此写入开机自动挂载文件中
[root@nfsa ~]# vim /etc/fstab
192.168.10:/nfs /nfs nfs defaults 0 0
上一篇: 世界上最大的鱿鱼:巨型鱿鱼重达900斤