【AWS AMI跨境备份】跨境使用 S3 备份和还原 AMI 镜像

ops/2024/10/18 3:00:02/

文章目录

    • 一、实验场景
    • 二、实验目标
    • 三、实验架构图
    • 四、涉及到AWS服务
    • 五、演示操作
      • 5.1 创建EC2实例
      • 5.2 创建映像
      • 5.3 备份AMI至Global S3
      • 5.4 复制AMI从Global S3至 CN S3
      • 5.5 还原AMI
      • 5.6 测试AMI
    • 六、参考链接

一、实验场景

将 AWS Global区域的EC2实例备份至 AWS CN区域。

备份方式:通过 AMI 镜像的方式;

备份频率:2次/月;

备份镜像:可能涉及镜像许可问题;

二、实验目标

  1. 跨境备份和还原所需要的AMI镜像(包括但不限于Windows、Linux等映像);
  2. 利用S3 存储的生命周期管理功能,每周备份一次 AMI 镜像至CN区的 S3 指定的存储桶中;
  3. 还原S3中备份的AMI镜像,查看该 AMI 是否能够正常使用;

三、实验架构图

image-20241016122037963

四、涉及到AWS服务

S3、EC2、AWS CLI2

五、演示操作

5.1 创建EC2实例

1️⃣以美国东部 (弗吉尼亚北部) us-east-1为例;

2️⃣EC2名称:EC2-AMI-Backup;

3️⃣Amazon Machine Image (AMI) 名称:Amazon Linux 2023 AMI;

Amazon Linux 2023 是基于 Linux 的现代化通用操作系统,提供 5 年的长期支持。它针对 AWS 进行了优化,旨在提供一个安全、稳定和高性能的执行环境来开发和运行您的云应用程序。

4️⃣Amazon Machine Image (AMI) ID:ami-06b21ccaeff8cd686 (64 位(x86), uefi-preferred) / ami-02801556a781a4499 (64 位(ARM), uefi)

image-20241015111342053

image-20241015111355697

image-20241016111441837

  • 安装Docker
Step 1: Update AL2023 Packages
sudo dnf updateStep 2. Installing Docker on Amazon Linux 2023
sudo dnf install dockerStep 3: Start and Enable its Service
sudo systemctl start docker && sudo systemctl enable docker && sudo systemctl status dockerStep 4: Allow docker to run without sudo
sudo usermod -aG docker $USERStep 5: Docker Uninstallation (optional)
sudo dnf remove docker
  • 安装Docker-Compose
Step 1: To download and install Compose standalone, run:
curl -SL https://github.com/docker/compose/releases/download/v2.29.6/docker-compose-linux-x86_64 -o /usr/local/bin/docker-composeStep 2: Apply executable permissions to the standalone binary in the target path for the installation.
cd /usr/local/bin/docker-compose
chmod +x docker-composeStep 3: Test and execute compose commands using docker-compose.
sudo ln -s /usr/local/bin/docker-compose /usr/bin/docker-compose
  • 安装WordPress

image-20241015231141948

  • 访问WordPress

image-20241016103112484

5.2 创建映像

依次点击操作——映像和模板——创建映像

image-20241015232855692

填写映像名称。

image-20241015233010655

查看确认AMI状态,是否是“可用”。

image-20241015233234361

确认该状态已经变为可用

image-20241015233915205

在快照一栏中,我们也可以发现该EC2快照。

image-20241015233807189


以下是使用CLI命令进行操作:

注意:需要提前在运行环境中配置好AWS CLI命令运行配置信息。

aws ec2 create-image --instance-id <id> --name <name>C:\Users\xyb>aws ec2 create-image --instance-id i-0625f12dd36562e05 --name EC2-AMI-Backup-CLI
{"ImageId": "ami-0d3ffbc792ff21ba9"
}

image-20241015235228484

5.3 备份AMI至Global S3

# 创建s3存储桶
aws s3api create-bucket \--bucket my-bucket \--region us-east-1# 备份镜像至S3存储桶🪣中
aws ec2 create-store-image-task \--image-id ami-1234567890abcdef0 \--bucket my-ami-bucket
aws s3api create-bucket --bucket my-ami-bucket-xybdiy --region us-east-1aws ec2 create-store-image-task --image-id ami-03263c5d606a74023 --bucket my-ami-bucket-xybdiy

报错提示:提示该存储桶名称已存在,需要重新选择新的存储桶名称进行尝试。

image-20241016000400169

  • 执行如下命令,备份AMI镜像至Globa区域的指定的S3存储桶里。
C:\Users\xyb>aws ec2 create-store-image-task --image-id ami-03263c5d606a74023 --bucket my-ami-bucket-xybdiy
{"ObjectKey": "ami-03263c5d606a74023.bin"
}

截图示例:

image-20241016000605519

  • 执行命令,查看该AMI镜像任务进度。
aws ec2 describe-store-image-tasks
C:\Users\xyb>aws ec2 describe-store-image-tasks
{"StoreImageTaskResults": [{"AmiId": "ami-03263c5d606a74023","TaskStartTime": "2024-10-15T16:05:39.813000+00:00","Bucket": "my-ami-bucket-xybdiy","S3objectKey": "ami-03263c5d606a74023.bin","ProgressPercentage": 100,"StoreTaskState": "Completed","StoreTaskFailureReason": ""}]
}

查看该镜像已经打包上传至存储桶中。

image-20241016001414905

5.4 复制AMI从Global S3至 CN S3

# 登录AWS境内账号,创建存储桶。
aws s3api create-bucket --bucket my-bucket-cn-xybdiy --region cn-northwest-1 --create-bucket-configuration LocationConstraint=cn-northwest-1
{"Location": "http://my-bucket-cn-xybdiy.s3.cn-northwest-1.amazonaws.com.cn/"
}

Global 区域存储桶:

image-20241016100157530

  • 执行如下命令,上传.bin至CN区域存储桶。
aws s3 cp ami-03263c5d606a74023.bin s3://my-bucket-cn-xybdiy

截图示例:
image-20241016101310838

  • 上传完成。

image-20241016101835242

CN 区域存储桶:

image-20241016101904035

5.5 还原AMI

# 示例
aws ec2 create-restore-image-task \--object-key ami-03263c5d606a74023.bin   \--bucket my-ami-bucket-xybdiy \--name "AMI-CN"
  • 执行如下命令,还原AMI。
aws ec2 create-restore-image-task --object-key ami-03263c5d606a74023.bin --bucket my-bucket-cn-xybdiy --name EC2-AMI-CN-Backup

image-20241016102258540

  • 在控制台中,我们可以查看到AMI镜像。

image-20241016102508444

5.6 测试AMI

  • 选择从 AMI 启动实例

image-20241016102614595

image-20241016102753618

image-20241016102808130

image-20241016103022280

测试WordPress服务是否能够正常访问。

image-20241016103631181

六、参考链接

💻 https://docs.aws.amazon.com/zh_cn/AWSEC2/latest/UserGuide/ami-store-restore.html

🔆 AWS CLI Command Reference — AWS CLI 2.18.7 Command Reference

📍 https://megazone.com/cn/ec2-instance-migration/


http://www.ppmy.cn/ops/126369.html

相关文章

NFTScan | 10.07~10.13 NFT 市场热点汇总

欢迎来到由 NFT 基础设施 NFTScan 出品的 NFT 生态热点事件每周汇总。 周期&#xff1a;2024.10.07~ 2024.10.13 NFT Hot News ​01/ 数据&#xff1a;9 月份加密市场大多数指标均出现下降&#xff0c;链上总交易量下降 13% 10 月 7 日&#xff0c;据 The Block 研究总监 la…

4G模组PSM+超低功耗详解,该选择那种功耗模式?

合宙4G-Cat.1模组支持三种功耗模式&#xff1a;常规模式、低功耗模式、PSM模式。 很多客户的实际应用场景&#xff0c;是不需要和服务器保持长连接的&#xff0c;一天甚至一周上传一两次数据&#xff0c;就能满足实际的项目需求了。 如果用合宙推荐的第二种低功耗模式&#x…

12.5 Linux_进程间通信_信号灯

概述 什么是信号灯&#xff1a; 信号灯也称为信号量&#xff0c;代表的是一类资源&#xff0c;其值表示系统中该资源的数量。 主要用途是实现进程、线程的同步。 什么是P/V操作&#xff1a; P操作就是申请资源&#xff0c;V操作就是释放操作。 信号灯的种类&#xff1a; …

了解Android中的事件分发机制

Android中的事件分发机制详解 在Android开发中&#xff0c;事件分发机制是处理用户输入事件&#xff08;如触摸、点击、滑动等&#xff09;的核心部分。深入理解这一机制对于开发者来说至关重要&#xff0c;它有助于我们更好地处理用户输入&#xff0c;提升应用的交互体验。以…

从MySQL到OceanBase离线数据迁移的实践

本文作者&#xff1a;玉璁&#xff0c;OceanBase 生态产品技术专家。工作十余年&#xff0c;一直在基础架构与中间件领域从事研发工作。现负责OceanBase离线导数产品工具的研发工作&#xff0c;致力于为 OceanBase 建设一套完善的生态工具体系。 背景介绍 在互联网与云数据库技…

【Kubernets】容器网络基础二:通讲CNI(Container Network Interface)容器网络接口实现方案

文章目录 背景知识Underlay网络Overlay网络一、基本概念二、工作原理三、实现方案四、应用场景 两者对比示意图 CNI实现有哪些&#xff1f;FlannelFlannel 的工作原理Flannel 的主要组件数据传输机制总结 Calico一、架构基础二、核心组件与功能三、路由与数据包转发四、安全策略…

jvm介绍

JVM&#xff0c;即Java虚拟机&#xff08;Java Virtual Machine&#xff09;&#xff0c;是运行Java程序的抽象平台。它是一个能够执行Java字节码的虚拟机实例&#xff0c;负责将Java字节码转换为特定平台上的机器码并执行。下面我将从几个方面对JVM进行详细介绍&#xff1a; 1…

串口空闲中断加DMA数据搬运

1 usart.c #include "stm32f10x.h" // Device header #include <stdio.h> #include <stdarg.h>//void Serial_Init(void) //{ // //使能GPIOA 以及串口1的时钟 // RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA|RCC_APB2Periph_US…