Docker: MySQL コンテナへのデータのコミット
MySQL コンテナ イメージにデータをコミットしようとする場合、その影響を理解することが重要です。データ ボリューム。
公式の MySQL Docker イメージは、データ ボリュームを使用してデータを保存します。これにより、コンテナの存続期間を超えてデータを永続化できますが、コミットされたイメージにデータが含まれないことも意味します。
MySQL とともにイメージにデータをコミットするには、ボリュームなしのカスタムベースイメージを作成します。たとえば、次の Dockerfile を使用して MySQL イメージに基づいて新しいイメージを作成します:
FROM mysql:latest RUN rm -rf /var/lib/mysql/ CMD ["mysqld"]
次に、カスタム イメージを構築します:
docker build -t my-custom-mysql-image .
このカスタム ベース イメージを使用すると、次のことができます。以前と同様にコンテナを作成してデータをインポートします:
docker run --name my-mysql-container -e MYSQL_ROOT_PASSWORD=secret -d my-custom-mysql-image docker exec -it my-mysql-container bash mysql -uroot -psecret -e 'create database liferay_psat1;' mysql -uroot -psecret liferay_psat1 < /mnt/liferay_sql_dump.sql
次に、コンテナを新しいイメージとしてコミットすると:
docker commit -m "Imported liferay sql dump" my-mysql-container my-custom-mysql-image:v1
インポートされたデータはコミットされたイメージに含まれますそして、そのイメージを使用して新しいコンテナを開始するときに使用できます。
以上がMySQL Docker コンテナにデータをコミットして保存する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。