새 컨테이너가 생성 된 후 호스트에서 컨테이너의 IP 주소를 가져 오기 위해 실행할 수있는 명령이 있습니까?
기본적으로 Docker가 컨테이너를 생성하면 자체 코드 배포 및 컨테이너 구성 스크립트를 롤링하고 싶습니다.
새 컨테이너가 생성 된 후 호스트에서 컨테이너의 IP 주소를 가져 오기 위해 실행할 수있는 명령이 있습니까?
기본적으로 Docker가 컨테이너를 생성하면 자체 코드 배포 및 컨테이너 구성 스크립트를 롤링하고 싶습니다.
답변:
--format
의 옵션은 inspect
구조에 온다.
최신 Docker 클라이언트 구문은 다음과 같습니다.
docker inspect -f '{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' container_name_or_id
이전 Docker 클라이언트 구문은 다음과 같습니다.
docker inspect --format '{{ .NetworkSettings.IPAddress }}' container_name_or_id
이 명령은 Docker 컨테이너의 IP 주소를 반환합니다.
주석에서 언급했듯이 Windows에있는 경우 중괄호 주위 "
에 작은 따옴표 대신 큰 따옴표 를 사용 '
하십시오.
<no value>
Fig / Boot2Docker를 사용하여 Mac 에서 응답 받기
<no value>
실행 중이 아닌 컨테이너에 대해 이것을 실행하면 얻을 수 있습니다. 이 작업을 수행하기 전에 컨테이너가 실행 중인지 확인하십시오.
{{ .NetworkSettings.Networks.$network.IPAddress }}
. 기본은 브리지 인 것처럼 보이지만 docker-compose 아래에는 앱 이름에 따라 달라지는 특정 이름이 있습니다 (--project-name 플래그에서 생각하지만 네트워킹 구성 유형에 따라 다릅니다. 설정했습니다). 나는 여기에 답변에 완전한 답변을 썼습니다. stackoverflow.com/questions/17157721/…
사용할 수 있습니다 docker inspect <container id>
.
예를 들면 다음과 같습니다.
CID=$(docker run -d -p 4321 base nc -lk 4321);
docker inspect $CID
docker inspect $CID | grep IPAddress | cut -d '"' -f 4
:)
alias dockerip='docker ps | tail -n +2 | while read cid b; do echo -n "$cid\t"; docker inspect $cid | grep IPAddress | cut -d \" -f 4; done'
docker inspect -format '{{ .NetworkSettings.IPAddress }}' ${CID}
docker inspect -format '{{ .NetworkSettings.IPAddress }}' ${CID}
새로운 구문입니다. -format
더 이상 사용되지 않습니다 --format
.
먼저 컨테이너 ID를 얻으십시오.
docker ps
(첫 번째 열은 컨테이너 ID입니다)
컨테이너 ID를 사용하여 다음을 실행하십시오.
docker inspect <container ID>
하단의 "NetworkSettings"아래에 "IPAddress"가 있습니다.
아니면 그냥 :
docker inspect <container id> | grep "IPAddress"
docker run -it MYCONTAINER /bin/bash
)의 출력은 inspect
어떤 부분이 없습니다 NetworkSettings
!
docker network inspect bridge | grep Gateway | grep -o -E '[0-9.]+'
... | grep IP
IP를 얻는 데 필요한 모든 형식 세부 사항에 대한 솔루션을 매우 선호합니다 . +1
docker run -it MYIMAGE
docker inspect MYIMAGE
MYIMAGE_1
docker inspect MYIMAGE_1
docker inspect CONTAINER_ID | grep "IPAddress"
-i
사건을 무시하기 위해 grep에 추가 하면 다음과 같이 작동합니다.
docker inspect CONTAINER_ID | grep -i "IPaDDreSS"
단 하나의 명령으로 모든 컨테이너 이름과 해당 IP 주소를 가져옵니다.
docker inspect -f '{{.Name}} - {{.NetworkSettings.IPAddress }}' $(docker ps -aq)
docker-compose
명령을 사용 하는 경우 다음과 같습니다.
docker inspect -f '{{.Name}} - {{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' $(docker ps -aq)
출력은 다음과 같습니다.
/containerA - 172.17.0.4
/containerB - 172.17.0.3
/containerC - 172.17.0.2
{{.NetworkSettings.IPAddress }}
에{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}
docker inspect --format '{{ .NetworkSettings.IPAddress }}' $(docker ps -aq | xargs) | sed -e '/^$/d'
.. 이 sed(1)
컨테이너는 존재하지만 IP 주소가없는 컨테이너의 빈 줄을 제거합니다.
이 쉘 스크립트를 귀하 ~/.bashrc
또는 관련 파일 에 추가 하십시오.
docker-ip() {
docker inspect --format '{{ .NetworkSettings.IPAddress }}' "$@"
}
그런 다음 컨테이너의 IP 주소를 얻으려면 다음을 수행하십시오.
docker-ip YOUR_CONTAINER_ID
Docker의 새 버전의 경우 다음을 사용하십시오.
docker-ip() {
docker inspect --format '{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' "$@"
}
Template parsing error: template: :1:19: executing "" at <.NetworkSettings.IPA...>: map has no entry for key "NetworkSettings"
source ~/.bash_profile
Docker 1.3 이상에서는 다음을 사용하여 확인할 수도 있습니다.
실행중인 Docker (Linux)를 입력하십시오 :
docker exec [container-id or container-name] cat /etc/hosts
172.17.0.26 d8bc98fa4088
127.0.0.1 localhost
::1 localhost ip6-localhost ip6-loopback
fe00::0 ip6-localnet
ff00::0 ip6-mcastprefix
ff02::1 ip6-allnodes
ff02::2 ip6-allrouters
172.17.0.17 mysql
창문 :
docker exec [container-id or container-name] ipconfig
docker exec [container-name-or-id] ip a
docker exec [container-id or container-name] ipconfig
Docker 버전 1.10.3부터 빌드 20f81dd
Docker에 달리 언급하지 않는 한 Docker는 항상 브리지 네트워크에서 컨테이너를 시작합니다. 따라서 아래 명령을 시도해 볼 수 있습니다.
docker network inspect bridge
그러면 컨테이너 섹션을 반환해야합니다. 컨테이너 섹션에는 해당 컨테이너의 IP 주소가 표시됩니다.
[
{
"Name": "bridge",
"Id": "40561e7d29a08b2eb81fe7b02736f44da6c0daae54ca3486f75bfa81c83507a0",
"Scope": "local",
"Driver": "bridge",
"IPAM": {
"Driver": "default",
"Options": null,
"Config": [
{
"Subnet": "172.17.0.0/16"
}
]
},
"Containers": {
"025d191991083e21761eb5a56729f61d7c5612a520269e548d0136e084ecd32a": {
"Name": "drunk_leavitt",
"EndpointID": "9f6f630a1743bd9184f30b37795590f13d87299fe39c8969294c8a353a8c97b3",
"IPv4Address": "172.17.0.2/16",
"IPv6Address": ""
}
},
"Options": {
"com.docker.network.bridge.default_bridge": "true",
"com.docker.network.bridge.enable_icc": "true",
"com.docker.network.bridge.enable_ip_masquerade": "true",
"com.docker.network.bridge.host_binding_ipv4": "0.0.0.0",
"com.docker.network.bridge.name": "docker0",
"com.docker.network.driver.mtu": "1500"
}
}
]
실행 :
docker ps -a
활성 도커 이미지가 표시됩니다.
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
3b733ae18c1c parzee/database "/usr/lib/postgresql/" 6 minutes ago Up 6 minutes 5432/tcp serene_babbage
컨테이너 ID 값을 사용하십시오.
docker inspect <CONTAINER ID> | grep -w "IPAddress" | awk '{ print $2 }' | head -n 1 | cut -d "," -f1
"172.17.0.2"
내가 좋아하는 답변 중 일부를 기반으로 모든 IP 주소와 특정 컨테이너에 대한 IP 주소를 가져 오는 함수로 병합하기로 결정했습니다. 그들은 지금 내 .bashrc
파일에 있습니다.
docker-ips() {
docker inspect --format='{{.Name}} - {{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' $(docker ps -aq)
}
docker-ip() {
docker inspect --format '{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' "$@"
}
첫 번째 명령은 모든 컨테이너의 IP 주소를, 두 번째 명령은 특정 컨테이너의 IP 주소를 제공합니다.
docker-ips
docker-ip YOUR_CONTAINER_ID
에서 실행되는 모든 컨테이너에서 IP 주소 테이블을 가져 오기 위해 다음 Bash 스크립트를 작성했습니다 docker-compose
.
function docker_container_names() {
docker ps -a --format "{{.Names}}" | xargs
}
# Get the IP address of a particular container
dip() {
local network
network='YOUR-NETWORK-HERE'
docker inspect --format "{{ .NetworkSettings.Networks.$network.IPAddress }}" "$@"
}
dipall() {
for container_name in $(docker_container_names);
do
local container_ip=$(dip $container_name)
if [[ -n "$container_ip" ]]; then
echo $(dip $container_name) " $container_name"
fi
done | sort -t . -k 3,3n -k 4,4n
}
변수 네트워크를 자신의 네트워크 이름으로 변경해야합니다.
Docker는 Go로 작성되었으며 쿼리 용도로 Go 구문을 사용합니다.
특정 컨테이너의 IP 주소를 검사하려면 -f
"format"에 대해 다음 명령을 실행해야합니다 .
docker inspect -f '{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' container_id_or_name
컨테이너 ID 또는 이름의 경우 명령을 실행할 수 있습니다
docker container ls
실행중인 모든 컨테이너가 나열됩니다.
다음은 docker inspect container
JSON 출력을 데이터 소스로 사용하여 오늘 Python에서 개발 한 솔루션입니다 .
검사해야 할 많은 컨테이너와 인프라가 있으며 모든 컨테이너에서 빠르고 예쁜 기본 네트워크 정보를 얻어야합니다. 방법으로 합니다. 그래서이 스크립트를 만들었습니다.
중요 : 버전 1.9부터 Docker를 사용하면 여러 네트워크를 만들어 컨테이너에 연결할 수 있습니다.
#!/usr/bin/python
import json
import subprocess
import sys
try:
CONTAINER = sys.argv[1]
except Exception as e:
print "\n\tSpecify the container name, please."
print "\t\tEx.: script.py my_container\n"
sys.exit(1)
# Inspecting container via Subprocess
proc = subprocess.Popen(["docker","inspect",CONTAINER],
stdout=subprocess.PIPE,
stderr=subprocess.STDOUT)
out = proc.stdout.read()
json_data = json.loads(out)[0]
net_dict = {}
for network in json_data["NetworkSettings"]["Networks"].keys():
net_dict['mac_addr'] = json_data["NetworkSettings"]["Networks"][network]["MacAddress"]
net_dict['ipv4_addr'] = json_data["NetworkSettings"]["Networks"][network]["IPAddress"]
net_dict['ipv4_net'] = json_data["NetworkSettings"]["Networks"][network]["IPPrefixLen"]
net_dict['ipv4_gtw'] = json_data["NetworkSettings"]["Networks"][network]["Gateway"]
net_dict['ipv6_addr'] = json_data["NetworkSettings"]["Networks"][network]["GlobalIPv6Address"]
net_dict['ipv6_net'] = json_data["NetworkSettings"]["Networks"][network]["GlobalIPv6PrefixLen"]
net_dict['ipv6_gtw'] = json_data["NetworkSettings"]["Networks"][network]["IPv6Gateway"]
for item in net_dict:
if net_dict[item] == "" or net_dict[item] == 0:
net_dict[item] = "null"
print "\n[%s]" % network
print "\n{}{:>13} {:>14}".format(net_dict['mac_addr'],"IP/NETWORK","GATEWAY")
print "--------------------------------------------"
print "IPv4 settings:{:>16}/{:<5} {}".format(net_dict['ipv4_addr'],net_dict['ipv4_net'],net_dict['ipv4_gtw'])
print "IPv6 settings:{:>16}/{:<5} {}".format(net_dict['ipv6_addr'],net_dict['ipv6_net'],net_dict['ipv6_gtw'])
출력은 다음과 같습니다.
$ python docker_netinfo.py debian1
[frontend]
02:42:ac:12:00:02 IP/NETWORK GATEWAY
--------------------------------------------
IPv4 settings: 172.18.0.2/16 172.18.0.1
IPv6 settings: null/null null
[backend]
02:42:ac:13:00:02 IP/NETWORK GATEWAY
--------------------------------------------
IPv4 settings: 172.19.0.2/16 172.19.0.1
IPv6 settings: null/null null
docker inspect --format '{{ .NetworkSettings.IPAddress }}' <containername or containerID here>
컨테이너가 기본 브리지 네트워크에 배포 된 경우 위와 같이 작동합니다.
그러나 사용자 정의 브리지 네트워크 또는 오버레이 네트워크를 사용하는 경우 아래가 더 효과적이라는 것을 알았습니다.
docker exec <containername or containerID here> /sbin/ifconfig eth0 | grep 'inet addr:' | cut -d: -f2 | awk '{ print $1}'
ko-dos의 답변을 확장하기 위해 다음은 모든 컨테이너 이름과 해당 IP 주소를 나열하는 별명입니다.
alias docker-ips='docker ps | tail -n +2 | while read -a a; do name=${a[$((${#a[@]}-1))]}; echo -ne "$name\t"; docker inspect $name | grep IPAddress | cut -d \" -f 4; done'
docker ps -q
을 피하기 위해 tail
, 그리고 --format
grep을하지 않도록합니다. 또한 docker inspect
쉘에서 루프하지 않고 여러 컨테이너 ID를 전달할 수 있습니다 .
docker ps -q
컨테이너의 숫자 ID 만 표시하지만 이름을 사용하는 것이 좋습니다. tail
첫 번째 줄 (테이블 헤더)을 제거하고 여전히 필요합니다. --format
그래도 사용할 수 있습니다 : docker ps | tail -n +2 | while read -a a; do name=${a[$((${#a[@]}-1))]}; echo -ne "$name\t"; docker inspect --format="{{.NetworkSettings.IPAddress}}" $name | cut -d \" -f 4; done
. 그러나 그것은 크게 개선 된 것처럼 보이지는 않습니다 grep
. 더 읽기 쉬운 IMO였습니다.
docker inspect $cid | grep IPAddress | cut -d '"' -f 4 | tail -n 1
Docker Toolbox를 사용하여 Docker를 설치 한 경우 Kitematic 애플리케이션을 사용하여 컨테이너 IP 주소를 얻을 수 있습니다.
docker inspect
당신이 고정 표시기 도구 상자를 실행할 때 작동하지 않습니다. IP 주소를보고하지만 서비스에서 사용할 올바른 주소는 아닙니다.
노트!!! Docker Compose 사용법 :
Docker Compose는 각 클러스터에 대해 격리 된 네트워크를 생성하므로 아래 방법은 작동하지 않습니다 docker-compose
.
가장 우아하고 쉬운 방법은, 쉘 함수를 정의되어 현재 가장-투표 대답을 WouterD의 @ :
dockip() {
docker inspect --format '{{ .NetworkSettings.IPAddress }}' "$@"
}
Docker는 Linux 프로그램과 같은 파일에 컨테이너 ID를 쓸 수 있습니다.
로 실행 --cidfile=filename
하면 Docker는 컨테이너의 ID를 "filename"에 덤프합니다.
자세한 정보는 " Docker에서 PID 동등한 섹션 실행 "을 참조하십시오.
--cidfile="app.cid": Write the container ID to the file
PID 파일 사용하기 :
--cidfile
매개 변수를 사용하여 컨테이너를 실행 하면 app.cid
파일 내용은 다음과 같습니다.
a29ac3b9f8aebf66a1ba5989186bd620ea66f1740e9fe6524351e7ace139b909
파일 컨텐츠를 사용하여 Docker 컨테이너를 검사 할 수 있습니다.
blog-v4 git:(develop) ✗ docker inspect `cat app.cid`
인라인 Python 스크립트를 사용하여 컨테이너 IP를 추출 할 수 있습니다.
$ docker inspect `cat app.cid` | python -c "import json;import sys;\
sys.stdout.write(json.load(sys.stdin)[0]['NetworkSettings']['IPAddress'])"
172.17.0.2
보다 인간 친화적 인 형태는 다음과 같습니다.
#!/usr/bin/env python
# Coding: utf-8
# Save this file like get-docker-ip.py in a folder that in $PATH
# Run it with
# $ docker inspect <CONTAINER ID> | get-docker-ip.py
import json
import sys
sys.stdout.write(json.load(sys.stdin)[0]['NetworkSettings']['IPAddress'])
자세한 정보는 " Docker 컨테이너 IP 주소를 얻는 10 가지 대안 "을 참조하십시오.
호스트의 모든 컨테이너 IP가 표시됩니다.
sudo docker ps -aq | while read line; do sudo docker inspect -f '{{.Name}} - {{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' $line ; done
Docker는 모든 컨테이너 IP 및 해당 이름을 인쇄하는 데 사용합니다.
docker ps -q | xargs -n 1 docker inspect --format '{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}} {{ .Name }}' | sed 's/ \// /'
완전성을 위해 :
나는 --format
옵션을 정말로 좋아 하지만 처음에는 그것을 알지 못했기 때문에 동일한 결과를 얻기 위해 간단한 Python one-liner를 사용했습니다.
docker inspect <CONTAINER> |python -c 'import json,sys;obj=json.load(sys.stdin);print obj[0]["NetworkSettings"]["IPAddress"]'
사용하다:
docker inspect $CID | grep IPAddress | grep -v null| cut -d '"' -f 4 | head -1
$ docker inspect c4591485328d | grep IPAddress | grep -v null| cut -d '"' -f 4 | head -1
172.17.0.2
들어 윈도우 용기 사용
docker exec <container> ipconfig
여기서 컨테이너 <container>
의 이름 또는 ID 입니다.
docker ps
컨테이너의 ID를 찾는 데 사용할 수 있습니다 .
컨테이너 ID를 잊었거나 쉘 명령으로 조작하고 싶지 않은 경우 Portainer와 같은 UI를 사용하는 것이 좋습니다.
$ docker volume create portainer_data
$ docker run -d -p 9000:9000 -v /var/run/docker.sock:/var/run/docker.sock -v portainer_data:/data portainer/portainer
여기에서 컨테이너 IP에 대한 모든 정보를 찾을 수 있습니다.