Docker 기술은 2013년 출시 이후 클라우드 컴퓨팅에서 널리 사용되는 컨테이너 기술 중 하나가 되었습니다. 이를 통해 개발자는 애플리케이션을 휴대용 컨테이너에 패키징하여 다양한 환경에서 쉽게 배포하고 실행할 수 있습니다. 그러나 일부 시나리오에서는 Docker 컨테이너의 네트워크 구성이 약간 복잡해질 수 있습니다. 예를 들어 외부 네트워크와 통신하기 위해 컨테이너가 필요한 경우, 컨테이너가 ARP 테이블을 자동으로 업데이트하지 못해 네트워크 통신이 차단되는 상황이 발생하는 경우가 있습니다. 이 문서에서는 Docker가 ARP를 업데이트하지 않는 이유와 이를 해결하는 방법을 살펴보겠습니다.
ARP(주소 확인 프로토콜)는 네트워크에서 MAC 주소를 확인하는 데 사용되는 프로토콜입니다. 호스트가 다른 호스트와 통신해야 할 경우 먼저 대상 호스트의 MAC 주소를 알아야 합니다. 대부분의 경우 호스트가 다른 호스트와 처음 통신할 때 대상 호스트의 MAC 주소를 얻기 위해 로컬 네트워크에 ARP 요청을 보내기 때문에 이는 문제가 되지 않습니다. 그러나 Docker 컨테이너의 경우 이 프로세스가 문제가 될 수 있습니다.
Docker는 Linux 커널 가상화 기술을 기반으로 하며 Linux 네트워크 네임스페이스 및 네트워크 브리징 기술을 사용하여 컨테이너에 네트워크 기능을 제공합니다. 네트워크 네임스페이스와 네트워크 브리징 기능을 사용하여 컨테이너의 가상 네트워크 카드를 호스트의 물리적 네트워크 카드에 연결할 수 있습니다. 그러나 컨테이너가 패킷을 전송하면 Docker는 컨테이너를 생성할 때 컨테이너의 IP 주소와 MAC 주소를 Docker 호스트의 ARP 테이블에 등록합니다. 이러한 방식으로 다른 호스트가 컨테이너와 통신해야 할 때 Docker 호스트의 ARP 테이블에서 컨테이너의 MAC 주소를 얻을 수 있습니다. 그러나 컨테이너의 IP 주소가 변경되면 Docker는 ARP 테이블의 레코드를 자동으로 업데이트하지 않으므로 네트워크 통신이 차단됩니다.
Docker가 ARP를 업데이트하지 않는 문제를 해결하는 방법에는 여러 가지가 있습니다. 한 가지 방법은 Docker 호스트의 ARP 캐시를 수동으로 지우는 것입니다. 다음 명령을 실행하여 이 작업을 수행할 수 있습니다.
sudo ip -s -s neigh flush all
이 명령은 Docker 호스트에서 ARP 캐시를 지워서 Docker가 ARP 테이블의 레코드를 업데이트하도록 합니다. 또한 다음 명령을 실행하여 컨테이너의 ARP 테이블을 사용할 수도 있습니다. arping
命令,对容器进行 Ping 测试,以强制 Docker 更新 ARP 表。例如,如果我们想要更新 IP 地址为 172.17.0.3
sudo arping -U 172.17.0.3
위 내용은 Docker가 ARP를 업데이트하지 않는 이유 살펴보기의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!