Docker創始者らが開発、ビルド/テスト/デプロイの自動化をポータブルにするツール「Dagger」登場。そのままローカルでもGitHubでもCircleCIでも実行可能に
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 Devkit 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万ドルの追加投資を受けたことを発表しています。これらを原資に、完成度の向上と機能追加、そして商品化を目指した開発が行われていくことになります。
追記(2022/10/26)
DaggerでGo言語が使えるようになりました。
関連記事
Solomon Hykes氏がDockerを去ったのは、ちょうど4年前の2018年4月でした。
あわせて読みたい
Google、ノーコード開発ツールのAppSheetに新機能「Apps Script connector for AppSheet」。Apps Script経由でのGoogle Workspaceとの連携処理が容易に
≪前の記事
「Visual Studio 2022 for Mac」の正式リリース近づく。macOSネイティブUI搭載、Apple M1プロセッサ対応、サーバレスアプリ開発対応など新機能