Docker를 활용하면 특정 프로그램을 컨테이너로 뛰울 수 있다.
프로그램에 기능이 추가되면 새로운 이미지를 만들어 컨테이너를 실행시켜야 한다.
이때 Docker는 기존 컨테이너에서 변경된 부분을 수정하지 않고 새로운 컨테이너를 만들어서 통째로 갈아 끼우는 방식으로 교체한다.
이런 특징 때문에 기존 컨테이너를 새로운 컨테이너로 교체하면 기존 컨테이너 내부에 있던 데이터도 같이 삭제된다.
만약 이컨테이너가 데이터베이스를 실행시키는 컨테이너였다면 저장된 데이터도 같이 삭제 된다.
따라서 컨테이너 내부에 저장된 데이터가 삭제되면 안되는 경우에는 볼룸(Volume) 이라는 개념을 사용한다.
도커의 볼룸(Volume)이란 도커 컨테이너에서 데이터를 영속적으로 저장하기 위한 방법이다.
볼룸은 컨테이너 자체의 저장 공간을 사용하지 않고 호스트 자체의 저장 공간을 고유해서 사용하는 형태이다.
$ docker run -v [호스트의 디렉토리 절대경로]:[컨테이너의 디렉톤리 절대경로] [이미지]:[태그명]
$ docker run -e MYSQL_ROOT_PASSWORD=password123 -p 3306:3306 -d mysql
$ echo $MYSQL_ROOT_PASSWORD
또는
$ exprot
$ docker exec -it [MySQL 컨테이너 ID] bash

$ cd /User/test $ mkdir docekr-mysql
# docker run -e MYSQL_ROOT_PASSWORD=password123 -p 3306:3306 -v {호스트의 절대경로}/mysql-sql:/var/lib/mysql -d mysql
$ docker run -e MYSQL_ROOT_PASSWORD=password123 -p 3306:3306 -v /User/test/docker-mysql:/var/lib/mysql -d mysql`
$ docker exec -it [MySQL 컨테이너 ID] bash
$ mysql -u root -p
mysql> show database;
mysql> create databases mydb;
mysql> show datavbases;
# 컨테이너 종료 후 삭제하고 다시 생성
$ docker stop [MySQL 컨테이너 ID]
$ docker rm [MySQL 컨테이너 ID]
$ docker run -e MYSQL_ROOT_PASSWORD=password123 -p 3306:3306 -v /User/test/docker-mysql:/var/lib/mysql -d mysql
$ docker exec -it [MySQL 컨테이너 ID] bash
$ mysql -u root -p
mysql> show database;
mysql> show datavbases;