FY26 - パッチ適用と OS モダナイゼーション
背景
FY25 において、Ops チームは GitLab.com のサポートインフラに適用されるパッチプロセスのオーナーシップを取得しました。現在注力している領域の概要は以下の通りです。
- VM ベースのパッチ適用作業のランブック整備
- 必要なパッチとリブートについてサービスオーナーへの自動通知の実装
- VM フリートのパッチ適用のための自動化フレームワークの構築
北極星(目指す姿)
デプロイされているすべてのソフトウェアは潜在的なセキュリティリスクを持っています。私たちは SaaS 製品のサポートインフラに影響するすべての脆弱性が自動化された方法で検出・解決できるようにすることを目指します。
FY26 の目標案
- Ubuntu 20.04 での新規インスタンスのデプロイを停止する
- 仮想マシン上で動作する必要があるサービスを文書化する
- VM 以外のインフラワークロードにおけるパッチのギャップに対処する
- Dedicated/Cells とプロセスを統一する
- 共有ランナーの COS イメージの更新サイクルを確立する
- runners-manager インスタンスを Kubernetes に移行する
追加詳細
Ubuntu 20.04 のデプロイ停止
- この OS は 2025 年 4 月にサポート終了を迎えます
- 多くのインスタンスタイプは依然として VM 上で動作する必要があり、EOL 前のアーキテクチャ移行は難しい見通しです
- Production Engineering は FY25 Q4 に Ubuntu 22.04 サポート作業の大部分を完了しました
- Ubuntu 20.04 を完全に廃止する前に、サービスオーナーと追加テストが必要です
仮想マシン上で動作する必要があるサービスの文書化
- サービスを Kubernetes に移行したり、クラウドネイティブな代替手段に置き換えたりすることを議論するケースが定期的に発生します。このような知識をハンドブックページ(または同様のもの)に集約することで、サービスのアーキテクチャ変更が難しい理由や、検討可能な代替案とその前提条件を把握できるようになります。
- 理想的には、よりメンテナンスしやすいインフラへのサービスデプロイの実現可能な選択肢の判断や、将来の計画立案に役立てることができます。
VM 以外のインフラワークロードにおけるパッチのギャップへの対処
- Kubernetes ポッド、CloudRun コンテナ、Cloudflare workers など、VM 以外のインフラワークロードを調査します
- 既存のワークフローがこれらを適切に最新状態に保っているかどうかを判断します
- 発見と更新プロセスの不備に対処するための自動化を追加します
共有ランナーの COS イメージの更新サイクルを確立する
- CI ジョブ VM 上の Container Optimized OS に対して標準化された更新スケジュールを実装し、一貫したセキュリティパッチ適用を確保します
Dedicated/Cells とのプロセス統一
- Cells/Dedicated デプロイメントにおけるセキュリティパッチ適用の現状を評価し、現在の GitLab.com デプロイメントとの重複を特定します
- パッチ適用プロセスの不備を特定して対処します
- プロセスを統合し、可能な限り冗長性を排除することで効率を高める機会を探ります
