Kubernetesで安全にアプリケーションをデプロイするCDツール“Spinnaker”とは
4月19日に開催された「Japan Container Days v18.04」カンファレンス。「Spinnakerを利用したKubernetesへの継続的デリバリ」のセッションでは、株式会社エーピーコミュニケーションズの溝内 崇氏が、CDツールの「Spinnaker」を解説した。
Spinnakerはクラウド用CDツール
溝内氏は冒頭で本セッションの内容について「Kubernetesの環境で安全にアプリケーションをデプロイする仕組み」と紹介。Kubernetesでは実現が難しい課題として「CI/CDの機能がなく別途用意する必要があること」を挙げた。
CI/CDには、テストなどを回し開発者に問題をフィードバックして高品質を保つ「CI(継続的インテグレーション)」と、CIで作られた高品質なものをステージングやプロダクションにもっていく「CD(継続的デリバリ)」が含まれる。これらは、高品質なプロダクトをユーザーに素早く届けることを目的としている。Spinnakerは、このうちCDをKubernetesなどで実現するが、CIは含まないため別途必要だという。
Spinnakerは、パイプラインやBlue/Greenデプロイメントなど、アプリケーションの自動デプロイに必要な機能を実装している。もともとNetflixが開発したオープンソースソフトウェアで、GoogleやMicrosoftも開発に参加。マルチクラウド対応で、Kubernetesのほか、いくつかのIaaSやPaaS(Google App Engine)に対応している。ちなみに、Spinnakerとは「ヨットの帆」のことだ。
Spinnakerの主な機能
ここから、溝内氏はSpinnakerの特徴となる機能を1つずつ紹介した。
1つめは、Kubernetesに標準実装されているデプロイ機能だ。
2つめは、GUIでパイプラインを簡単に作れること。溝内氏は例として、10分待つのとテストの実行とで両方が正常だったらデプロイする、という場合の操作画面を示した。
3つめは、複数のデプロイメント方法をサポートしていること。「Red/Black Deploy(Blue/Greenデプロイメントに相当するNetflix用語)」「Rolling Red/Black Deploy(ローリングアップデート)」「Canary Deploy」の3種類をサポートする。ユースケースとしては、Red/Blackは切り替え・切り戻しを瞬時にしたいとき、Rolling Red/Blackは段階的に切り替えたいとき、Canary Deployは新しいものを試験するときなど最小構成だけ切り替えたいときに使うという。いずれもボタンをクリックするだけでロールバックできる。
4つめはパイプライン中にカスタムスクリプトを実行できること。これにより「Serverspec」や「Selenium」などのテスト工程を組み込めるという。
5つめは、前述したようにCIが別途必要なこと。ただし、連携できるのは「Jenkins」と「Travis CI」の2つのみだという。
6つめは進捗状況の通知機能だ。溝内氏はSlackに通知する例を示した。
7つめはパイプラインの途中で承認フローを組み込めること。例えば、テストまでは自動だが本番には管理者の承認が必要、というケースなどに通知と組み合わせて使用できる。
そのほかにも溝内氏が興味をもったものの検証できなかった機能として、デプロイできる時間帯を限定する「White-listed Execution Windows」や、ランダムに障害を起こすChaos Monkeyを組み込む「Chaos Monkey Integration」、Webhookのトリガー、認証機能などがあるという。ただし、Spinnakerのクセとして、ほぼ同じものでもKubernetesと用語が違うものがあることを溝内氏は注意した。
Spinnakerの今後については、2か月ごとにバージョンアップされること、KubernetesのManifestをデプロイする機能が追加されてKubernetes環境そのものをCD可能になること、カナリアテストのOSS「Kayanta」と連携可能になることが挙げられた。
Spinnakerのメリットとデメリット
最後に溝内氏の所感が語られた。デメリットとしては、現時点では情報が少ないため、トラブルが起こったときなどにソースコードを読むなどのトラブルシューティング能力が必要とされることが挙げられた。また、マルチクラウド対応のため、前述のようにKubernetesと用語のミスマッチがあることも挙げられた。
一方、メリットしてはCDする上で必要な機能が過不足なく揃っていることが挙げられた。また、GUIでKubernetesのコンポーネントを作成できる点が便利なことや、Kayanta対応など機能拡充が進んでおり今後の動向に期待できることが挙げられた。
写真提供: https://www.flickr.com/groups/3958077@N22/
[C-2]Spinnakerを利用したKubernetesへの継続的デリバリ[Takashi Mizouchi(AP Communications)]
連載バックナンバー
Think ITメルマガ会員登録受付中
全文検索エンジンによるおすすめ記事
- 「GitOps」を活用して、アプリケーションを効率的かつ自動的にデプロイする
- OpenShift Commonsで知る継続的デリバリーのSpinnaker最新情報
- CNCFのサンドボックスプロジェクト、カオスエンジニアリングのLitmus Chaosを紹介
- OpenShift Commons Gatheringで語られたOpenShiftに最適なCI/CDとは
- CI/CDから障害の復旧までハイレベルの運用自動化を実現するKeptnとは
- オープンでロックインなし 業務でKubernetesを使うための“最高の仕事道具”とは
- Oracle Cloud Hangout Cafe Season4 #3「CI/CD 最新事情」(2021年6月9日開催)
- CNCFのWebinarからKubernetesのデプロイメントに冪等性を実現するwerfを紹介
- CNDT 2022、NTTコムのエンジニアがマニフェストレスを実現したIaCのためのSaaSを解説
- OpenStack Summit 2018 インフラの次はCI/CDに注目