Docker의 컨테이너 간 통신 방법: 1. 컨테이너 IP를 사용하여 액세스합니다. 2. 호스트의 "ip:port"를 사용하여 액세스합니다. 3. 링크를 사용하여 통신을 위한 연결을 설정합니다. ” 소통을 위해 .
이 튜토리얼의 운영 환경: linux7.3 시스템, docker-1.13.1 버전, Dell G3 컴퓨터.
1. 컨테이너 IP를 통해 액세스
컨테이너가 다시 시작되면 IP가 변경됩니다. 컨테이너 IP를 통해 액세스하는 것은 좋은 솔루션이 아닙니다.
2. 호스트의 ip:port를 통해 액세스
호스트의 ip:port를 통해 액세스하면 제한된 통신을 위해 노출된 포트에서 수신 대기하는 프로세스에만 의존할 수 있습니다.
3. 링크를 통해 연결 설정(공식적으로 권장하지 않음)
컨테이너 실행 시 소스 컨테이너와 링크된 컨테이너가 서로 통신할 수 있도록 매개변수 링크를 지정하고, 수락된 컨테이너는 해당 컨테이너의 일부 데이터를 얻을 수 있습니다. :환경 변수와 같은 소스 컨테이너.
# 源容器:mysql docker run -itd --name test-mysql -e MYSQL_ROOT_PASSWORD=root mysql:5.7 #被链接容器 centos docker run -itd --name test-centos --link test-mysql:mysql centos /bin/bash #进入test-centos docker exec -it test-centos /bin/bash
링크 이름이나 링크할 때 사용한 별칭을 통해 직접 들어갈 수 있습니다:
링크를 통해 설정된 컨테이너는 링크된 컨테이너가 소스 컨테이너에 ping을 보낼 수 있지만 그 반대는 불가능합니다.
링크된 컨테이너의 환경 변수 보기
링크된 컨테이너는 소스 컨테이너의 환경 변수 정보를 상속합니다.
/etc/hosts의 호스트 항목과 달리 환경 변수에 저장된 IP 주소는 소스 컨테이너를 다시 시작해도 자동으로 업데이트되지 않습니다. 연결된 컨테이너의 IP 주소를 확인하려면 /etc/hosts의 호스트 항목을 사용하는 것이 좋습니다.
Docker는 환경 변수 외에도 소스 컨테이너의 호스트 항목을 /etc/hosts 파일에 추가합니다.
소스 컨테이너가 다시 시작되면 링크 컨테이너의 /etc/hosts 파일이 소스 컨테이너의 새 IP 주소로 자동 업데이트되어 링크 통신을 계속할 수 있습니다.
4. 사용자 정의 네트워크를 통해 브리지 네트워크 생성(권장)
docker 네트워크를 수행하고, docker 실행 시 새로 생성된 브리지 네트워크에 컨테이너를 할당하여 동일한 브리지 네트워크에 있는 컨테이너가 를 통해 서로 접근할 수 있도록 합니다.
네트워크 만들기
docker network create test-network
컨테이너를 시작할 때 생성된 네트워크에 가입하세요
docker run -it --network test-network --network-alias mysql -e MYSQL_ROOT_PASSWORD=123 mysql:5.7
연결된 컨테이너 시작
docker run -it --network test-network --network-alias centos centos /bin/bash
추천 학습: "docker 비디오 튜토리얼"
위 내용은 Docker의 컨테이너 간 통신 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!