다른 컨테이너에서 MySQL 컨테이너에 연결
MySQL을 실행하는 Docker 컨테이너를 설정하고 포트 3306을 노출했지만 어떻게 할 수 있습니까? 다른 컨테이너에서 해당 데이터베이스에 액세스하십니까?
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 주소에 의존할 필요가 없어집니다.
위 내용은 Docker의 다른 컨테이너에서 MySQL 컨테이너에 연결하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!