CI/CDパイプラインの標準化、パッケージ化、結合テスト
3番目のステップで取り組んだのはパイプラインの標準化だという。杉野氏のチームは、自分のチームだけでなく、社内やNTTグループの複数の開発チームにCI/CDパイプラインを提供しており、個別対応が増えてしまう状況にあった。
そこで、各種マイクロサービスで共通して利用可能なCI/CDパイプラインの開発標準を確立するとともに、運用フローや手順書なども整備していった。その結果、さらにCI/CDパイプラインの安定性や変更容易性を向上できたという。
このようにしてCI/CDパイプラインの標準化を進めていったものの、複数のアプリケーション開発に適用するのが難しい個別要件がたびたび発生した。しかし、共通のパイプラインという関係上、個別要件を考慮していくとどうしても大きく複雑な仕様になってしまう。その結果、時間が経つにつれてCI/CDパイプラインの安定性や変更容易性の確保が難しくなってきたのだ。
そこで、4番目のステップとして、コンポーザブルなパイプライン構築に取り組んだという。パイプラインの共通部品をパッケージ化しておいて、開発チームがパッケージを組み合わせることでパイプラインを構築できるようにしたのだ。
コンポーザブルなパイプラインの実現のために、CUE言語というオープンソースのデータバリデーション言語を採用した。このCUE言語でパッケージを実装しており、開発者はパッケージを選択し組み合わせるだけで標準化されたパイプラインを生成できるようにしたのだ。CUE言語は、パッケージ化できるだけでなく、シンプルに制約を記述できたり、複数のデータ構造を直感的に結合できるといった特徴を持っている。
こうしたパイプラインのパッケージ化を可能にしたことで、個別要件への対応しやすさとさらなる安定性・変更容易性を両立できた。
さらに、5番目のステップとしてパッケージを利用した結合テストに取り組んだ。このための仕組みはGo言語で実装されたという。
「この3年間、このようにPipeline as Codeという形でCI/CDパイプラインをメンテナンスしてきました。その結果として、Secret管理サービス機能を利用した機密情報管理やBlue/Greenデプロイ機能のインテグレーションなどの実装を安定して組み込むことができました」(杉野氏)
なお、パッケージ化してパイプラインを提供する技術を用いて、パッケージを組み合わせるだけで独自要件に合わせたアプリケーション基盤とそれを継続的に改善する仕組みを提供するDevOpsプラットフォームである「Qmonus Value Stream」を社内外の開発チームに提供していると紹介し、セッションを締めくくった。
クラウドの複雑さに課題を感じている方に!
クラウドは近年ますます複雑化してきています。本来は顧客への価値創造に使うべきエンジニアの時間は、クラウドの検証や学習にも多く使われるようになってきています。Qmonus Value Streamは、パッケージを組み合わせるだけでお客様の独自要件に合わせたアプリケーション基盤とそれを継続的に改善する仕組みを提供するDevOpsプラットフォームです。現在フリートライアルをご用意しておりますので、ぜひこの機会に無料でお試しください。