Amazon CloudFormation: How to get an ELB's private IP for a specific subnet?
Solution 1
Unfortunately not. I've gone back and forth with our AWS solutions engineer on this and currently there's no way to query the internal IPs for an ELB. I'm currently scraping log files to find them.
Solution 2
We had same problem, below command I use for getting internal IP of ELB "LAMP-Prod"
aws ec2 describe-network-interfaces --filters "Name=description,Values=ELB LAMP-Prod" |grep -wE 'Description|PrivateIpAddress'
Or using JQ and without the need to specify an ELB name
aws ec2 describe-network-interfaces --filters Name=requester-id,Values='amazon-elb' | jq -r '.NetworkInterfaces[].PrivateIpAddresses[].PrivateIpAddress'
Solution 3
If you want to get the private ip address of an elb, check network interfaces under network and security in you ec2 dashboard.
Solution 4
JQ parsing version, just FYI.
aws ec2 describe-network-interfaces --filters "Name=description,Values=ELB your-elb-name" --output json | jq ".NetworkInterfaces[].PrivateIpAddresses[].PrivateIpAddress"
Related videos on Youtube
ObiwanKeTobi
Updated on September 18, 2022Comments
-
ObiwanKeTobi over 1 year
TL;DR - Is it possible for a CloudFormation template to insert the subnet-specific internal IP address of a specific ELB into the UserData of an instance within that subnet?
We have a fleet of EC2 web servers in an Amazon VPC with six subnets, one private and one public across each of the three AZ's within EU-West-1. All servers are configured with CloudFormation.
We would like to configure Apache's mod_rpaf to log the
X-Forwarded-For
header (we can change the LogFormat, but this doesn't translate easily to PHP or Apache error logs; RPAF is the neatest solution for us).As far as I know, the way an ELB is architected means that it has a 'foot' in each of its configured AZs, and this can change if the ELB is torn down or re-created.
It seems that the version of mod_rpaf in Ubuntu 12.04's repositories hasn't been updated to allow CIDR notation for the
ProxyIPS
directive, and in theory the ELB's IP address can be anything within our three public subnets.The one remaining solution is to configure the module via Puppet, using hieradata generated by the instance's UserData. I know that to some degree you can interpolate references and variables within CloudFormation templates, but I'm unsure if it's possible to effectively say "Give me the private IP address for this ELB in this subnet".
-
Froyke about 7 yearsThe original author downvoted this solution for not being 100% compatible with his 'requirements'...Then chose a solution which mentions scrapping logs files...go figure...
-
ObiwanKeTobi almost 7 years@Froyke - just seen this, ultimately I didn't mark the answer as accepted due to the log-scraping comment - I accepted the answer due to the first two words, which give the correct answer to my original question, which was centred specifically around CloudFormation.
-
cgseller over 6 yearsHe is actually correct, if you goto network interfaces, you can see all your network interfaces. If you query for your ELB name, it will filter out everything but the interfaces that you have on that ELB, and then you can drill down. Not programatic, but works.
-
Edward over 6 yearsThis is accurate and deserves more upticks.
-
Aftab Naveed almost 6 yearsThanks for the hint. Does it remain static?
-
JasdeepSingh almost 6 yearsno. IPs for ELBs doesn't stay static. they change very frequently. you can observe it by just pinging the elb endpoint