다른 컨테이너에서 MySQL 컨테이너에 연결
MySQL을 실행하고 포트 3306을 노출한 Docker 컨테이너를 설정했지만 어떻게 할 수 있습니까? 다른 컨테이너에서 해당 데이터베이스에 액세스합니까?
IP 주소 사용
처음에는 MySQL 컨테이너의 IP 주소(172.17.0.2)를 사용하여 연결을 시도했습니다. 이것이 작동하기는 하지만 IP 주소가 변경될 수 있으므로 이상적이지는 않습니다.
사용자 정의 네트워크
더 나은 접근 방식은 사용자 정의 네트워크를 사용하여 컨테이너를 연결하는 것입니다. 네트워크를 생성하고 여기에 MySQL 및 PHP 컨테이너를 모두 연결할 수 있습니다.
docker network create my_network
컨테이너 연결
두 컨테이너 모두 실행 동일한 네트워크, --network 플래그를 사용하여 네트워크 이름 제공:
docker run -d --name php_container --network my_network my_php_image docker run -d --name mysql_container --network my_network my_mysql_image
해당 네트워크의 컨테이너 내에서 컨테이너 이름을 확인하고 호스트 이름을 사용하여 연결할 수 있습니다. 예를 들어, PHP 컨테이너에서 다음을 사용하여 MySQL에 연결할 수 있습니다:
$mysqli = new mysqli("mysql_container", "mattia", "prova", "prova");
결론
사용자 정의 네트워크는 Docker에서 컨테이너를 연결하는 보다 강력하고 유연한 방법을 제공합니다. 컨테이너 이름을 호스트 이름으로 사용하면 액세스가 단순화되고 IP 주소에 의존할 필요가 없습니다.
부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.
Copyright© 2022 湘ICP备2022001581号-3