Intellipaat Back

Explore Courses Blog Tutorials Interview Questions
0 votes
2 views
in AWS by (19.1k points)

I have a little question regarding Elastic IPs and its charge. Some blogs say that Elastic IP will charge you by the bandwidth you use

Elastic IP addresses charge by bandwidth and have an hourly price when they are not attached to a running instance

From http://things.zarate.org/scaling-a-single-ec2-instance-and-downsizing

From my understanding after reading some blogs and the documentation, you will only be charged if you use the elastic IPs in communicating between instances and if you have elastic IPs standing there idle on your account without being associated to your instance

If you communicate between instances using public or elastic IP address even in the same region you pay regional data transfer rates(0.01$ per GB in/out).

From http://www.cloudiquity.com/2009/02/using-amazon-ec2-public-ip-address-inside-ec2-network/

See AWS calculator

So my confusion is on the part whether AWS charges for any kinds of traffic requests (using my browser, SSH) using the elastic IPs?

So if for example, I ssh-ed to my instances using the elastic IPs (For example 8.8.8.8) instead of the public DNS name given like ec2-xxx-xxx-xxx-xxx.compute-1.amazonaws.com, will this bandwidth registered as simple bandwidth in/out usage or the public/elastic IP bandwidth?

1 Answer

0 votes
by (44.4k points)

Consider the data transfer charges and Elastic IP charges separately.

Elastic IP addresses

Allocating and using one Elastic IP addresses per instance is normally free, except if the Elastic IP address is not currently associated with an instance, see section Elastic IP Addresses on page Amazon EC2 Pricing:

  • $0.00 for one Elastic IP address related to a running instance
  • $0.005 per additional Elastic IP address related to a running instance per hour on a pro rata basis
  • $0.005 per Elastic science address not related to a running instance per hour on a pro rata basis
  • $0.00 per Elastic IP address remap for the first one hundred remaps per month
  • $0.10 per Elastic IP address remap for extra remaps over 100 per month

The rationale behind this approach is explained in the respective FAQ Why am I charged when my Elastic IP address is not associated with an instance?:

In order to assist guarantee our customers are efficiently using the Elastic IP addresses, we impose a small hourly charge for each address when it is not associated with a running instance.

Data Transfer

Again, the key aspect is explained in section Data Transfer on page Amazon EC2 Pricing (and detailed by some FAQs):

You primarily pay for Internet Data Transfer, i.e. data transferred "in" and "out" of Amazon EC2, which specifically excludes the following:

There is no data Transfer charge between Amazon EC2 and alternative Amazon Web Services among the same region (i.e. between Amazon EC2 us west and Amazon S3 in us west). Data transferred between Amazon EC2 instances located in several Availability Zones within the same Region are going to be charged Regional data Transfer. Data transferred between AWS services in several regions are going to be charged as internet data Transfer on each side of the transfer.

Caveat

The important caveat to be aware of indeed follows below that statement though:

Public and Elastic IP and Elastic Load balancing data Transfer

  • $0.01 per GB in/out – If you opt on to communicate using your Public or Elastic IP address or Elastic Load Balancer within the Amazon EC2 network, you’ll pay Regional Data Transfer rates even if the instances are within the same Availability Zone. For data transfer among the same Availability Zone, you can easily avoid this charge (and get better network performance) by using your private IP whenever possible.

Remedy

Not mentioned within the aforementioned paragraph is an important and quite useful feature of the AWS DNS infrastructure though, see Public IP Addresses and External DNS Hostnames:

We provide every instance that contains a public IP address with an external DNS hostname. We resolve an external DNS hostname to the public IP address of the instance outside the network of the instance, and to the private IP address of the instance from within the network of the instance.

That is, it's resolving the public DNS (e.g. ec2-xxx-xxx-xxx-xxx.compute-1.amazonaws.com) to the private IP address while you are using it within the Amazon EC2 network, and to the public or Elastic IP address while using it outside the Amazon EC2 network. Like this you get the free availability Zone data Transfer and reduced charge Regional data Transfer mechanically, e.g. they are actively applying their advice to Always use the internal address when you are communicating between Amazon EC2 instances [which] ensures that your network traffic follows the highest bandwidth, lowest price, and lowest latency path through our network.

This obviously doesn't work, if you are using the IP addresses directly (i.e. without DNS), which is thus usually best avoided for this and other reasons in the context of EC2.

Related questions

Want to get 50% Hike on your Salary?

Learn how we helped 50,000+ professionals like you !

0 votes
1 answer
...