Docker創始者らが開発、ビルド/テスト/デプロイの自動化をポータブルにするツール「Dagger」登場。そのままローカルでもGitHubでもCircleCIでも実行可能に
今回は「Docker創始者らが開発、ビルド/テスト/デプロイの自動化をポータブルにするツール「Dagger」登場。そのままローカルでもGitHubでもCircleCIでも実行可能に」についてご紹介します。
関連ワード (再利用可能、特定、記述法等) についても参考にしながら、ぜひ本記事について議論していってくださいね。
本記事は、Publickey様で掲載されている内容を参考にしておりますので、より詳しく内容を知りたい方は、ページ下の元記事リンクより参照ください。
Dockerの創始者であるSolomon Hykes氏らが中心となって開発しているオープンソースのCI/CD環境構築ツール「Dagger」が公開されました。
Windows、Mac、Linuxで試すことができます。
And we are live! Introducing Dagger, a new way to build CI/CD pipelines. By the creators of Docker. https://t.co/DU8racmoUo
— dagger (@dagger_io) March 30, 2022
Daggerが定義したCI/CDパイプラインはポータブルになる
Daggerとは「A Portable Devkito for CI/CD Pipelines」だと説明されています。すなわち、ソフトウェアのビルド、テスト、デプロイを行う一連のCI/CDパイプラインをポータブルにするための開発キットだ、ということです。
具体的には、DaggerでいちどCI/CDパイプラインを定義すれば、そのまま定義を書き換えることなくローカルのPCやサーバで実行可能なだけではなく、GitHubやCircleCIなどの主要なCI/CDサービスの上でも実行可能になります。
一般に、例えばGitHubを利用して構成したCI/CDパイプラインを、ローカルで再現しようとする場合、もしくはJenkinsやCircleCIやGitLabなどの別のツールやサービスを用いて再構築しようとする場合、設定ファイルなどの大幅な書き換えや作り直しをせざるを得ません。
そのため、ほとんどのCI/CDパイプラインはそれを構成するプラットフォームやサービスにロックインされている状態と言えます。
ところがDaggerでCI/CDパイプラインの定義をすると、その定義を書き換えることなくローカルのPC環境でも、サーバでも、GitHubでもJenkinsでもCircleCIでも、同じ機能を持つCI/CDパイプラインを構築できるようになります。
これにより、CI/CDパイプラインが特定のツールやサービスにロックインされることがなくなります。また、開発者は開発チームののCI/CDパイプラインと同じものを簡単に手元のローカルPCで再現することや、逆にローカルのCI/CDパイプラインをサービス上に大規模に展開することなどができるようになります。
DaggerのGitHubのページにも、以下の2つの利点が強調されています。
- Unify dev and CI environments. Write your pipeline once, Dagger will run it the same everywhere.
- Reduce CI lock-in. No more re-writing everything from scratch every 6 months.
1つ目は、開発環境とCI環境の統合。一度CI/CDパイプラインを記述すれば、Daggerはそれをどこでも同じように実行する、ということ。2つ目は、CI環境へのロックインの削減。(環境の変更により)6カ月ごとにすべてを最初から書き直すことは、もうしなくてよい、ということです。
Dockerコンテナが登場したことにより、ローカルのPC、サーバ上のビルド環境、ステージング環境、本番環境などに対する高いポータビリティが実現され、それらの間でソフトウェアを自由に移動、展開させることが容易になりました。
Daggerはこれをさらに推し進め、ビルド、テスト、デプロイを含む一連のCI/CDパイプラインをまるごとポータブルにし、ローカルのPC上の開発環境でも、開発チームが管理するステージング環境でも、どんな環境に対してもCI/CDパイプラインの移動、展開を容易にするものと言えます。
Daggerのおもな構成要素はCUE言語とBuildKit
DaggerのこうしたCI/CDパイプラインのポータビリティを実現している主なテクノロジーは、CUE言語とBuildKitの2つです。
CUE言語とは、Googleが開発した設定記述向けのプログラミング言語です。
現在、さまざまなソフトウェアの設定ファイルの記述法として、YamlやJSONが採用されていますが、必ずしも表現力や可読性が十分とは言えない場面があります。
CUE言語はこうした設定を記述するための構文、表現力、可読性を考慮して作られたプログラミング言語であり、高い表現力と機能、可読性を備えつつ、高度で抽象的な記述を可能にしています。
Daggerでは、このCUE言語を用いてCI/CDパイプラインを記述することになります。
一方、Daggerにおいてビルドやデプロイといったいわゆるアクションは、Dockerコンテナとして実行されます。そのためDaggerのユーザーはこれらのアクションを好きな言語で記述し、実行できます。このときDockerコンテナをビルドするのがBuildKitです。
Daggerでは、これらのDockerコンテナによるアクションをさまざまな場面やプラットフォームで再利用可能になっています。
現時点でDaggerはパブリックベータの段階で、Mac、Windows、Linuxのローカル環境でのCI/CDパイプラインの構築を試すことができるほかに、GitHub、GitLab、Jenkinsに対応する方法も説明されています。
開発の主体となっているDagger社は昨年700万ドルの投資を受け、さらに今年3月に2000万ドルの追加投資を受けたことを発表しています。これらを原資に、完成度の向上と機能追加、そして商品化を目指した開発が行われていくことになります。
関連記事
Solomon Hykes氏がDockerを去ったのは、ちょうど4年前の2018年4月でした。
- Docker発展の貢献者、Docker社創業者兼CTOのSolomon Hykes氏がDockerを去ると発表