(zt) Amazon EC2 实践概要

2024-04-03 19:32
文章标签 实践 概要 amazon ec2 zt

本文主要是介绍(zt) Amazon EC2 实践概要,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

From: http://blog.csdn.net/tienway/archive/2010/03/16/5386119.aspx

亚马逊将他们的云计算平台称为弹性计算云(Elastic Compute Cloud,EC2),它是最早提供远程云计算平台服务的公司。早在2006年3月,亚马逊就发布了简单存储服务(Simple Storage Service,S3)。

亚马逊网络服务平台使用REST (Representational State Transfer)和简单对象访问协议(SOAP)等标准接口,用户可以通过这些接口访问到相应的存储服务。

核心概念

l          Amazon EC2(Amazon Elastic Compute Cloud):是web service,目的是使得用户可以发起和管理Amazon数据中心的Linux/UNIX 和Windows 服务器实例。Amazon EC2提供虚拟主机服务,主要可以随需添加“机器”,硬盘等,达到快速扩展的目地。

l         Amazon S3(Amazon Simple Storage Service):是一个公开的服务,Web 应用程序开发人员可以使用它存储数字资产,包括图片、视频、音乐和文档。 S3 提供一个 RESTful API 以编程方式实现与该服务的交互。

l         Amazon AMI(Amazon Machine Image):相当于一套业务系统的snapshot,保存到Amazon S3中,它包含启动业务应用实例必需的所有信息。

l         Instance:运行着的业务系统实例,该实例基于AMI产生,是执行AMI产生的系统,可以基于同一个AMI产生很多实例,共同对外提供服务,一般来说,一个Instance对应一个虚拟机。

l         Instance Type:Amazon为了满足不同Instance的计算需求,提供了灵活的资源提供方式:Standard, High-Memory and High-CPU,m1.small,m1.large,m1.xlarge三种为standard类型,m2.xlarge,m2.2xlarge,m2.4xlarge为High-Memory 类型,c1.medium,c1.xlarge为High-CPU类型。

l         Regions:Amazon EC2支持在多个不同地理位置的区域发起实例,在每一个Region,都有一个标准的数据中心,提供EC2服务。

l          AWS(Amazon Web Services):EC2 AWS提供了在Amazon的计算环境中运行企业应用的能力。

 

要想自己的企业应用运行于Amazon的云计算环境中,做法比较简单,只需要利用Amazon提供的工具、登录Amazon AWS门户网站进行相应的操作即可。

准备工作

  • 下载Amazon的命令行工具ec2-api-tools,需要的JRE为1.5以上;
  • 如果访问Linux and UNIX 实例,需要一个SSH客户端;如果访问Windows 实例,需要一个远程桌面连接客户端;
  • 为了使用Amazon EC2,必须注册AWS账号(http://aws.amazon.com/),注册Amazon S3账号(http://aws.amazon.com/s3/),注册Amazon EC2账号((http://aws.amazon.com/)),这三个账号的注册是独立注册,并且是必须的;
  • Amazon S3账号是为了存储或者取回Amazon EC2 AMIs;
  • 得到Key identifiers(访问证书X.509 Certificate):设置ec2-api-tools时使用;

 

开发步骤

第一步:

建立自己的企业应用,并打包到AMI中,该AMI包含你应用所有依赖的软件,包括操作系统以及相关配置、业务应用、依赖的运行库等等。

如何制作AMI,不用担心,Amazon提供了必需的工具为你创建和打包AMI。

第二步:

上传你的AMI包到Amazon S3(Amazon Simple Storage Service)服务存储中。在Amazon S3下,我们可以安全可信的访问我们的AMI。

第三步:

在Amazon EC2平台上,注册你的AMI,通过这个步骤,校验上传AMI是否正确,并且申请到为一个AMI ID。

第四步:

借助AMI ID和Amazon EC2提供的web服务API,就可以运行、监控、终止AMI申请的实例。当前,Amazon提供了命令行工具和java库,你可以直接访问Amazon提供的SOAP或者基于API的查询。

 

制作AMI

AMI是一个基本的部署单元,作为一个基本单元,可以启动一个对应的客户端实例。所有的AMI被保存在Amazon S3中,Amazon S3存储数据对象在bucket中,一个bucket有一个全局唯一的名字,并且仅仅属于专用的用户。上传MAI时,需要指定一个bucket,如果已经存在,则上传失败。

制作AMI有两种方式:

基于已经存在的AMI模板,首先选择一个已经存在的AMI,然后启动一个AMI Instance,通过SSH服务,访问并控制AMI Instance。

建立Loopback File,这种方式比较麻烦,具体可以参考Amazon的官方文档。

 

设置ec2-api-tools

首先从http://developer.amazonwebservices.com/connect/entry.jspa?externalID=351&categoryID=88下载ec2-api-tools,Amazon提供了Windows 2000/XP and Linux/UNIX/Mac版本。下载后是一个zip包,直接解压缩即可。

 

1、  ec2-api-tools的运行依赖于环境变量EC2_HOME,查找需要的库文件。EC2_HOME指向ec2-api-tools的安装路径ec2-api-tools-A.B-nnnn (A,B标识版本编号,n标识为修订编号)。

set EC2_HOME=c:\amazon\ec2\ec2-api-tools-1.3-46266

 

2、  ec2-api-tools需要在申请Amazon EC2 服务时产生的证书与密钥,以便在用命令行发出请求时,确知身份。为了不用每次使用命令行时,都去指定证书与密钥,可以通过设置环境变量,windows下:

set EC2_PRIVATE_KEY=c: \amazon\ec2\pk-HKZYKTAIG2ECMXYIBH3HXV4ZBZQ55CLO.pem

set EC2_CERT=c:\amazon\ec2\cert-HKZYKTAIG2ECMXYIBH3HXV4ZBZQ55CLO.pem

3、  指定Amazon EC2使用的Region,默认情况下,Amazon EC2工具使用Eastern United States region (us-east-1),指向us-east-1.ec2.amazonaws.com 服务节点。通过ec2-describe-regions指令,查询可用的regions,然后通过set EC2_URL=<service_endpoint>,修改使用的region。

 

运行一个Instance

以windows实例为例。

  • 运行一个Instance实例,需要的前提条件:
  • 预装1.5.0以及以上的JRE,设置JAVA_HOME环境变量;
  • 确信有AWS账号,并且在Amazon S3和Amazon EC2注册;
  • 确信在ec2路径下有X.509证书和私钥;
  • 设置了EC2_HOME、EC2_CERT and EC2_PRIVATE_KEY环境变量;

 

1、  使用ec2-describe-images发现可以使用AMI以及信息;

2、  因为Amazon EC2需要使用SSH 密钥对获取windows登录密钥。因此首先获取SSH密钥对,一般保存到本地一个密钥文件中;

3、  使用ec2-run-instances <ami_id> -k <keypair-name>启动一个Instance,此命令将返回AMI实例的ID;

4、  使用ec2-describe-instances <instance_id>查询Instance的状态;

 

Amazon EC2的基本情况(资料来自网络):

  • 磁盘系统使用 RAID 构建
  • 大部分服务器在美国,小部分在欧洲,位于美国的服务器性能占了总量的 75-80%。
  • 各类 Instance 背后的硬件结构都是相似的,亚马逊在所有服务器之间协调资源,没有特意为不同的 Instance 购置不同的服务器。
  • EC2 最初的目标利用率是 70 - 75%。

<script type="text/javascript"></script>

这篇关于(zt) Amazon EC2 实践概要的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/873782

相关文章

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

系统架构师考试学习笔记第三篇——架构设计高级知识(20)通信系统架构设计理论与实践

本章知识考点:         第20课时主要学习通信系统架构设计的理论和工作中的实践。根据新版考试大纲,本课时知识点会涉及案例分析题(25分),而在历年考试中,案例题对该部分内容的考查并不多,虽在综合知识选择题目中经常考查,但分值也不高。本课时内容侧重于对知识点的记忆和理解,按照以往的出题规律,通信系统架构设计基础知识点多来源于教材内的基础网络设备、网络架构和教材外最新时事热点技术。本课时知识

Prometheus与Grafana在DevOps中的应用与最佳实践

Prometheus 与 Grafana 在 DevOps 中的应用与最佳实践 随着 DevOps 文化和实践的普及,监控和可视化工具已成为 DevOps 工具链中不可或缺的部分。Prometheus 和 Grafana 是其中最受欢迎的开源监控解决方案之一,它们的结合能够为系统和应用程序提供全面的监控、告警和可视化展示。本篇文章将详细探讨 Prometheus 和 Grafana 在 DevO

springboot整合swagger2之最佳实践

来源:https://blog.lqdev.cn/2018/07/21/springboot/chapter-ten/ Swagger是一款RESTful接口的文档在线自动生成、功能测试功能框架。 一个规范和完整的框架,用于生成、描述、调用和可视化RESTful风格的Web服务,加上swagger-ui,可以有很好的呈现。 SpringBoot集成 pom <!--swagge

vue2实践:el-table实现由用户自己控制行数的动态表格

需求 项目中需要提供一个动态表单,如图: 当我点击添加时,便添加一行;点击右边的删除时,便删除这一行。 至少要有一行数据,但是没有上限。 思路 这种每一行的数据固定,但是不定行数的,很容易想到使用el-table来实现,它可以循环读取:data所绑定的数组,来生成行数据,不同的是: 1、table里面的每一个cell,需要放置一个input来支持用户编辑。 2、最后一列放置两个b

【HarmonyOS】-TaskPool和Worker的对比实践

ArkTS提供了TaskPool与Worker两种多线程并发方案,下面我们将从其工作原理、使用效果对比两种方案的差异,进而选择适用于ArkTS图片编辑场景的并发方案。 TaskPool与Worker工作原理 TaskPool与Worker两种多线程并发能力均是基于 Actor并发模型实现的。Worker主、子线程通过收发消息进行通信;TaskPool基于Worker做了更多场景化的功能封装,例

vue2实践:第一个非正规的自定义组件-动态表单对话框

前言 vue一个很重要的概念就是组件,作为一个没有经历过前几代前端开发的我来说,不太能理解它所带来的“进步”,但是,将它与后端c++、java类比,我感觉,组件就像是这些语言中的类和对象的概念,通过封装好的组件(类),可以通过挂载的方式,非常方便的调用其提供的功能,而不必重新写一遍实现逻辑。 我们常用的element UI就是由饿了么所提供的组件库,但是在项目开发中,我们可能还需要额外地定义一

【阅读文献】一个使用大语言模型的端到端语音概要

摘要 ssum框架(Speech Summarization)为了 从说话人的语音提出对应的文本二题出。 ssum面临的挑战: 控制长语音的输入捕捉 the intricate cross-mdoel mapping 在长语音输入和短文本之间。 ssum端到端模型框架 使用 Q-Former 作为 语音和文本的中介连接 ,并且使用LLMs去从语音特征正确地产生文本。 采取 multi-st

《C++中的移动构造函数与移动赋值运算符:解锁高效编程的最佳实践》

在 C++的编程世界中,移动构造函数和移动赋值运算符是提升程序性能和效率的重要工具。理解并正确运用它们,可以让我们的代码更加高效、简洁和优雅。 一、引言 随着现代软件系统的日益复杂和对性能要求的不断提高,C++程序员需要不断探索新的技术和方法来优化代码。移动构造函数和移动赋值运算符的出现,为解决资源管理和性能优化问题提供了有力的手段。它们允许我们在不进行不必要的复制操作的情况下,高效地转移资源

20151207 spring概要

AOP 多个类中出现相同的方法 业务逻辑中出现的重复性代码 抽取融合 --- 基本概念: 连接点 具有边界性质,相当于锚的位置 切点 相当于一些已经被抽取的重复性代码的位置,和锚做连接 增强 抽取出来的重复性代码和逻辑 目标对象 目标类 引介 织入 代理 切面 --- 实现重复逻辑的复用: 1 在目标对象中设置连接点。 2 编写增强代码,