本文主要介绍如何将SMB文件系统挂载至云服务器ECS(Linux)上并执行读写操作。
前提条件
注意 Linux系统推荐挂载使用NFS文件系统。由于Linux系统对SMB协议的兼容程度较低,建议仅在需要跨操作系统共享数据的情况下使用Linux系统挂载SMB文件系统。
- 在需要创建文件系统的地域,已有可用的云服务器ECS(Linux)。具体操作,请参见创建ECS实例。
SMB文件系统现在官方支持如下的Linux操作系统版本。如果没有特别声明,本文仅针对以下Linux操作系统版本:
- CentOS 7.6 64bit(3.10.0-957.5.1.el7.x86_64)
- Ubuntu 18.04 64bit(4.15.0-48-generic)
- Debian 9.9 64bit(4.9.0-9-amd64)
- Suse Enterprise Server 12 SP2 64bit(4.4.74-92.35-default)
- OpenSUSE 42.3 64bit(4.4.90-28-default)
- Alibaba Cloud Linux(4.19.34-11.al7.x86_64)
- CoreOS(4.19.43-coreos VersionID=2079.4.0)
说明 由于Linux一些早期版本的SMB客户端在某些场景有缺陷,如果您使用了非官方支持的Linux操作系统版本,阿里云不能保证该SMB文件系统的可靠性。 - 已创建SMB文件系统。具体操作,请参见通过控制台创建通用型NAS文件系统。
- 已添加挂载点。具体操作,请参见添加挂载点。
- 网络连通。
- 确保云服务器ECS(Linux)和SMB文件系统在同一个专有网络VPC中。
- 检查文件系统白名单,确保云服务器ECS(Linux)已经被授予访问该SMB文件系统的权限。
- 确保端口445处于打开状态,SMB文件系统将通过TCP端口445通信。
如果端口445未打开,请在目标ECS实例的安全组中添加关于端口445的安全组规则。具体操作,请参见添加安全组规则。
安装软件
在Linux操作系统中安装cifs-utils工具包。
- 如果您使用Ubuntu或Debian操作系统,通过apt-get软件包管理工具进行安装。
sudo apt-get update
sudo apt-get install cifs-utils
- 如果您使用RHEL、CentOS、Alibaba Cloud Linux操作系统,通过yum包管理器进行安装。
sudo yum install cifs-utils
- 如果您使用OpenSUSE、SLES12-SP2操作系统,通过zypper或yast工具进行安装。
sudo zypper install cifs-utils
sudo yast2 -> Software -> Software Management, 然后安装cifs-utils
- 如果您使用CoreOS操作系统,通过以下方法进行安装:
- 配置SELINUX。
sed -i 's/SELINUXTYPE=mcs/SELINUXTYPE=targeted/' /etc/selinux/config
- 在CoreOS操作系统上手动编译cifs-utils客户端工具。
您可以执行以下命令启动一个Fedora容器用以编译cifs-utils客户端工具。或下载阿里云官方提供的CoreOS版本的cifs-utils工具包,并拷贝至/tmp/或者/bin目录。
$ docker run -t -i -v /tmp:/cifs fedora /bin/bash fedora # yum groupinstall -y "Development Tools" "Development Libraries" fedora # yum install -y bzip2 fedora # curl https://download.samba.org/pub/linux-cifs/cifs-utils/cifs-utils- 6.9.tar.bz2 --output cifs-utils-6.9.tar.bz2; fedora # bunzip cifs-utils-6.9.tar.bz2; && tar xvf cifs-utils-6.9.tar fedora # cd cifs-utils-6.9; ./configure && make fedora # cp mount.cifs /cifs/ fedora # exit
- 配置SELINUX。
挂载文件系统
经典使用场景
不同的使用场景,可配置不同的挂载选项,实现文件系统最优性能。经典的使用场景及挂载选项配置如下所示:
- 云服务器ECS(Linux)共享访问场景
在多个云服务器ECS(Linux)中需要共享访问文件系统数据,但没有用户权限控制要求,被授权的云服务器ECS(Linux)管理员可以使用如下方法在各个云服务器ECS(Linux)上执行挂载。
mount -t cifs //smbfs.hangzhou-g.aliyun.com/myshare /mnt/sharepath -o vers=2.1,guest,mfsymlinks
- 多用户Home Directory场景
在多个云服务器ECS(Linux)中需要共享访问文件系统数据时,如果有权限控制需求,可以通过挂载时指定uid、gid、dir_mode、file_mode参数实现。
- 云服务器ECS(Linux) WebServer共享访问场景
在多个云服务器ECS(Linux)上安装WebServer(如apache),且SMB文件系统作为共享文件存储。说明
- SMB文件系统主要特点是共享访问、横向扩展、高可用,由于和本地硬盘实现机理不同,某些场景的小文件访问性能上会稍微有一些差距。对于WebServer场景,如果想要达到极致性能,可以考虑只将需要共享的文件放在SMB文件系统上,而将不需要共享访问的WebServer程序等放在本地硬盘。
- WebServer应用通常网络协议通讯负载较大,此场景需要开通WebServer加速功能,请您联系阿里云NAS团队申请开通。
- 云服务器ECS(Windows)和云服务器ECS(Linux)共享访问场景
如果您需要同时从云服务器ECS(Windows)和云服务器ECS(Linux)访问SMB文件系统的内容。则需要在云服务器ECS(Linux)挂载时一定使用客户端缓存,即设置cache=strict或者默认方式挂载。