How to get container ip address inside this container?
'docker inspect $hostname ...' not suitable, because I don't share /var/run/docker.sock host file to container.
I can find the IP address with
hostname -i Of course, that may not be completely accurate if there is more than one interface.
Edit
Note: According to the hostname man page, hostname -i uses DNS to resolve the ip address, where hostname -I displays all the addresses except loopback, does not depend on DNS, and is recommended.
In all my Docker containers, -i and -I return the same results (but this is not the case on my desktop).
hostname -i | awk '{print $1}' because there is a trailing space (and may be more than one IP)hostname -I | awk '{print $1}' because -i gives single ip where -I gives multiple (if present)hostname -i and hostname -I both return 172.18.0.2 172.19.0.2 (but hostname -I does return a trailing space). I think the behavior of hostname -i depends on how dns is configured.As the IP address is in the first line of /etc/hosts, you can do in a container the awk command that prints the first word of the first line of /etc/hosts
$ awk 'END{print $1}' /etc/hosts 172.17.0.14 awk 'END{print $1}' /etc/hostsseems to do the jobsed -i 's/[ \t]*$//' "$1"Why not something as simple as:
grep "`hostname`" /etc/hosts|awk '{print $1}' or
grep "$HOSTNAME" /etc/hosts|awk '{print $1}' Normally you can use the linux program ifconfig to get IP addresses and other networking details. Your container may not have it, in which case you'll need to install it via apt-get or yum or your distro's package manager. A basic pipeline to get the IP address would be
ifconfig eth0 | grep "inet addr:" | cut -d : -f 2 | cut -d " " -f 1 ifconfig installed.If you prefer to use ip rather than ifconfig, on Linux you can do:
ip addr | grep inet | tr -s ' ' | cut -d ' ' -f 3 This simply gets all of the IP addresses and interfaces, searches only for those starting with inet and returns only the 3rd column.
As a nice side-effect, this includes the subnet mask, too! (e.g. 172.17.0.2/16)
If you don't want the subnet mask, you can use:
ip addr | grep inet | tr -s ' ' | cut -d ' ' -f 3 | tr -d '/' NOTE: This shows ALL of the IPs in the container. You can use awk or sed to remove 127.0.0.1/16 and other unwanted IPs. :)
This may work on some containers if it has the "hostname" command.
docker ps to get the (container id)
docker exec -it (container id) hostname -i
--link firstcontainer:firstcontainerand then in nginx, you can actually just proxy to a hostnamefirstcontainerbecause the linking will automatically set up DNS to resolve it to the firstcontainer IP.