NFS远程挂载
NFS远程挂载
一、概述
NFS是一种基于TCP/IP 传输的网络文件系统协议。通过使用NFS协议,客户机可以像访问本地目录一样访问远程服务器中的共享资源
NAS存储: NFS服务的实现依赖于RPC (Remote Process Call,远端过程调用)机制,以完成远程到本地的映射过程。
在Centos 7系统中,需要安装nfs-utils、 rpcbind 软件包来提供NFS共享服务,前者用于NFS共享发布和访问,后者用于RPC支持。
手动加载NFS共享服务时,应该先启动rpcbind, 再启动nfs。
nfs端口:2049
RPC端口:111
2.特点
采用TCP/IP传输网络文件
安全性低
简单易操作
适合局域网环境
二、nfs远程挂载实验
先准备两台虚拟机 一台当作服务端 另一台则是客户端
-
在服务端上安装nfs-utils rpcbind软件包
yum install nfs-utils rpcbind -y
-
创建测试文件夹用作客户端可访问的文件夹
mkdir /nfstest
-
开启rpcbind服务和nfs服务
systemctl start rpcbind systemctl start nfs
-
在/nfstest 目录下创建两个文件
touch /nfstest/只因你太美.txt touch /nfstest/鸡你太美.txt
-
修改nfstest文件权限 修改属主和属组
chmod -R 777 /nfstest/ chown -R nfsnobody.nfsnobody /nfstest/
-
修改配置文件 写入/nfstest *(insecure,rw,sync) 即可
文件目录 目标IP/端口(rw,sync,all_squash,anonuid=1000,anongid=1000)。
它主要分三部分,第一部分为共享出去的目录,第二部分为允许访问的ip,可以是一个IP,也可以是IP段,第三部分为小括号中的权限选项。rw 允许读写
ro 只读
sync 同步写入
async 先写入缓冲区,必要时才写入磁盘,速度快,但会丢数据
subtree_check 若输出一个子目录,则nfs服务将检查其父目录权限
no_subtree_check 若输出一个字目录,不检查父目录,提高效率
no_root_squash 客户端以root登录时,赋予其本地root权限
oot_squash 客户端以root登录时,将其映射为匿名用户
all_squash 将所有用户映射为匿名用户vim /etc/exports /nfstest *(insecure,rw,sync) `这里*设置全部地址都可,也可改为具体的ip地址`
-
准备客户端同样安装软件 启动服务
yum install nfs-utils rpcbind -y systemctl start rpcbind systemctl start nfs
-
查看服务端挂载情况 showmount -e ip
showmount -e x.x.x.x 显示如下: Export list for x.x.x.x: /nfstest *
-
把服务端的测试文件/nfstest文件挂载到客户端的client_nfs文件上
再次说明x.x.x.x为你的ip地址
这里我先创建被挂载的文件client_nfs mkdir /client_nfs mount挂载 mount -t nfs x.x.x.x:/nfstest/ /client_nfs/
-
ls 查看/client_nfs文件
ls /client_nfs/ 鸡你太美.txt 只因你太美.txt
注意:
-
因为以及设置了rw 可读写 权限 即可以在/client_nfs文件下创建文件 在服务端机器/nfstest文件下 也能看到所创建的文件
-
如果想取消挂载 umount 命令即可
注意不要在client_nfs目录下使用
umount /client_nfs
-
-
因为你挂载了服务端的文件,那么当你取消挂载,然后在客户端原先的client_nfs文件下创建文件,再进行挂载操作后,查看文件就会再显示,读取的都是挂载文件/nfstest的文件。
-
开机自动挂载
配置开机挂载服务,每次开机都能用nfs
-
把挂载命令写入到 开机启动挂载文件中
vim /etc/fstab 在下面添加 x.x.x.x:/nfstest /client_nfs nfs defaults 0 0
autofs自动挂载服务
如果开机就强制挂载很多内容,但是又不经常使用,会给服务器造成很大压力
因此一些具有动态特性的文件系统,可以选择进行动态挂载。比如:光盘、软盘、U盘、移动硬盘、NFS、SMB等文件系统
autofs特点
autofs和mount命令的不同点在于
autofs是一个守护进程,它会在后台检测用户是否要访问某一个还未挂载的文件系统,autofs会自动检测该文件系统是否存在,如果存在则进行挂载,如果用户过一段时间没有使用该文件系统,autofs自动将其卸载,节省人力维护成本,以及节省服务器资源
缺点:
autofs特点是,当用户请求时候才挂载文件系统,如果是高并发的业务场景,大量的用户并发访问文件系统,autofs突然进行大量的挂载,会给服务器造成很大压力,因此在一些高并发场景下,宁愿保持持续挂载,也不用autofs
-
安装autofs
yum install autofs -y
-
编辑 /etc/auto.master
/misc /etc/auto.misc //在这一行下面添加如下语句 (第七行) /- /etc/auto.home
-
编辑/etc/auto.home文件
/client_nfs -rw,soft,intr x.x.x.x:/nfstest
-
启动autofs
systemctl start autofs
-
检查/client_nfs文件是否挂载了 如果挂载了可以umount取消挂载
[root@localhost ~]# df -h 文件系统 容量 已用 可用 已用% 挂载点 devtmpfs 476M 0 476M 0% /dev tmpfs 487M 0 487M 0% /dev/shm tmpfs 487M 7.7M 479M 2% /run tmpfs 487M 0 487M 0% /sys/fs/cgroup /dev/sda2 19G 1.9G 18G 10% / /dev/sda1 1014M 132M 883M 13% /boot tmpfs 98M 0 98M 0% /run/user/0
-
查看/client_nfs文件 会自动挂载并显示/nfstest文件中的内容
[root@localhost ~]# ls /client_nfs/ 鸡你太美.txt 只因你太美.txt
-
再次查看挂载情况
[root@localhost ~]# df -h 文件系统 容量 已用 可用 已用% 挂载点 devtmpfs 476M 0 476M 0% /dev tmpfs 487M 0 487M 0% /dev/shm tmpfs 487M 7.7M 479M 2% /run tmpfs 487M 0 487M 0% /sys/fs/cgroup /dev/sda2 19G 1.9G 18G 10% / /dev/sda1 1014M 132M 883M 13% /boot tmpfs 98M 0 98M 0% /run/user/0 x.x.x.x:/nfstest 19G 2.9G 17G 15% /client_nfs
-
当一段时间不操作,之后autofs会自动卸载该设备
-