Monorepoの運用を支援する、OSSのキャッシュビルドシステム「Zim」柔軟なビルド、デプロイを実現

複数のパッケージを単一リポジトリで管理するMonorepoが注目されている。1つの変更を関連する複数のパッケージに適用できるなどのメリットがあるが、優れたツールがなければ破綻する。

2020年10月22日 08時00分 公開
[Adrian BridgwaterComputer Weekly]

 クラウドセキュリティ企業Fugueが興味深い技術を提案している。Fugueは「フュージー」(few-g)と発音する。だが、その名前はバロック時代に人気があった多声部から成る音楽スタイル(フーガ)に由来する。

 同社のコア製品は、クラウドアプリケーション開発にセキュリティを組み込んで「Amazon Web Services」(AWS)、「Microsoft Azure」「Google Cloud Platform」の構成ミスをなくし、クラウドの曖昧で未知の要素をソフトウェアエンジニアが制御できるようにすることでコンプライアンスを証明しようとしている。

 Fugueの最初のスタックはセキュリティに軸を置くソフトウェアだった。だが、今は「Zim」という「非セキュリティ」分野の新しいオープンソースプロジェクトをリリースしている。

会員登録(無料)が必要です

 Zimは、Monorepo(モノレポ)を利用するチーム向けのキャッシュビルドシステムだ。

Monorepoとは

 Monorepoとは、多くのプロジェクトのコードを同じリポジトリに格納するソフトウェア開発戦略のことだ。Atlassianのサイトの記載によると、Monorepoのプロジェクトはそれぞれがほぼ無関係か疎結合型で、他の手段(例えば、依存関係管理ツール)によって接続される可能性が高いという。Monorepoは全てのコードと資産が1カ所にあるため、単一ソースの可視性が高い。同じ理由でコラボレーションの助けにもなる。また、開発者が1つのコードに「アトミックな変更」を行うだけで複数のプロジェクト全体に影響を及ぼすことができるため、開発速度も向上する。

 では、Zimは何を行うのだろうか。

 前述の通り、Zimは多くのコンポーネントや依存関係が含まれるMonorepoを使用する開発者向けに設計されたキャッシュビルドシステムだ。チーム全体に「高速増分並列ビルド」を提供する。「Docker」によるクロスプラットフォームビルド向けの組み込みサポートにより、言語に依存しないビルドシステムを実現する。

 Zimは、GitHubでホストされるオープンソースプロジェクトとして入手できる。

 「Zimの開発には、『GNU Make』の基本概念と『Buck』(Facebook)、『Bazel』(Google)、『Please』(Thought Machine)が採用するキャッシュ戦略にヒントを得ている。GNU Makeと同様、Zimは入力や出力を定義する新しいルールの簡単な表現方法と、出力の作成に必要なコマンドなどを備えている。ZimではRule Keys(ルールキー)を処理する。ルールの入力と構成を組み合わせたハッシュを基にルールの出力がキャッシュ内に既に存在するかどうかを判断するのに、このルールキーが使用される」と、Fugueの共同設立者でコミュニケーション部門のバイスプレジデントを務めるドリュー・ライト氏は同製品のリリースノートに記載している。

 FugueがクラウドセキュリティとコンプライアンスSaaSをAWSに構築するに当たって、最初は「AWS Lambda」と「AWS Fargate」によるサーバレスアプローチを採用した。それは、仮想サーバ(「Amazon EC2」インスタンスなど)の管理を避け、AWSのメカニズムによってセキュリティとジョブを分離して応答性の高い動的なスケーリングできるようにするためだった。

 そのため、チームは全コードをMonorepoに格納し、Makefileを使ってタスクのビルドとデプロイを全てスクリプト化することにした。

 だが、システムのコンポーネントが数百に増えるとMakefileのアプローチは扱いにくくなり、ビルドと成果物の管理ツールを改善する必要があることが分かってきた。

 「Zimとその共有キャッシュにより、多くの一般的なタスクのビルド時間が大幅に短縮された。Zimの共有ビルドテンプレートを再利用すると、Makefileベースのビルドスクリプトのメンテナンスも大幅に減少した。当社のテンプレートライブラリはPython、Go、Node.jsで記述されており、AWS LambdaとAWS Fargate用バイナリの効率的なビルドをサポートする」(ライト氏)

 Zimの主な特徴は次の通りだ。詳細については同社のブログを参照してほしい。

  • 高速並列ビルド

入力が変化する場合のみルールが実行され、他の開発者が既にビルドしている場合は共有キャッシュから出力が取り出される。

  • ビルド手順の簡単な定義

新しい種類のコンポーネントのビルド方法を数行のYAMLで定義する。

  • ビルド環境の分離とクロスプラットフォームコンパイル

組み込みのDockerサポートを利用。コンポーネントのビルド時に使うDockerイメージを指定するだけだ。

  • 入出力リソースの種類の柔軟性

Zimはネイティブなサポート対象リソースとしてファイルとDockerイメージの両方と連携可能。

  • 共有キャッシュの設定が容易

「AWS CloudFormation」により「Amazon S3」に設定できる。

  • 軽量で簡単なインストール

ZimはGoで記述され、単一のバイナリにビルドされる。そのため、事実上全てのCI/CDパイプラインと互換性がある。

Copyright © ITmedia, Inc. All Rights Reserved.

新着ホワイトペーパー

事例 株式会社エヌ・ティ・ティ・データ・イントラマート

東レ・メディカルの事例に学ぶ、ローコード開発による“脱Notes”の推進方法

東レグループ全体でNotesからの脱却が進められたため、移行に向けたプロジェクトを開始した東レ・メディカル。約600のNotesアプリケーションを稼働させていたという同社は、どのようにプロジェクトを成功させたのだろうか。

事例 株式会社エヌ・ティ・ティ・データ・イントラマート

ERPフロント更改で変化への対応力を強化、エクシオグループのシステム刷新術

システムの老朽化が課題となっていたエクシオグループでは、パッケージ製品やローコード開発プラットフォームを使ったERPフロントの刷新を進め、ビジネス変化への対応力を高めたシステムを実現している。同社の取り組みを紹介する。

事例 株式会社エヌ・ティ・ティ・データ・イントラマート

三菱UFJニコスの業務改革、ハイパーオートメーション基盤の構築とその成果

三菱UFJニコスは、2017年にデスクトップ型RPAを導入した。その活用が拡大するにつれ、さまざまな課題が生じていたことから、「ハイパーオートメーション」の概念を取り入れた業務改革に踏み切った。改革の中身を詳しく見ていく。

事例 株式会社エヌ・ティ・ティ・データ・イントラマート

業務標準化とシステム開発の両立に成功、事例に学ぶ工程管理システムの刷新術

関西電力グループで電気通信などの事業を手掛けるオプテージでは、法人向け製品の工程管理において業務の属人化と情報の分断という課題を抱えていた。同社は、業務標準化とシステム開発を両立するためにあるシステム基盤を導入する。

製品資料 株式会社エヌ・ティ・ティ・データ・イントラマート

企業DX推進の障壁を取り除き、業務改革を実現するクラウド対応基盤とは?

DX推進の障壁には、アナログ業務の継続、データのサイロ化、複数システム間の非効率な確認作業などがある。本資料では、これらの課題を解決する方法として、ローコード開発プラットフォーム「intra-mart」を紹介する。

アイティメディアからのお知らせ

From Informa TechTarget

「テレワークでネットが遅い」の帯域幅じゃない“真犯人”はこれだ

「テレワークでネットが遅い」の帯域幅じゃない“真犯人”はこれだ
ネットワークの問題は「帯域幅を増やせば解決する」と考えてはいないだろうか。こうした誤解をしているIT担当者は珍しくない。ネットワークを快適に利用するために、持つべき視点とは。

ITmedia マーケティング新着記事

news017.png

「サイト内検索」&「ライブチャット」売れ筋TOP5(2025年5月)
今週は、サイト内検索ツールとライブチャットの国内売れ筋TOP5をそれぞれ紹介します。

news027.png

「ECプラットフォーム」売れ筋TOP10(2025年5月)
今週は、ECプラットフォーム製品(ECサイト構築ツール)の国内売れ筋TOP10を紹介します。

news023.png

「パーソナライゼーション」&「A/Bテスト」ツール売れ筋TOP5(2025年5月)
今週は、パーソナライゼーション製品と「A/Bテスト」ツールの国内売れ筋各TOP5を紹介し...