ダイナミックコンフィグ
プロジェクトごとに毎回 CircleCI 設定ファイルを手動で作成するのではなく、特定の パイプライン値やファイルパスに応じて設定ファイルを動的に生成できると便利な場合があります。
CircleCI のダイナミックコンフィグ機能により、以下が可能となります。
- 条件付きでワークフローやコマンドを実行する。
- パイプライン パラメーターの値を渡す/ 別の設定ファイルを生成する。
- デフォルトの親
.circleci/
ディレクトリの外部に存在する別のconfig.yml
をトリガーする。
チームでのコードの格納に、複数のリポジトリではなくモノレポ (単一のリポジトリ) を使用している場合には特に、条件付きの自動生成が役立ちます。
例えば、リポジトリで変更されたファイルまたはサブディレクトリに基づいて、ダイナミックコンフィグを使用し、特定のワークフローをトリガーすることが考えられます。 そうしなければ、ちょっとした更新を加えるだけだとしても、すべてのマイクロサービスやサブプロジェクトでビルド、テスト、デプロイの一連のプロセスを毎回行うことになります。 このシナリオは、_パス フィルタリング_とも呼ばれます。
ダイナミックコンフィグを使用するもう 1 つのシナリオは、プロジェクトが複数のモジュールから構成され、それぞれのモジュールが別のジョブを要求する場合です。 こうしたジョブは、設定ファイルの_フラグメント_として複数のファイルに格納できます。 1 つの完全な .circleci/config.yml
ファイルを使用する代わりに、パイプラインがトリガーされると、ダイナミックコンフィグを使用してこうした個別のフラグメントを結合して完全な設定ファイルにすることができます。 このシナリオは、_コンフィグ分割_とも呼ばれます。
CircleCI のダイナミックコンフィグの入門ガイド
CircleCI でダイナミックコンフィグの使用を開始するには、以下の手順に従います。
- CircleCI Web アプリケーションの Projects ダッシュボードで、目的のプロジェクトを選択します。
- 右上隅の Project Settings ボタンをクリックします。
- 左側のパネルで Advanced を選択します。
-
Enable dynamic config using setup workflows (セットアップ ワークフローによるダイナミックコンフィグを有効にする) 設定までスクロールし、下記画像のようにオンにします。
- 上記のステップにより、ダイナミックコンフィグ機能が使用できるようになりますが、静的な
config.yml
はこれまでどおり動作します。 この機能は、config.yml
にsetup
キーとtrue
値を追加しないと使用できません。setup: true
キーを (.circleci/
ディレクトリ内の) 親設定ファイルの最上部に追加すると、そのconfig.yml
は設定ファイルとして指定されます。 setup
ワークフローの最後で、continuation
Orb からcontinue
ジョブを呼び出す必要があります。 注: ダイナミックコンフィグの使用 で説明されているように、 指定されたファイルの更新 に基づいてワークフローまたはステップを条件付きで実行する場合 (“パスフィルタリング”)、これは適用 されません 。
ダイナミックコンフィグが機能するしくみ
CircleCI のダイナミックコンフィグ機能では、セットアップワークフローを使用します。 _セットアップ ワークフロー_には、パイプラインパラメーターを演算するジョブを含めることが可能で、パイプラインパラメーターは、その後、他のディレクトリに存在する別の設定ファイルに渡すことができます。 セットアップ ワークフローはまた、既存のスクリプトを使って新しい設定ファイルを生成することもできます。 いずれの場合でも、セットアップワークフローは、目的の次の設定ファイルまでパイプラインを続行します。
その裏では、continuation 設定は、パブリック_pipeline continuation (パイプラインの続行)_ API への呼び出しとして実行されます。 この API は、_continuation キー_を受け入れます。このキーはジョブ (初期セットアップ ワークフローの一部として実行) の環境に自動的に挿入され、パイプラインごとに一意のシークレットキーとなります。 API はまた、設定ファイル文字列と一連のパイプライン パラメーターも受け入れます。
次の内容に注意してください。
- セットアップには、
version: 2.1
以上を指定する必要があります。 - パイプラインは一回のみ続行できます (つまり、別のセットアップ設定では、パイプラインは続行できません)。
- パイプラインは、作成して 6 時間以内であれば続行できます。
- セットアップ設定には、1 つのワークフローのみを含めることができます。
- 続行時間に送信されたパイプラインパラメーターは、トリガー (セットアップ) 時に送信されたパイプラインパラメーターとオーバーラップすることはできません。
- セットアップ設定で宣言されたパイプラインパラメーターは、continuation 設定でも宣言される必要があります。 このパラメーターは、続行時に使用することができます。
セットアップ ワークフローを使用してダイナミックコンフィグを生成する方法の基本的な例は、 ダイナミックコンフィグの使用を参照してください。
ダイナミックコンフィグに関するよくあるご質問
パイプラインパラメーター
Q: パイプラインパラメーターは API でしか使用できないのではありませんか?
A: 以前はそうでした。 今では、ダイナミックコンフィグ機能を使用すると、パイプラインが実行される (API または Webhook のいずれかからトリガーされる、つまり VCS へのプッシュイベント) 前に、パイプラインパラメーターを動的に設定できるようになりました。
カスタム Executor
Q: カスタム Executor を使用できますか?
A: カスタム Executor は使用できますが、continuation ステップが機能するように、特定の依存関係をインストールする必要があります (現時点: curl
、jq
)。
continuation Orb
Q: continuation
Orb とは何ですか?
A: continuation
Orb は、パイプラインの続行プロセスを管理できるようにユーザーを支援します。 continuation
Orb は、 continuePipeline
に対する API 呼び出しをラップします。 詳細については、 continuation
Orb のドキュメントを参照してください。
Q: continuation Orb を使用しないことは可能ですか?
A: continuation Orb でカバーされない特別な要件がある場合は、他の方法で同じ機能を実装することができます。 Orb を使って続行機能がどのように実装されているかを学習するには、 Orb Sourceを参照してください。
次のステップ
- ダイナミックコンフィグの使用 ガイド
-
continuation
Orb -
continuePipeline
API 呼び出し - CircleCI Academy の ダイナミックコンフィグコース を受講すると、さらに詳しく学ぶことができます。
ドキュメントの改善にご協力ください
このガイドは、CircleCI の他のドキュメントと同様にオープンソースであり、 GitHub でご利用いただけます。 ご協力いただき、ありがとうございます。
- このページの編集をご提案ください (最初に「コントリビューションガイド」をご覧ください)。
- ドキュメントの問題点を報告する、またはフィードバックやコメントを送信するには、GitHub で issue を作成してください。
- CircleCI は、ユーザーの皆様の弊社プラットフォームにおけるエクスペリエンスを向上させる方法を常に模索しています。 フィードバックをお寄せいただける場合は、リサーチコミュニティにご参加ください。
サポートが必要ですか
CircleCI のサポートエンジニアによる、サービスに関する問題、請求およびアカウントについての質問への対応、設定の構築に関する問題解決のサポートを行っています。 サポートチケットを送信して、CircleCI のサポートエンジニアにお問い合わせください。日本語でお問い合わせいただけます。
または、 サポートサイト から、サポート記事やコミュニティフォーラム、トレーニングリソースをご覧いただけます。
CircleCI Documentation by CircleCI is licensed under a Creative Commons Attribution-NonCommercial-ShareAlike 4.0 International License.