Amazon Elastic Compute Cloud

From Infogalactic: the planetary knowledge core
Jump to: navigation, search

Lua error in package.lua at line 80: module 'strict' not found. Lua error in package.lua at line 80: module 'strict' not found.

Amazon Elastic Compute Cloud (EC2)
AWS Simple Icons Compute Amazon EC2 Instances.svg
Amazon Elastic Compute Cloud (EC2)
Original author(s) Amazon.com, Inc.
Developer(s) Amazon.com
Initial release August 25, 2006; 18 years ago (2006-08-25)
Development status Active
Operating system <templatestyles src="Plainlist/styles.css"/>
Available in English
Type Virtual Private Server
License Proprietary software
Website aws.amazon.com/ec2/

Amazon Elastic Compute Cloud (EC2) forms a central part of Amazon.com's cloud-computing platform, Amazon Web Services (AWS), by allowing users to rent virtual computers on which to run their own computer applications. EC2 encourages scalable deployment of applications by providing a web service through which a user can boot an Amazon Machine Image to configure a virtual machine, which Amazon calls an "instance", containing any software desired. A user can create, launch, and terminate server-instances as needed, paying by the hour for active servers - hence the term "elastic". EC2 provides users with control over the geographical location of instances that allows for latency optimization and high levels of redundancy.[1]

In November 2010 Amazon switched its own retail website to using EC2 and AWS.[2]

History

Amazon announced a limited public beta test of EC2 on August 25, 2006,[3] offering access on a first-come, first-served basis. Amazon added two new instance types (Large and Extra-Large) on October 16, 2007.[4] On May 29, 2008, two more types were added, High-CPU Medium and High-CPU Extra Large.[5] There are twelve types of instances available.[6]

Amazon added three new features on March 27, 2008:[7] static IP addresses, availability zones, and user selectable kernels. On August 20, 2008, Amazon added Elastic Block Store (EBS)[8] This provides persistent storage, a feature that had been lacking since the service was introduced.

Amazon EC2 went into full production when it dropped the beta label on October 23, 2008. On the same day, Amazon announced the following features:[9] a service level agreement for EC2, Microsoft Windows in beta form on EC2, Microsoft SQL Server in beta form on EC2, plans for an AWS management console, and plans for load balancing, autoscaling, and cloud monitoring services.[9] These features were subsequently added on May 18, 2009.[10]

Amazon EC2 was developed mostly by a team in Cape Town, South Africa led by Chris Pinkham.[11][12][13][14] Pinkham provided the initial architecture guidance for EC2 and then built the team and led the development of the project along with Willem Van Biljon, Roland Paterson-Jones, Christopher Brown, Quinton Hoole, Peter DeSantis, Marcin Kowalski, Benjamin Tobler, James Greenfield, Atle Jorgensen, Alan Powell, Eden Adogla, Liehann Loots, David Brown, Anton Eicher, Christopher de Kadt, Greg Kempe, Riel Smit, Jeremy Thurgood and Andries Dippenaar.

Elastic compute units

The elastic compute unit (ECU) was introduced by Amazon EC2 as an abstraction of computer resources. Amazon’s Definition of ECU notes “We use several benchmarks and tests to manage the consistency and predictability of the performance of an EC2 Compute Unit. One EC2 Compute Unit provides the equivalent CPU capacity of a 1.0-1.2 GHz 2007 Opteron or 2007 Xeon processor. This is also the equivalent to an early-2006 1.7 GHz Xeon processor referenced in our original documentation”

Elastic block storage

The Amazon Elastic Block Store (EBS) provides raw block devices that can be attached to Amazon EC2 instances. These block devices can then be used like any raw block device. In a typical use case, this would include formatting the device with a filesystem and mounting it. In addition EBS supports a number of advanced storage features, including snapshotting and cloning. EBS volumes can be up to 1TB in size. EBS volumes are built on replicated storage, so that the failure of a single component will not cause data loss. EBS was introduced to the general public by Amazon in August 2008.[8]

Instance types

EC2 uses Xen virtualization.[15] Each virtual machine, called an "instance", functions as a virtual private server. Amazon sizes instances based on "Elastic Compute Units". The performance of otherwise identical virtual machines may vary.[16]

As of December 2012, the following instance types were offered:[17]

  • On-demand: pay by hour without commitment
  • Reserved: rent instances with one-time payment receiving discounts on the hourly charge
  • Spot: bid-based service: runs the jobs only if the spot price is below the bid specified by bidder. The spot price is claimed to be supply-demand based, however a 2011 study concluded that the price was generally not set to clear the market, but was dominated by an undisclosed reserve price.[18]

Cost

Amazon CTO Werner Vogels announces price reductions at AWS Summit 2013 NYC

As of July 2014, Amazon charged about $0.013/hour ($9.7/month) for the smallest "Micro Instance" (t2.micro) virtual machine running Linux or Windows. Storage-optimized instances cost as much as $6.820/hour (i2.8xlarge). "Reserved" instances can go as low as $4.5/month for a three-year prepaid plan.[note 1][19] The data transfer charge ranges from free to $0.12 per gigabyte, depending on the direction and monthly volume (inbound data transfer is free on all AWS services[20]).

AWS' pricing came under scrutiny due to the complexity of their pricing model.[21] Third-party vendors, such as Cloudyn[22] and CloudCheckr[23] offer fee for service analysis to help reduce costs. However, such are the potential savings from switching virtual servers off when they are not required that products that enable real time on-demand scheduling are rapidly being developed by third-party vendors, such as Cloud Machine Manager[24]

Free tier

As of December  2010 Amazon offered a bundle of free resource credits to new account holders. The credits are designed to run a "micro" sized server, storage (EBS), and bandwidth for one year.[25] Unused credits cannot be carried over from one month to the next.[26]

Reserved instances

Reserved instances enable EC2 or RDS service users to reserve an instance for one or three years. The corresponding per hour rate charged by Amazon to operate the instance is much less than the rate charged for on-demand instances.[27]

Reserved Instances can be purchased in three different ways: All Upfront, Partial Upfront and No Upfront. The different purchase options allow for different structuring of payment models.

Comparison table

API name Memory (GiB) Cores/Compute units Instance storage (GB) 32bit/64bit I/O performance EBS-optimizable On-demand cost (Linux: per hour on US East 1)
t2.nano 0.5 1/Variable 0 (EBS only) 32/64 Low No $0.0065
t2.micro 1 1/Variable 0 (EBS only) 32/64 Low No $0.013
t2.small 2 1/Variable 0 (EBS only) 32/64 Low No $0.026
t2.medium 4 2/Variable 0 (EBS only) 32/64 Low No $0.052
m1.small 1.7 1/1 160 32/64 Moderate No $0.060
m1.medium 3.75 1/2 410 32/64 Moderate No $0.120
m1.large 7.5 2/4 850 64 Moderate 500 Mbit/s $0.240
m1.xlarge 15 4/8 1600 64 High 1000 Mbit/s $0.480
m2.xlarge 17.1 2/6.5 420 64 Moderate No $0.410
m2.2xlarge 34.2 4/13 850 64 High 500 Mbit/s $0.820
m2.4xlarge 68.4 8/26 1690 64 High 1000 Mbit/s $1.640
m3.xlarge 15 4/13 0 (EBS only) 64 Moderate 500 Mbit/s $0.500
m3.2xlarge 30 8/26 0 (EBS only) 64 High 1000 Mbit/s $1.000
c1.medium 1.7 2/5 350 32/64 Moderate No $0.145
c1.xlarge 7 8/20 1690 64 High 1000 Mbit/s $0.580
c3.8xlarge 60 32 (Xeon E5-2680 v2) 64
c4.8xlarge 60 36 (Xeon E5-2666 v3) 64
cc1.4xlarge 23 2/33.5 (2 Intel Xeon X5570) 1690 64 Very High (10 Gbit)  ? $1.300
cc2.8xlarge 60.5 2/88 (2 Intel Xeon E5-2670) 3370 64 Very High (10 Gbit) Not necessary $2.400
cr1.8xlarge 244 2/88 (2 Intel Xeon E5-2670) 240 (SSD) 64 Very High (10 Gbit) Not necessary $3.500
cg1.4xlarge 22 2/33.5 (2 Intel Xeon X5570) + 2 NVIDIA Tesla "Fermi" M2050 GPU 1960 64 Very High (10 Gbit) Not necessary $2.100
g2.2xlarge 15 Xeon E5-2670 + NVIDIA Tesla "Kepler" GPU 60 (SSD) 64
hi1.4xlarge 60.5 16/35 (8 cores + 8 hyperthreads) 2*1024 (SSD) 64 Very High (10 Gbit) Not necessary $3.100
hs1.8xlarge 117 16/35 (8 cores + 8 hyperthreads) 48000 (24 * 2TB drives) 64 Very High (10 Gbit) Not necessary $4.600

Features

Operating systems

When it launched in August 2006, the EC2 service offered Linux and later Sun Microsystems' OpenSolaris and Solaris Express Community Edition. In October 2008, EC2 added the Windows Server 2003 and Windows Server 2008 operating systems to the list of available operating systems.[28][29] In March 2011, NetBSD AMIs became available.[30] In November 2012, Windows Server 2012 support was added.[31]

Since 2006, Colin Percival, a FreeBSD developer and Security Officer, solicited Amazon to add FreeBSD.[32] In November 2012, Amazon officially supported running FreeBSD in EC2.[33][34][35] The FreeBSD/EC2 platform is maintained by Percival[36] who also developed the secure deduplicating Amazon S3-cloud based backup service Tarsnap.[37]

Amazon has their own Linux distribution based on the Fedora and Red Hat Enterprise Linux as a low cost offering known as the Amazon Linux AMI. Version 2013.03 included:[38]

Persistent storage

An EC2 instance may be launched with a choice of two types of storage for its boot disk or "root device." The first option is a local "instance-store" disk as a root device (originally the only choice). The second option is to use an EBS volume as a root device. Instance-store volumes are temporary storage, which survive rebooting an EC2 instance, but when the instance is stopped or terminated (e.g., by an API call, or due to a failure), this store is lost.

Amazon EBS

EBS volumes provide persistent storage independent of the lifetime of the EC2 instance, and act much like hard drives on a real server. More accurately, they appear as block devices to the operating system that are backed by Amazon's disk arrays. The OS is free to use the device however it wants. In the most common case, a file system is loaded and the volume acts as a hard drive. Another possible use is the creation of RAID arrays by combining two or more EBS volumes. RAID allows increases of speed and/or reliability of EBS. Users can set up and manage storage volumes of sizes from 1GB to 1TB. The volumes support snapshots, which can be taken from a GUI tool or the API. EBS volumes can be attached or detached from instances while they are running, and moved from one instance to another.[39]

Simple Storage Service (S3) is a storage system in which data is accessible to EC2 instances, or directly over the network to suitably authenticated callers (all communication is over HTTP). Amazon does not charge for the bandwidth for communications between EC2 instances and S3 storage "in the same region." Accessing S3 data stored in a different region (for example, data stored in Europe from a US East Coast EC2 instance) will be billed at Amazon's normal rates.

S3-based storage is priced per gigabyte per month. Applications access S3 through an API. For example, Apache Hadoop supports a special s3: filesystem to support reading from and writing to S3 storage during a MapReduce job. There are also S3 filesystems for Linux, which mount a remote S3 filestore on an EC2 image, as if it were local storage. As S3 is not a full POSIX filesystem, things may not behave the same as on a local disk (e.g., no locking support).

Elastic IP addresses

Amazon Elastic IP

Amazon's elastic IP address feature is similar to static IP address in traditional data centers, with one key difference. A user can programmatically map an elastic IP address to any virtual machine instance without a network administrator's help and without having to wait for DNS to propagate the binding. In this sense an Elastic IP Address belongs to the account and not to a virtual machine instance. It exists until it is explicitly removed, and remains associated with the account even while it is associated with no instance.

Amazon CloudWatch

Amazon CloudWatch

Amazon CloudWatch is a web service that provides real-time monitoring to Amazon's EC2 customers on their resource utilization such as CPU, disk and network. CloudWatch does not provide any memory, disk space, or load average metrics without running additional software on the instance. Amazon provides example scripts for Linux instances.[40] The data is aggregated and provided through AWS management console. It can also be accessed through command line tools and Web API's, if the customer desires to monitor their EC2 resources through their enterprise monitoring software.

The metrics collected by Amazon CloudWatch enables the auto-scaling feature to dynamically add or remove EC2 instances.[41] The customers are charged by the number of monitoring instances.

Since May 2011, Amazon CloudWatch accepts custom metrics that can be submitted programmatically via Web Services API and then monitored the same way as all other internal metrics, including setting up the alarms for them.

Automated scaling

Auto-scaling

<templatestyles src="Module:Hatnote/styles.css"></templatestyles>

Amazon's auto-scaling feature of EC2 allows it to automatically adapt computing capacity to site traffic. The schedule-based (e.g. time-of-the-day) and rule-based (e.g. CPU utilization thresholds) auto scaling mechanisms are easy to use and efficient for simple applications. However, one potential problem is that VMs may take up to several minutes to be ready to use, which are not suitable for time critical applications. The VM startup time are dependent on image size, VM type, data center locations, etc.[42]

Lack of IPv6-support

Despite an announcement in the year 2011,[43] EC2 doesn't yet support IPv6.[44]

Reliability

To make EC2 more fault-tolerant, Amazon engineered Availability Zones that are designed to be insulated from failures in other availability zones. Availability zones do not share the same infrastructure. Applications running in more than one availability zone can achieve higher availability.[45]

EC2 provides users with control over the geographical location of instances that allows for latency optimization and high levels of redundancy. For example, to minimize downtime, a user can set up server instances in multiple zones that are insulated from each other for most causes of failure such that one backs up the other.

Higher-availability database services, like Amazon Relational Database Service run separately from EC2 instances.

Issues

In early July 2008 the anti-spam organizations Outblaze and Spamhaus.org began blocking Amazon's EC2 address pool due to problems with the distribution of spam and malware.[46]

On December 1, 2010, Amazon pulled its service to WikiLeaks after coming under political pressure in the US.[47] The Internet group Anonymous attempted to attack EC2 in revenge; however, Amazon was not affected by the attack.[48]

Amazon's websites were temporarily offline on December 12, 2010, although it was initially unclear if this was due to attacks or a hardware failure. An Amazon official later stated that it was due to a hardware failure.[49]

Shortly before 5 am ET on April 21, 2011, an outage started at EC2's Northern Virginia data center that brought down several websites, including Foursquare, Springpad, Reddit, Quora, and Hootsuite.[50][51][52] Specifically, attempts to use Amazon's elastic-disk and database services hung, failed, or were slow. Service was restored to some parts of the datacenter (three of four "availability zones" in Amazon's terms) by late afternoon Eastern time that day;[53] problems for at least some customers were continuing as of April 25.[54] 0.07% of EBS volumes in one zone have also been lost; EBS failures were a part of normal operation even before this outage and were a risk documented by Amazon,[55] though the number of failures and the number of simultaneous failures may find some EC2 users unprepared.

On Sunday August 6, 2011, Amazon suffered a power outage in one of their Ireland availability zones.[56] Lightning was originally blamed for the outage; however, on August 11, Irish energy supplier ESB Networks dismissed this as a cause, but at time of writing, could not confirm what the cause of the problem was.[57] The power outage raised multiple questions regarding Amazon's EBS infrastructure, which caused several bugs in their software to be exposed. The bugs resulted in some customers' data being deleted when recovering EBS volumes in a mid-write operation during the crash.[58]

August 8, 2011, saw another network connectivity outage of Amazon's Northern Virginia datacenter, knocking out the likes of Reddit, Quora, Netflix and FourSquare.[59] The outage lasted around 25 minutes.

Another Northern Virginia datacenter outage occurred on October 22, 2012, from approximately 10 am to 4 pm PT. Edmodo, Airbnb, Flipboard, Reddit, and other customers were affected. Anonymous claimed responsibility, however Amazon denied this assertion.[60]

See also

Lua error in package.lua at line 80: module 'strict' not found.

<templatestyles src="Div col/styles.css"/>

Notes

  1. $109 for a three-year Heavy Utilization Reserved t2.micro Instances reservation amortized over thirty-six months plus one month at $0.002/hour.

References

  1. Lua error in package.lua at line 80: module 'strict' not found.
  2. Lua error in package.lua at line 80: module 'strict' not found.
  3. Lua error in package.lua at line 80: module 'strict' not found.
  4. Lua error in package.lua at line 80: module 'strict' not found.
  5. Lua error in package.lua at line 80: module 'strict' not found.
  6. Amazon EC2 Instances. Aws.amazon.com. Retrieved on 2013-08-09.
  7. Lua error in package.lua at line 80: module 'strict' not found.
  8. 8.0 8.1 Lua error in package.lua at line 80: module 'strict' not found.
  9. 9.0 9.1 Lua error in package.lua at line 80: module 'strict' not found.
  10. Lua error in package.lua at line 80: module 'strict' not found.
  11. Lua error in package.lua at line 80: module 'strict' not found.
  12. Lua error in package.lua at line 80: module 'strict' not found.
  13. Lua error in package.lua at line 80: module 'strict' not found.
  14. Lua error in package.lua at line 80: module 'strict' not found.
  15. Lua error in package.lua at line 80: module 'strict' not found.
  16. J. Dejun, G. Pierre and C.-H. Chi. EC2 Performance Analysis for Resource Provisioning of Service-Oriented Applications. In Proceedings of the Workshop on Non-Functional Properties and SLA Management in Service-Oriented Computing, November 2009.
  17. Lua error in package.lua at line 80: module 'strict' not found.
  18. Lua error in package.lua at line 80: module 'strict' not found.
  19. Amazon Elastic Compute Cloud (Amazon EC2), Cloud Computing Servers. Aws.amazon.com (2014-07-01). Retrieved on 2014-07-01.
  20. Lua error in package.lua at line 80: module 'strict' not found.
  21. Lua error in package.lua at line 80: module 'strict' not found.
  22. Lua error in package.lua at line 80: module 'strict' not found.
  23. Lua error in package.lua at line 80: module 'strict' not found.
  24. Lua error in package.lua at line 80: module 'strict' not found.
  25. Lua error in package.lua at line 80: module 'strict' not found.
  26. Lua error in package.lua at line 80: module 'strict' not found.
  27. Lua error in package.lua at line 80: module 'strict' not found.
  28. Lua error in package.lua at line 80: module 'strict' not found.
  29. Lua error in package.lua at line 80: module 'strict' not found.
  30. NetBSD Blog. Blog.netbsd.org (2011-03-13). Retrieved on 2013-08-09.
  31. Lua error in package.lua at line 80: module 'strict' not found.
  32. Lua error in package.lua at line 80: module 'strict' not found.
  33. Lua error in package.lua at line 80: module 'strict' not found.
  34. Lua error in package.lua at line 80: module 'strict' not found.
  35. Lua error in package.lua at line 80: module 'strict' not found.
  36. Lua error in package.lua at line 80: module 'strict' not found.
  37. Lua error in package.lua at line 80: module 'strict' not found.
  38. Lua error in package.lua at line 80: module 'strict' not found.
  39. Lua error in package.lua at line 80: module 'strict' not found.
  40. "Henry". "Cloudwatch for memory usage"
  41. AWS in Action & Wittig (2016), pp. 372-375.
  42. Lua error in package.lua at line 80: module 'strict' not found.
  43. Lua error in package.lua at line 80: module 'strict' not found.
  44. https://forums.aws.amazon.com/message.jspa?messageID=613158
  45. Lua error in package.lua at line 80: module 'strict' not found.
  46. Lua error in package.lua at line 80: module 'strict' not found.
  47. Lua error in package.lua at line 80: module 'strict' not found.
  48. Lua error in package.lua at line 80: module 'strict' not found.
  49. Lua error in package.lua at line 80: module 'strict' not found.
  50. Lua error in package.lua at line 80: module 'strict' not found.
  51. Lua error in package.lua at line 80: module 'strict' not found.
  52. Lua error in package.lua at line 80: module 'strict' not found.
  53. 6:18 pm PDT April 21, 2011, entry, says "all Availability Zones except one have been functioning normally for the past 5 hours."
  54. April 25 entry.
  55. Amazon Elastic Block Store (EBS) section "Volume Durability"
  56. Lua error in package.lua at line 80: module 'strict' not found.
  57. Lua error in package.lua at line 80: module 'strict' not found.
  58. Lua error in package.lua at line 80: module 'strict' not found.
  59. Lua error in package.lua at line 80: module 'strict' not found.
  60. Lua error in package.lua at line 80: module 'strict' not found.

External links