はじめに
docker-composeファイルをもらって起動して色々とやっていたんだけれども、後からMySQLのデータが永続化されていなくてDocker落としたくねぇ、、となった時のお話
MySQLデータの永続化の手順
- MySQLデータをホストにコピーする
- Dockerコンテナを落とす
- docker-compose.ymlの書き換え
- Dockerコンテナの起動
MySQLデータをホストにコピーする
MySQLのデータはコンテナ内の/var/lib/mysqlの中にあります。
まずこれをホストPC(ローカル)にコピーしてきます。
まずは以下のコマンドでMySQLコンテナのコンテナIDを調べる。
1 | docker ps |
MySQLのコンテナIDが分かったらホストPCにデータファイルをコピーするコマンドを実行します。
1 | docker cp <コンテナID>:/var/lib/mysql <コピー先のパス> |
この時はじめにコピー先のディレクトリが存在していない場合は作成しておきましょう。
ディレクトリがなければエラーになります。
Dockerコンテナを落とす
おなじみのコマンド。
1 | docker-compose down |
docker-compose.ymlの書き換え
MySQLコンテナの記述の部分に下記を追加します。
1 2 | volumes: - <MySQLデータをコピーしたパス>:/var/lib/mysql |
Dockerコンテナの起動
これまたおなじみのコマンド。
1 | docker-compose up -d |
MySQLのデータを確認するとDockerを落とす前と同様で永続化されていることがわかります!
以上です。