ホームページ >データベース >mysql チュートリアル >MySQL と PostgreSQL: コンテナ化環境のベスト プラクティス
MySQL と PostgreSQL: コンテナ化環境のベスト プラクティス
クラウド コンピューティングとコンテナ化テクノロジの急速な発展に伴い、ますます多くの企業がアプリケーションをコンテナ内にデプロイし始めています。コンテナ内でデータベースを実行することは一般的な要件であり、MySQL と PostgreSQL の 2 つは一般的なデータベースの選択肢です。この記事では、コンテナ化された環境で MySQL と PostgreSQL を使用するためのベスト プラクティスを検討し、いくつかのサンプル コードを提供します。
コンテナ化された環境では、適切なデータベース イメージを選択することが重要な最初のステップです。 Docker Hub は、公式およびコミュニティが管理するデータベース イメージを多数提供する優れたリソースです。 MySQL の場合は、mysql:latest など、公式に提供されているイメージを使用できます。 PostgreSQL の場合は、postgres:latest など、公式に提供されているイメージを使用できます。
コンテナ内でデータベースを実行するには、適切な構成が必要です。 MySQL および PostgreSQL の場合、環境変数を使用してコンテナを構成できます。次に、MySQL コンテナの構成例を示します。
docker run -d --name mysql-container -e MYSQL_ROOT_PASSWORD=mysecretpassword mysql:latest
このコマンドは、mysql-container という名前の MySQL コンテナを作成し、root ユーザーのパスワードを mysecretpassword に設定します。
同様に、PostgreSQL コンテナを構成するには、次のコマンドを使用できます:
docker run -d --name postgres-container -e POSTGRES_PASSWORD=mysecretpassword postgres:latest
このコマンドは、postgres-container という名前の PostgreSQL コンテナを作成し、postgres ユーザーのパスワードを mysecretpassword に設定します。
コンテナ化された環境では、コンテナのライフサイクルは一時的であり、コンテナが再起動されると、コンテナ内のデータは失われます。したがって、コンテナーの再起動後もデータを保持するには、永続ストレージを構成する必要があります。 MySQL および PostgreSQL の場合、データ ディレクトリはホストのファイル システムにマウントできます。以下は、データ ディレクトリをマウントする MySQL コンテナの例です。
docker run -d --name mysql-container -v /path/to/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=mysecretpassword mysql:latest
この例では、/path/to/data はホスト上のディレクトリであり、MySQL コンテナはこのディレクトリにデータを保存します。
PostgreSQL の場合、同様の方法を使用してデータ ディレクトリをマウントできます。
docker run -d --name postgres-container -v /path/to/data:/var/lib/postgresql/data -e POSTGRES_PASSWORD=mysecretpassword postgres:latest
コンテナ化された環境では、コンテナ同士が通信する必要がある場合があります。コンテナ内のデータベースに接続するには、コンテナ ネットワークを使用して接続する必要があります。以下は、MySQL コンテナとアプリケーション コンテナ間の接続の例です。
# 创建数据库容器 docker run -d --name mysql-container -e MYSQL_ROOT_PASSWORD=mysecretpassword mysql:latest # 创建应用程序容器,并连接到数据库容器 docker run -d --name app-container --link mysql-container:mysql your-app-image
この例では、アプリケーション コンテナは、mysql-container にリンクすることによって MySQL データベースと通信します。
PostgreSQL の場合、同様の方法を使用してアプリケーション コンテナに接続することもできます。
# 创建数据库容器 docker run -d --name postgres-container -e POSTGRES_PASSWORD=mysecretpassword postgres:latest # 创建应用程序容器,并连接到数据库容器 docker run -d --name app-container --link postgres-container:postgres your-app-image
データベースのバックアップは次のとおりです。データベース管理において非常に重要な重要な部分です。コンテナ化された環境では、コンテナのバックアップ機能を使用してデータベースのバックアップを実装できます。次に、MySQL コンテナ データのバックアップの例を示します。
docker exec mysql-container mysqldump -u root -pmysecretpassword --all-databases > backup.sql
このコマンドは、mysql-container コンテナで mysqldump コマンドを実行し、すべてのデータベース データを backup.sql ファイルにエクスポートします。
同様に、同様のコマンドを使用して PostgreSQL コンテナのデータをバックアップできます:
docker exec postgres-container pg_dumpall -U postgres > backup.sql
このコマンドは、postgres-container コンテナで pg_dumpall コマンドを実行し、すべてのデータベース データをバックアップにエクスポートします。 .sql ファイル。
概要
この記事では、コンテナ化された環境で MySQL と PostgreSQL を使用するためのベスト プラクティスについて説明し、いくつかのサンプル コードを提供します。適切なデータベース イメージの選択、データベース コンテナの構成、永続ストレージの構成、コンテナ ネットワークを使用したデータベースへの接続、およびコンテナ化されたデータベースのバックアップは、コンテナ化された環境で MySQL と PostgreSQL を使用するための重要な手順です。データベース コンテナを適切に構成および管理することで、コンテナ化された環境で高パフォーマンスで信頼性の高いデータベース サービスを確保できます。
以上がMySQL と PostgreSQL: コンテナ化環境のベスト プラクティスの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。