BT

最新技術を追い求めるデベロッパのための情報コミュニティ

寄稿

Topics

地域を選ぶ

InfoQ ホームページ ニュース コピー&ペーストのデプロイから完全なGitOpsへ移行する方法

コピー&ペーストのデプロイから完全なGitOpsへ移行する方法

原文リンク(2025-01-02)

InnerSourceは、GitOpsを導入する際、企業固有のロジックを共有することで開発作業の軽減に貢献したと、Jemma Hussein Allen氏はQCon Londonで語った。彼女は講演の中で、コピー&ペーストのデプロイメントから完全なGitOpsへと移行した方法を示した。彼女は、心理的に安全な環境は、ペインポイントを解決しイノベーションを促進するのに役立つオープンで正直な議論のために本当に重要であると述べた。

当時のバージョン管理ツールはサブバージョンだったが、より一般的な分散バージョン管理システム、Gitベースの開発者プラットフォームであるGithubに移行した。

GitOpsの実装を始めたとき、彼らのサーバーはLAMPスタック(Linux、Apache、MySQL、PHP)を使っていた。Hussein Allen氏は、これはPHPウェブ・アプリケーションの標準的なソフトウェア・スタックであり、アプリケーションは順調に稼働しているため変更したくなく、焦点はデプロイの自動化にあった、と言及した。

CI/CDツールとしてJenkinsを選択したのは、ブロック構成を構築する際のパイプラインの柔軟性、他のツールとのプラグイン統合が数多く用意されていたからだとHussein Allen氏は言った。Puppetは、最近のデプロイですでに実装されており、うまく機能していたため、構成管理に使用された。よって、Puppetを使用し続ける決定がされた、と彼女は言及した。

Hussein Allen氏は、GitOpsの4つの原則について言及した。

  • 宣言的 - 望ましいシステムの状態は、宣言的に定義される必要がある。
  • Versioned and Immutable(バージョン管理され、不変である) - 望ましいシステムの状態は、不変かつバージョン管理の手法で保存される必要がある。
  • 自動プル - 望ましいシステムの状態は、手動介入なしで自動的にソースからプルされる。
  • 継続的な調整 - システムの状態は継続的に監視され、調整される。

フセイン・アレン氏によると、彼らがもっとも重要だと考えた原則は、宣言的なシステム状態の定義、強固なバージョン管理、継続的なリコンシリエーションである。それらが、より早い開発とデプロイメントの観点で利点をもたらしたからである。

フセイン・アレン氏によれば、手作業による介入をすべて排除することについては、彼らはより慎重に行ったという。自動テストの完全な包括的セット、高可用性、非常に成熟した監視ソリューション、チームの作業方法との互換性が必要だったからだ。

フセイン・アレン氏が説明したように、開発者はDockerを使ってワークスペースをカスタマイズした。

我々は、開発者がベースイメージをダウンロードできるイメージレジストリを設定し、マルチ環境のテストとデプロイのワークフローに統合する前に、ローカルで新機能を開発・テストするためのビルディングブロックとして使用できるようにしました。

変更前は、開発者はローカルでコードを変更し、テストのために開発環境にデプロイしていたとフセイン・アレン氏は言う。複数の開発者が開発環境で異なる変更を同時にテストする必要があるときに、このテスト方法では課題が生じた、と彼女は説明する。

開発環境に複数の変更が含まれている場合、個別にテストすることができず、信頼できる結果が得られませんでした。イメージ・レジストリを使うことで、開発者は、メインの開発テスト・プールに変更を統合する前に、本番環境で稼動しているコードに対して、自分の変更をローカルで分離してテストできるようになりました。

GitOps に関する開発者からのフィードバックから浮かび上がった共通のテーマは、より迅速に導入するためのビルディング・ブロックと「クイック・スタート」ガイドの必要性だった。InnerSource機能を導入することで、開発者はこうしたビルディング・ブロックやボイラープレートを作成して貢献するようになった、とHussein Allen氏は言う。共有リソースへの貢献の増加は、開発者が新しいツールを導入するスピードに、ポジティブかつ直接的な影響を与えた。

開発者の要求が進化するにつれて、心理的に安全な環境の中でオープンな対話することは、開発者の進化するニーズを理解する上で非常に重要である、とフセイン・アレン氏は言う。定期的なつながりや強固なオフライン・コミュニケーション・チャンネルを確立することで、開発者はプラットフォームのロードマップや、彼らの仕事に影響を与える可能性のある変更について、常に最新の情報を得ることができる。これらのチャネルは、開発者からのフィードバックや提案を得る貴重な機会にもなり、プラットフォーム戦略に統合できる、と彼女は締めくくった。

InfoQ は、GitOps の採用についてJemma Hussein Allen 氏にインタビューした。

InfoQ: 開発者が古い仕事のやり方から移行するのを助けるために何をしましたか?

Jemma Hussein Allen: 開発者のトレーニングやペアプログラミングに時間を費やしました。いくつかのチームでは、新しい働き方に移行するのに時間がかかりました。重い業務負荷となり、開発者が新しいプロセスに慣れ、古い働き方と同じように効率的に使えるようになるには時間がかかるためです。チームのプロダクトオーナーや利害関係者と協力して、新しいプロセスの利点を示すことで、開発者が新しいツールを学び、日常業務に導入するための帯域幅を与えることができました。

InfoQ: 開発者のニーズを把握し、対話を続けるためのアプローチは?

Jemma Hussein Allen: 開発者のニーズを理解する上で役に立ったのは、プラットフォーム・エンジニアと開発者がより緊密に協力する機会を提供することでした。プラットフォーム・チームが一元化された組織においては、「私の立場で一日を過ごしてみよう」といった取り組みによって、プラットフォーム・エンジニアが短期間プロダクト・チームに参加したり、逆にプロダクト・エンジニアが短期間プラットフォーム・チームに参加したりすることは、あらゆるペインポイントまたはプラットフォームに対して行うことができる改善点への理解を得るためにとても価値がある可能性があります。

作者について

関連するコンテンツ

BT