複数の環境 (ローカル、CI/CD、運用環境) にわたって MySQL を利用する Spring Boot アプリケーションを開発する場合、データベース資格情報を動的に処理するために不可欠です。
問題:
application.properties では、一般的なアプローチは MySQL 情報をハードコーディングすることです。ただし、各環境には独自のデータベース構成がある可能性があるため、異なる環境でプロジェクトを実行する場合に問題が発生します。
提案された解決策:
この問題に対処するには、各環境に適切な値を持つシステム環境変数を作成することをお勧めします。これらの環境変数を application.properties で使用して、データ ソース フィールドを動的にできます。
環境変数を使用する手順:
システム環境変数の作成:
次のシステム環境変数を作成しますMySQL用構成:
環境変数を application.properties に組み込みます:
application.properties 内で、ハードコードされた値を環境に置き換えます。変数:
spring.datasource.url = ${OPENSHIFT_MYSQL_DB_HOST}:${OPENSHIFT_MYSQL_DB_PORT}/"nameofDB" spring.datasource.username = ${OPENSHIFT_MYSQL_DB_USERNAME} spring.datasource.password = ${OPENSHIFT_MYSQL_DB_PASSWORD}
代替アプローチ:
もう 1 つの推奨されるアプローチは、Spring のプロファイル固有のプロパティを使用することです。環境変数 spring.profiles.active を宣言すると、Spring はアクティブなプロファイルに基づいて、対応するプロパティ ファイルを自動的に読み取ることができます。例:
このアプローチでは、application.properties ファイルは変更されませんが、環境固有のファイルになります。構成は、プロファイル固有のプロパティ ファイルで定義されます。
以上がSpring Boot で複数の環境にわたってデータベース資格情報を動的に管理するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。