> 운영 및 유지보수 > Docker > docker가 mysql에 들어갈 수 없으면 어떻게 해야 합니까?

docker가 mysql에 들어갈 수 없으면 어떻게 해야 합니까?

PHPz
풀어 주다: 2023-04-25 09:36:51
원래의
1471명이 탐색했습니다.

Docker는 기본 이미지에 독립적인 실행 환경을 구축하고 애플리케이션과 서비스를 휴대용 컨테이너로 패키징할 수 있는 인기 있는 컨테이너화 기술입니다. Docker는 단순성, 사용 용이성, 속도, 효율성 및 손쉬운 배포를 특징으로 하여 개발 작업을 더욱 편리하고 효율적으로 만듭니다. 하지만 Docker를 사용하다 보면 MySQL 컨테이너에 진입하지 못하는 등의 문제가 자주 발생합니다.

Docker의 MySQL 컨테이너는 로컬에 설치된 MySQL처럼 작동할 수 있지만 어떤 경우에는 MySQL 컨테이너에 들어갈 수 없는 상황이 발생합니다. 아래에서는 Docker 컨테이너에 MySQL을 입력할 수 없는 이유와 해결 방법을 구체적으로 분석해 보겠습니다.

  1. MySQL 컨테이너가 시작되었는지 확인

먼저 MySQL 컨테이너가 올바르게 시작되었는지 확인해야 합니다. Docker 명령 "docker ps -a"를 통해 모든 컨테이너의 상태를 볼 수 있습니다. MySQL 컨테이너가 시작되지 않거나 실행이 중지된 경우 MySQL 컨테이너를 다시 시작해야 합니다. 컨테이너는 "docker start [컨테이너 ID]" 명령으로 시작할 수 있습니다.

  1. MySQL 컨테이너 실행 상태 확인

MySQL 컨테이너가 성공적으로 시작되면 “docker exec” 명령을 사용하여 컨테이너에 들어갈 수 있습니다. 하지만 컨테이너가 정상적으로 시작되지 않으면 컨테이너에 들어갈 수 없습니다. 컨테이너가 실행되고 있지 않으면 다음 명령을 사용하여 컨테이너를 시작할 수 있습니다.

docker run --name [容器名称] -p [端口号]:3306 -e MYSQL_ROOT_PASSWORD=[密码] -d mysql:latest
로그인 후 복사
로그인 후 복사
로그인 후 복사
  1. MySQL 컨테이너 포트 설정을 확인하세요.

또한 컨테이너를 실행할 때 포트가 올바르게 설정되지 않은 경우 컨테이너에 들어갈 수 없으며 MySQL 데이터베이스에 액세스할 수도 없습니다. 다음 명령어를 사용하여 컨테이너의 포트가 올바르게 설정되었는지 확인할 수 있습니다.

docker port [容器ID]
로그인 후 복사

콘솔에 포트 정보가 표시되지 않으면 포트가 성공적으로 설정되지 않은 것입니다. 다음 명령을 사용하여 컨테이너 설정을 다시 수행할 수 있습니다.

docker run --name [容器名称] -p [端口号]:3306 -e MYSQL_ROOT_PASSWORD=[密码] -d mysql:latest
로그인 후 복사
로그인 후 복사
로그인 후 복사
  1. MySQL 컨테이너 네트워크 유형 확인

기본적으로 Docker는 "--network=bridge" 매개변수를 사용하여 컨테이너 네트워크를 생성합니다. 이렇게 하면 컨테이너가 호스트와 동일한 네트워크 위치에 배치되어 컨테이너를 실행하는 모든 프로세스가 컨테이너 내부의 MySQL 데이터베이스에 액세스할 수 있습니다. 그러나 어떤 경우에는 호스트 또는 없음과 같은 다른 네트워크 유형을 사용해야 합니다. 따라서 MySQL 컨테이너에 들어가기 전에 컨테이너의 네트워크 유형이 올바르게 설정되었는지 확인해야 합니다.

다음 명령을 사용하여 컨테이너의 네트워크 유형을 확인할 수 있습니다.

docker inspect [容器ID] | grep NetworkMode
로그인 후 복사

네트워크 유형이 브리지가 아닌 경우 docker 명령을 다시 실행하여 올바른 컨테이너 네트워크 유형을 설정해야 합니다.

  1. MySQL 컨테이너 환경 변수를 확인하세요

MySQL 컨테이너를 실행할 때 환경 변수를 통해 MySQL 루트 사용자 비밀번호를 지정해야 합니다. 예:

docker run --name [容器名称] -p [端口号]:3306 -e MYSQL_ROOT_PASSWORD=[密码] -d mysql:latest
로그인 후 복사
로그인 후 복사
로그인 후 복사

환경 변수가 설정되지 않으면 MySQL 데이터베이스는 사용할 수 없습니다. 액세스할 수 없으며 MySQL 컨테이너에 들어갈 수 없습니다. 따라서 필요한 모든 환경 변수가 올바르게 설정되었는지 확인해야 합니다.

  1. MySQL 데이터베이스가 시작되었는지 확인하세요

마지막으로 MySQL 컨테이너에 들어갈 수 없다면 MySQL 데이터베이스가 제대로 시작되지 않았기 때문일 수 있습니다. 다음 명령을 통해 MySQL 데이터베이스의 상태를 확인할 수 있습니다.

docker logs [容器ID] | grep "MySQL Community Server"
로그인 후 복사

로그에 "MySQL Community Server... selected"와 같은 정보가 표시되면 MySQL 데이터베이스가 성공적으로 시작되었음을 의미합니다. 이 정보가 보이지 않는다면, 컨테이너 환경 변수, 포트 번호 등이 올바르게 구성되었는지 확인해야 합니다.

요약하자면, Docker 컨테이너에 MySQL 데이터베이스를 입력할 수 없다면 위의 요인 중 하나 때문일 수 있습니다. MySQL 컨테이너가 Docker 환경에서 제대로 실행되도록 하려면 이러한 문제를 하나씩 해결하고 올바른 구성 및 환경 변수를 설정해야 합니다.

위 내용은 docker가 mysql에 들어갈 수 없으면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿