挂载NFS文件系统到云服务器(Linux)
当创建文件系统后,您需要使用云服务器来挂载该文件系统,以实现多个云服务器共享使用文件系统的目的。
前提条件
- 确定云服务器操作系统类型,不同操作系统安装NFS客户端的命令不同。
- 已完成创建文件系统,并获取到文件系统的挂载地址。
- 存在至少一台与文件系统所属VPC相同的云服务器。
操作步骤
- 使用云账号登录管理控制台。
- 登录管理控制台,选择区域和Project。
- 选择“计算 > 弹性云服务器”,进入管理控制台。
- 以root用户登录弹性云服务器。
若以非root用户登录弹性云服务器,具体操作请参考使用非root的普通用户挂载文件系统到Linux。
- 安装NFS客户端。
- 查看系统是否安装NFS软件包。
- CentOS、Red Hat、Oracle Enterprise Linux、SUSE、Euler OS、Fedora或OpenSUSE系统下,执行如下命令:
- Debian或Ubuntu系统下,执行如下命令:
如未显示,执行3.b。- CentOS、Red Hat、Euler OS、Fedora或Oracle Enterprise Linux系统下,回显如下类似信息:
libnfsidmap nfs-utils
- SUSE或OpenSUSE系统下,回显如下类似信息:
nfsidmap nfs-client
- Debian或Ubuntu系统下,回显如下类似信息:
nfs-common
- 如果查看到未安装,根据不同的操作系统,执行不同命令。
执行以下命令前要求云服务器已连接到互联网,否则安装NFS客户端失败。
- 查看系统是否安装NFS软件包。
- 执行如下命令,创建用于挂载文件系统的本地路径。
mkdir 本地路径
- 执行如下命令,将文件系统挂载到与文件系统所属VPC相同的云服务器上。文件系统目前仅支持NFSv3协议挂载到Linux云服务器。
其中变量说明见表1。
mount -t nfs -o vers=3,timeo=600,noresvport,nolock 挂载地址 本地路径
已挂载文件系统的云服务器重启后,该云服务器上的挂载信息将会丢失,您可以通过在fstab文件中配置自动挂载来保证云服务器重启时自动挂载文件系统,具体操作请参见自动挂载文件系统。
表1 参数说明 参数
说明
vers
文件系统版本,目前只支持NFSv3。取值:3。
timeo
NFS客户端重传请求前的等待时间(单位为0.1秒)。建议值:600。
resvport/noresvport
设置连接服务器是否使用保密源端口。默认的resvport为设置保密端口;noresvport设置为非保密端口。内核2.6.28及以后版本支持。
建议设置为noresvport,可指定网络在重新连接时使用新的TCP端口,以保障在网络发生故障恢复时连接不会中断。
lock/nolock
选择是否使用NLM协议在服务器上锁文件。当选择nolock选项时,锁对于同一主机的应用有效,对不同主机不受锁的影响。建议值:nolock。如不加此参数,则默认为lock,就会发生其他服务器无法对此文件系统写入的情况。
挂载地址
SFS Turbo文件系统的格式为:文件系统IP:/,例如192.168.0.0:/。如图1所示。
本地路径
云服务器上用于挂载文件系统的本地路径,例如“/local_path”。
挂载文件系统时,更多性能调优的挂载参数,可参考表2配置,各参数之间以逗号进行分隔。例如:
mount -t nfs -o vers=3,timeo=600,nolock,rsize=1048576,wsize=1048576,hard,retrans=3,noresvport,async,noatime,nodiratime 挂载地址 本地路径
表2 挂载参数 参数
说明
rsize
每次向服务器读取文件的最大字节数。实际数据小于或等于此值。rsize必须是1024倍数的正整数,小于1024时自动设为4096,大于1048576时自动设为1048576。默认时,服务器和客户端进行协商后设置。
建议设置为最大值1048576。
wsize
每次向服务器写入文件的最大字节数。实际数据小于或等于此值。wsize必须是1024倍数的正整数,小于1024时自动设为4096,大于1048576时自动设为1048576。默认时,服务器和客户端进行协商后设置。
建议设置为最大值1048576。
soft/hard
取值为soft,即软挂载方式挂载系统,若NFS请求超时,则客户端向调用程序返回错误;取值为hard,即使用硬连接方式,若NFS请求超时,则客户端一直重新请求直至成功。
默认为hard。
retrans
客户端返回错误前的重传次数。默认值为3。
resvport/noresvport
设置连接服务器是否使用保密源端口。默认的resvport为设置保密端口;noresvport设置为非保密端口。内核2.6.28及以后版本支持。
建议设置为noresvport,可指定网络在重新连接时使用新的TCP端口,以保障在网络发生故障恢复时连接不会中断。
sync/async
sync为同步写入,表示将写入文件的数据立即写入服务端;async为异步写入,表示将数据先写入缓存,再写入服务端。
同步写入要求NFS服务器必须将每个数据都刷入服务端后,才可以返回成功,时延较高。建议设置为async。
noatime
如果不需要记录文件的访问时间,可以设置该参数。避免频繁访问时,修改访问时间带来的开销。
nodiratime
如果不需要记录目录的访问时间,可以设置该参数。避免频繁访问时,修改访问时间带来的开销。
没有“使用建议”的参数推荐使用默认参数。
- 挂载完成后,执行如下命令,查看已挂载的文件系统。
mount -l
如果回显包含如下类似信息,说明挂载成功。挂载地址 on /local_path type nfs (rw,vers=3,timeo=600,nolock,addr=)
- 挂载成功后,用户可以在云服务器上访问文件系统,执行读取或写入操作。
若挂载失败或超时,请参考故障处理处理。
支持写入的单个文件最大容量为16TB。