写点什么

如何在云上快速搭建 NFS

  • 2019-10-28
  • 本文字数:2503 字

    阅读完需:约 8 分钟

如何在云上快速搭建 NFS

简介

传统架构中我们常使用 NFS 来作为共享文件的存储。那么在搬迁到云中的时候我们该如何快速搭建相应的 NFS 系统?


本文将为您介绍快速搭建 NFS 系统的解决方案的四个关键词,分别是:


· 利用适用于文件的 AWS Storage Gateway 搭建云中 NFS


· 在 EC2 上使用 NFS


· NFS 只在 VPC 内网可连


· 工作于由光环新网运营的 AWS 中国(北京)区域

服务简介

File Gateway

文件网关提供了一个文件接口,让您可以使用行业标准 NFS 文件协议将文件作为对象存储在 Amazon S3 中,并通过 NFS 从您的数据中心或 Amazon EC2 访问这些文件,或通过 S3 API 以对象形式访问这些文件。所有权、权限和时间戳作为与该文件关联的对象的用户元数据,永久存储在 S3 中。当对象传输到 S3 之后,它们可以作为原生 S3 对象进行管理,版本控制、生命周期管理和跨区域复制等存储桶策略将直接应用于存储在存储桶中的对象。


客户使用文件网关 NFS 接口将文件数据存储到 S3 中,这些数据便可以供基于对象的工作负载使用,用作传统备份应用程序的经济高效的存储目标,或者用作应用程序文件存储的云端存储库或存储层。

在 EC2 上使用 File Gateway 作为 NFS


工作方式:


· 对象数据存储在 S3 中,提供数据可靠性和持久性


· Gateway 缓存为一个 EC2 实例,和 S3 定期同步数据


· 使用 NFS 的实例与 gateway 缓存实例交流读写数据

搭建步骤

创建网关

  1. 创建 Storage Gateway, 选择文件网关类型



  1. 选择 Amazon EC2 作为主机平台,按照设置说明配置 VPC,主机类型,添加新 EBS 卷,安全组等。


注意:


1)我们将配置 NFS 服务器只在 VPC 可连,所以请禁用自动分配公有 IP 选项


2)对添加的 EBS 卷,设置大小在 150G 以上


3)在安全组上临时配置安全策略,允许 VPC 内其它机器通过 80 端口访问该机器


4)保证该机器能够访问公网,一般通过 NAT 网关(https://docs.aws.amazon.com/zh_cn/AmazonVPC/latest/UserGuide/vpc-nat-gateway.html)等方式实现。



  1. 等待 EC2 创建完成,点击进入 EC2 详情页,记录下该机器的私有 IP (下文称该 IP 为: Gateway 私有 IP)

链接并激活网关

  1. 在 IAM 中创建新的 EC2 角色,配置拥有 AWS Storage Gateway Full Access




  1. 在同一个 VPC 中创建另外一台临时的 EC2 实例(Amazon Linux),并满足以下条件


a. 能够使用 SSH 登录


b. 绑定上一步中创建的 EC2 角色(ec2-storage-gateway)


  1. SSH 登录到临时 EC2 实例

  2. 运行以下命令得到 gateway 实例的激活码


curl -I [gateway 私有 IP]/?activationRegion=cn-north-1



记录下激活码 activationKey 的值


  1. 运行以下命令激活 file gateway


aws storagegateway activate-gateway –activation-key [activationKey] –gateway-name [gateway name] –gateway-timezone “[time zone]” –gateway-region cn-north-1 –gateway-type FILE_S3 –region cn-north-1



激活成功后命令返回 GatewayARN


  1. 返回 Storage Gateway,检查 my_gateway 是否已经建立



  1. 点击 my_gateway,编辑本地磁盘,将创建时添加的 EBS 卷配置成缓存,并且保存。

关联 S3 和 file gateway

1.点击并创建文件共件



2.配置文件共享设置。


1)选择网关 my_gateway


2)S3 存储段名称填写 s3 存储桶名称,可以为现有的 s3 存储桶,也可以新建一个



  1. 在 S3 存储桶和 file gateway 不在同一账号的情况下,我们也可以关联两者。需要在 S3 存储桶上额外设置存储桶策略。如果只是同一账号的情景,请直接跳到下一步。


注意:以下策略中的 Principal 中配置的角色为上一步中自动创建的新 IAM 角色。可以在 IAM 界面中查询到。


Json

{
                "Version": "2012-10-17",
    "Id": "FGWPolicy",
    "Statement": [
        {
            "Sid": "FGWStmt",
            "Effect": "Allow",
            "Principal": {
                "AWS": "arn:aws-cn:iam::[account id]:role/service-role/StorageGatewayBucketAccessRole8e94d222-b375-4f29-ac2a-99d77c1bf3"
            },
            "Action": "s3:*",
            "Resource": [
                "arn:aws-cn:s3:::images-andrew",
                "arn:aws-cn:s3:::images-andrew/*"
            ]
        }
    ]
}


当然,你也可以控制 file gateway 账户只对 S3 存储桶拥有只读权限。


Json

{
    "Version": "2012-10-17",
    "Id": "FGWPolicy",
    "Statement": [
        {
            "Sid": "FGWStmt",
            "Effect": "Allow",
            "Principal": {
                "AWS": "arn:aws-cn:iam::[account id]:role/service-role/StorageGatewayBucketAccessRole8e94d222-b375-4f29-ac2a-99d77c1bf3"
            },
            "Action": [
                "s3:Get*",
                "s3:List*"
            ],
            "Resource": [
                "arn:aws-cn:s3:::images-andrew",
                "arn:aws-cn:s3:::images-andrew/*"
            ]
        }
    ]
}


4.点击下一步,确认,等待文件共享状态变为可用。


在 Ec2 上使用 file gateway 上的 NFS

  1. 登录已经创建的临时 EC2 实例。我们将在该机器上测试 NFS 的配置。

  2. 运行以下命令


sudo mount -t nfs -o nolock [gateway 私有 IP]:/[s3 存储桶名] [MountPath]



  1. 成功 mount 后,您就可以在/nfs 文件夹看到 s3 存储桶中的内容了。您可以添加,删除,或者查看这些内容。


注意: 您在/nfs 文件夹下的操作会直接映射到 gateway 缓存实例上。缓存实例会定期和 S3 做同步。所以如果您添加了一个文件在/nfs 中,过若干秒就能在 S3 存储桶中看到它了。

注意事项

Gateway 缓存实例在该架构中为一个潜在的单点故障,建议使用一些机制来减小它的影响。比如在该机器上设置自动恢复机制。详情请参考:


https://docs.aws.amazon.com/zh_cn/AWSEC2/latest/UserGuide/ec2-instance-recover.html


作者介绍:


任庆杰


任庆杰,AWS解决方案架构师。负责基于AWS的云计算方案架构的咨询和设计,同时致力于AWS云服务在国内和全球的应用和推广。在加入AWS前,拥有超过7年的软件开发和IT项目管理经验。
复制代码


本文转载自 AWS 技术博客。


原文链接:


https://amazonaws-china.com/cn/blogs/china/how-to-establish-nfs


2019-10-28 08:00747

评论

发布
暂无评论
发现更多内容

python使用命令行传入参数

卤蛋翔

6月日更

官宣!禅道与极狐(GitLab)达成深度合作,携手推进开源开放DevOps生态发展

禅道项目管理

项目管理 DevOps gitlab

23种设计模式,正确的解读方式原来是这样

Java架构师迁哥

分享:在阿里做Java开发的这五年,收获与感悟

Java架构师迁哥

蓝海战略 - 如何设计与众不同的价值曲线

石云升

战略思考 职场经验 6月日更

你想进大厂吗?阿里Java面试“内幕”分享

Java架构师迁哥

defi流动性挖矿系统开发(案例版)丨defi流动性挖矿源码现成版

系统开发咨询1357O98O718

【干货篇】bilibili:基于 Flink 的机器学习工作流平台在 b 站的应用

Apache Flink

flink

OGA 联盟正式成立!禅道作为理事单位助力共建开源生态!

禅道项目管理

项目管理 DevOps gitlab

Flink 在有赞的实践和应用

Apache Flink

flink

拍乐云推出业内首个「线上美术教学音视频方案」,打造极致互动体验

拍乐云Pano

大数据好书推荐

五分钟学大数据

阿里P8熬了一个月肝出这份32W字Java面试手册,在Github标星68K+

Java 程序员 面试

系统性思维 系统之美2

张老蔫

28天写作

系统性思维 系统之美1

张老蔫

28天写作

拍乐云受邀QCon大会 | 详解音视频技术架构实践,首发美术教学音视频方案

拍乐云Pano

2021金三银四面试经历:腾讯三面落马+拒网易、CVTE后,字节四面成功拿下offer

Java 程序员 架构 面试

联邦计算在百度观星盘的实践

百度Geek说

从零开始学习3D可视化之控制对象(2)

ThingJS数字孪生引擎

可视化 数据化 3D 3D可视化

新大陆!阿里P9整理出:Java架构师“成长笔记”共计23版块

Java架构师迁哥

持续测试 | 测试流程提效:在 CODING 中实践迭代内的持续测试

CODING DevOps

DevOps 测试计划 持续测试 迭代式测试

OpenYurt v0.4.0 新特性发布:高效地管理边缘存储资源

阿里巴巴云原生

云原生

defi流动性挖矿系统开发案例分析,defi流动性挖矿现成源码

系统开发咨询1357O98O718

研发自动化,你准备好了么?

PingCode研发中心

研发管理 研发效能 研发工具 研发团队

如何设置HashMap初始化大小

Hex

后端 hashmap

《原则》(三)

Changing Lin

百度开发者中心全新升级 | 文末六一送福利

百度开发者中心

百度 福利

反洗钱监管再度升级,看这家金融集团如何应对

索信达控股

大数据 银行 金融监管 风险管理 数据管理

龙蜥专场精彩回放来了!10位技术大咖、242位开发者相聚

阿里云基础软件团队

百度搜索与推荐引擎的云原生改造

百度开发者中心

云原生

defi流动性系统开发案例详情丨defi流动性源码功能

系统开发咨询1357O98O718

如何在云上快速搭建 NFS_语言 & 开发_亚马逊云科技 (Amazon Web Services)_InfoQ精选文章