강의

멘토링

커뮤니티

인프런 커뮤니티 질문&답변

김주희님의 프로필 이미지
김주희

작성한 질문수

비전공자도 이해할 수 있는 Docker 입문/실전

[실습] Docker로 MySQL 실행시켜보기 - 3

volume 생성 후 DB 조회 시 동일한 DB 없음

작성

·

156

·

수정됨

0

PS C:\Users\SSAFY\Inflearn\docker-mysql> docker run -e MYSQL_ROOT_PASSWORD=$(비밀번호) -d -p 3306:3306 -v C:\Users\SSAFY\Inflearn\docker-mysql\mysql_data:\var\lib\mysql mysql
0b272839d37a21ba514052f486d744988addbbfd898f88e4bbb77383c1a35d6c
PS C:\Users\SSAFY\Inflearn\docker-mysql> docker ps
CONTAINER ID   IMAGE     COMMAND                   CREATED          STATUS          PORTS                               NAMES
0b272839d37a   mysql     "docker-entrypoint.s…"   14 seconds ago   Up 13 seconds   0.0.0.0:3306->3306/tcp, 33060/tcp   unruffled_diffie
PS C:\Users\SSAFY\Inflearn\docker-mysql> docker exec -it 0b2 bash
bash-5.1# mysql -u root -p
Enter password:
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 9
Server version: 9.3.0 MySQL Community Server - GPL

Copyright (c) 2000, 2025, Oracle and/or its affiliates.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| sys                |
+--------------------+
4 rows in set (0.014 sec)

mysql> create database mydb;
Query OK, 1 row affected (0.024 sec)

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mydb               |
| mysql              |
| performance_schema |
| sys                |
+--------------------+
5 rows in set (0.001 sec)

mysql> exit
Bye
bash-5.1# exit
exit
PS C:\Users\SSAFY\Inflearn\docker-mysql> docker ps
CONTAINER ID   IMAGE     COMMAND                   CREATED              STATUS              PORTS                               NAMES
0b272839d37a   mysql     "docker-entrypoint.s…"   About a minute ago   Up About a minute   0.0.0.0:3306->3306/tcp, 33060/tcp   unruffled_diffie
PS C:\Users\SSAFY\Inflearn\docker-mysql> docker rm -f 0b2
0b2
PS C:\Users\SSAFY\Inflearn\docker-mysql> docker run -e MYSQL_ROOT_PASSWORD=$(비밀번호) -d -p 3306:3306 -v C:\Users\SSAFY\Inflearn\docker-mysql\mysql_data:\var\lib\mysql mysql
e0dbe2fa08d4ba1dec0442afacf5290a4c6ecef265be723e489b5d08f1ec237f
PS C:\Users\SSAFY\Inflearn\docker-mysql> docker ps
CONTAINER ID   IMAGE     COMMAND                   CREATED         STATUS         PORTS                               NAMES
e0dbe2fa08d4   mysql     "docker-entrypoint.s…"   9 seconds ago   Up 8 seconds   0.0.0.0:3306->3306/tcp, 33060/tcp   romantic_booth
PS C:\Users\SSAFY\Inflearn\docker-mysql> docker exec -it e0d
docker: 'docker exec' requires at least 2 arguments

Usage:  docker exec [OPTIONS] CONTAINER COMMAND [ARG...]

See 'docker exec --help' for more information
PS C:\Users\SSAFY\Inflearn\docker-mysql> docker exec -it e0d bash
bash-5.1# mysql -u root -p
Enter password:
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 9
Server version: 9.3.0 MySQL Community Server - GPL

Copyright (c) 2000, 2025, Oracle and/or its affiliates.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| sys                |
+--------------------+
4 rows in set (0.014 sec)

강사님과 동일하게 volume 생성 후 다른 컨테이너로 접속 시 mydb가 조회되지 않습니다... 원인이 무엇인지 궁금합니다.
비밀번호는 암호화했습니다.

답변 2

0

JSCODE 박재성님의 프로필 이미지
JSCODE 박재성
지식공유자

안녕하세요 주희님! 질문 잘 해주셨습니다:)

아래 답변에 나와있는 해결 방법으로 한 번 시도 해보시겠어요~??

https://inf.run/7d8pW

만약 위 링크에 있는 해결 방법으로도 해결 안 되시면 질문 또 남겨주세요!!

김주희님의 프로필 이미지
김주희
질문자

해결했습니다 감사합니다 !

0

안녕하세요, 인프런 AI 인턴입니다. 김주희님.

Docker 컨테이너에서 볼륨을 사용하여 데이터베이스를 지속화하려는 과정에서 문제가 발생하신 것 같습니다. MySQL에서 볼륨을 사용할 때 데이터가 영구적으로 저장되지 않는 문제는 주로 볼륨 마운트의 경로 설정이나 볼륨의 초기화 문제에서 발생할 수 있습니다.

문제 분석

  1. 볼륨 마운트 경로 확인: 윈도우에서는 호스트 경로를 마운트할 때 경로의 형식이 매우 중요합니다. 예를 들어, 윈도우 경로는 백슬래시(\) 대신 슬래시(/)를 사용해야 하며, 절대 경로를 사용할 때는 "C:/Users/SSAFY/Inflearn/docker-mysql/mysql_data"와 같이 따옴표로 경로를 감싸서 사용하는 것이 권장됩니다.

  2. 볼륨 초기화 문제: MySQL 컨테이너를 처음 실행할 때 데이터 디렉토리가 비어 있지 않으면, MySQL은 자체 초기화 과정을 건너뛰고 기존 데이터를 사용합니다. 이 과정에서 다른 컨테이너가 기존의 초기화된 데이터가 있는 디렉토리를 사용하면 데이터베이스 구성이 제대로 되지 않을 수 있습니다.

해결 방법

  • 올바른 경로 설정: 호스트 경로를 사용할 때는 위에서 언급한 것처럼 슬래시(/)와 따옴표로 경로를 감싸서 사용해 보십시오.

  • 볼륨을 새로 생성하여 사용: 아래 명령어로 데이터 저장을 보장하기 위해 Docker가 관리하는 자체 볼륨을 사용하는 방법입니다. 이는 경로 문제를 피하고 데이터 손실을 방지할 수 있습니다.

  docker volume create mysql-data
  docker run -e MYSQL_ROOT_PASSWORD=비밀번호 -d -p 3306:3306 -v mysql-data:/var/lib/mysql mysql

이 방법은 Docker 볼륨을 직접 생성하여 사용하는 것이기 때문에, 컨테이너가 삭제되더라도 데이터베이스 데이터는 보존됩니다.

추가 정보가 필요하시다면 다음의 유사한 질문을 참고해보세요:
- 윈도우 볼륨 생성 안되는 문제
- docker volume 생성 이후 container 종료

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

김주희님의 프로필 이미지
김주희

작성한 질문수

질문하기