여러 Docker 컨테이너로 작업할 때 컨테이너 작업을 조정하고 준비 상태를 확인하는 것이 중요할 수 있습니다. MySQL 컨테이너를 배포하고 데이터베이스가 준비되면 스크립트를 실행하는 예를 들어보겠습니다. 그러나 질문에서 언급한 것처럼 조기 실행으로 인해 문제가 발생하면 MySQL의 가용성을 감지하기 위한 안정적인 메커니즘의 필요성이 강조됩니다.
제공된 Bash 스크립트는 반복적으로 시도하는 루프에 의존하여 실용적인 솔루션을 제공합니다. 성공적으로 연결될 때까지 MySQL에 연결합니다. 효과적이기는 하지만 모든 시나리오에 최적인 것은 아닙니다.
대신 mysql-client와 함께 사용할 수 있는 mysqladmin 유틸리티를 활용하는 것이 좋습니다. 패키지. mysqladmin은 MySQL 인스턴스 관리를 위한 명령줄 인터페이스를 제공합니다. 유용한 기능 중 하나는 대상 서버에 연결을 시도하는 ping 명령입니다.
mysqladmin을 대기 프로세스에 통합하려면 적절한 호스트 및 인증 매개변수를 사용하여 mysqladmin ping을 반복적으로 실행하는 루프를 사용하면 됩니다. 명령이 MySQL 연결 성공을 나타내는 오류를 더 이상 반환하지 않으면 추가 작업을 진행하십시오.
while ! mysqladmin ping -h"$DB_HOST" --silent; do sleep 1 done
이 접근 방식은 MySQL 준비를 기다리는 보다 가볍고 대상화된 수단을 제공하고 리소스 소비를 최소화하며 안정적인 컨테이너를 보장합니다. 조율합니다.
위 내용은 Docker 컨테이너에서 MySQL 준비를 정상적으로 기다리는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!