GitHubは200万行規模のRailsアプリケーションであり、毎週RailsとRubyを最新版にアップデートし続けている

今回は「GitHubは200万行規模のRailsアプリケーションであり、毎週RailsとRubyを最新版にアップデートし続けている」についてご紹介します。

関連ワード (可能性、運用、開発等) についても参考にしながら、ぜひ本記事について議論していってくださいね。

本記事は、Publickey様で掲載されている内容を参考にしておりますので、より詳しく内容を知りたい方は、ページ下の元記事リンクより参照ください。


4月10日でサービス開始からちょうど15周年を迎えたGitHubは、当初からRuby on Railsを用いたモノリシックなアプリケーションとして作られてきました。現在では200万行近い規模のコードになっているそうです。

今年1月には1億人以上のデベロッパーが利用することも発表しており、GitHubはまさに世界最大級のRailsアプリケーションと言っていいでしょう。

そのGitHubは5年前の2018年、Railsのバージョンを3.2から5.2に上げる作業に1年半を費やし。そして二度とこのようなことにならないよう、より頻繁にアップデートを行うべき、などの教訓を得たとしていました。

そして現在、GitHubは毎週月曜日にRailsのアップデート作業を開始するようになっており、またRubyも毎週アップデートを行っていることをブログ「Building GitHub with Ruby and Railsで明らかにしました。

See how we've matured from taking months to migrate from our custom fork of #RubyonRails to a newer stable release to now upgrading in under a week thanks a thorough test suite, great testing environments, and progressive rollout deploys. https://t.co/cXtgDqRz0z

— GitHub (@github) April 6, 2023

現在のGitHubがどのようにRailsとRubyをアップデートしているのか、ブログで書かれているポイントを見てみましょう。

200万行近い規模のコード、Railsを毎週アップデート

前述の通り、ブログによると現在のGitHub.comは200万行近い規模のコードとなっており、1000人以上のエンジニアが開発に取り組んでいるとのことです。

そして1日に20回以上デプロイをし、毎週Railsをアップデートしているとも説明されています。

Railsのアップデートの様子をブログから以下に引用します。

Every Monday a scheduled GitHub Action workflow triggers an automated pull request, which bumps our Rails version to the latest commit on the Rails main branch for that day. All our builds run on this new version of Rails. Once all the builds pass, we review the changes and ship it the next day.

毎週月曜日にはスケジュール化されたGitHub Actionのワークフローが自動的にプルリクエストを実行し、その日のRailsのメインブランチの最新のコミットが、私たちのRailsバージョンに反映されます。
私たちのビルドは、すべてこの新しいバージョンのRailsで実行されます。すべてのビルドがパスした後に変更点がレビューされ、翌日には本番環境へと出荷されるのです。

毎週Railsをアップデートするようになったことで次のようなメリットが得られたとしています。

GitHubを利用しているデベロッパーに最新のツールを提供できる
より優れたデータベース接続処理、より高速なビューレンダリングなど、最新のRailsの機能をユーザーに提供できる

自社独自のRailsパッチが不要になる
自社向けのパッチを作り、それがRailsに反映されるのを待つのではなく、Rails自体にパッチを提案できるようになる

Railsとの協業が容易になる
Railsに提案して次バージョンで反映されるのを待つ代わりに、Railsに対して作業し、翌週には反映されるのを見るようになる

最新の依存関係を維持することで、よりよいセキュリティの状態が得られる
日常的にアップデートしているため、脆弱性の報告があったとしても、なにか特別な作業が発生するわけではない

ビッグバン的なマイグレーションがなくなる
アップデートごとに小さな変更しか行われないため、アップデートによる非互換があったとしても理解しやすく、対処しやすい。

メインブランチのバグを発見し、フィードバックしやすい
これにより開発チームが強化され、アプリケーションへの理解を深めることにもなる

Rubyも毎週アップデート

GitHubではRailsと同じように、Rubyについても毎週アップデートを行っているとのことです。下記もブログからの引用です。

Naturally, we have a similar process for Ruby upgrades. In February 2022, shortly after upgrading to Ruby 3.1, we started building and testing Ruby shas from 3.2-alpha in a parallel build. When CI runs for the GitHub Rails application, two versions of the builds run: one build uses the Ruby version we are running in production and one uses the latest Ruby commit including the latest changes in Ruby, which we update weekly.

当然ながら、Rubyのアップグレードも同様のプロセスで行っています。2022年2月、Ruby 3.1にアップグレードした直後に、Ruby 3.2-alphaのビルドとテストも並行して開始しました。GitHubのRailsアプリケーションのCIが実行されると、2つのバージョンでビルドが実行されます。1つのビルドは本番で運用しているRubyのバージョンを使い、1つは毎週更新しているRubyの最新の変更を含むRubyを使っています。

GitHubは、このようなRailsやRubyのアップデートを行うために、徹底したテストスイートを維持し改善するために働く多くの優秀なエンジニアが必要だと説明しており、それによって自社のテストスイートは問題を発見する可能性が高く、もし発見できなかったとしても、それがユーザーで発覚する前のデプロイ中に発見できると確信していると説明。

それだけGitHubのエンジニアリングは成熟しているのだ、としています。

  • Building GitHub with Ruby and Rails | The GitHub Blog

COMMENTS


Recommended

TITLE
CATEGORY
DATE
ファッション写真から服やアクセを抽出する「Fashionpedia」 Googleなどが開発 :Innovative Tech
イラスト・デザイン
2021-03-20 23:12
中国の偽物・不正ビジネスに切り込む「暴露系」動画が注目を集める
IT関連
2023-11-22 07:50
CTC、EX管理ツールでエンゲージメント向上–データドリブンな人事施策を実現
IT関連
2022-12-07 21:43
ハイブリッドワークで再定義されるオフィス–「コミュニケーション」とはどう付き合う?
IT関連
2023-01-01 10:52
富士通、23年度のキャリア採用拡充–挑戦意欲と「ジョブ」への適性重視
IT関連
2023-03-02 17:14
ライフスタイルブランド「Little Rooms」手掛けるand、5000万円の資金調達を実施
ネットサービス
2021-05-18 17:31
「nasne」3度目の入荷も一晩で完売 来週も入荷あり
くらテク
2021-04-22 03:22
Clubhouse、招待制ようやく終了 新ロゴも披露
アプリ・Web
2021-07-23 03:55
AMD、デスクトップPC向けCPU「Ryzen 7000」シリーズを発表–最大29%高速化
IT関連
2022-09-01 02:42
バイデン大統領のEV販売目標達成に向けて、自動車メーカーが政府の投資拡大を要請
IT関連
2021-08-20 18:18
「もう中学生」が「もう就活生」に 就活マナーを学べる恋愛ゲーム、毎日放送が公開
キャリア・しごと
2021-07-02 14:49
SAP、テクノロジーによる人材活用策を紹介–KDDIのジョブ型人事構築の事例も
IT関連
2021-06-30 07:55
神奈川県予防医学協会、RPAなどの活用で生産性を12%向上
IT関連
2021-03-31 06:16
アルゴリズムに焦点を当てた第230条の改正に向け米議員が公聴会で討議
パブリック / ダイバーシティ
2021-05-02 09:05