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
茨城県、関係人口データを一元管理–移住希望者への最適な情報発信を目指す
IT関連
2023-07-26 11:55
Anker、FMトランスミッター4製品を自主回収 総務省の調査を受け
IT関連
2021-02-15 08:02
バイデン氏、巨大企業の規制推進派カーン氏をFTC委員長に
IT関連
2021-06-16 14:30
M2搭載「MacBook Air」–薄型軽量化されたアップル製ノートを写真でチェック
IT関連
2022-08-12 20:59
UBE、基幹システムを「SAP S/4HANA Cloud」で刷新–リアルタイムデータで意思決定を高度化
IT関連
2024-10-18 04:38
お寺のデジタル化サービスが提供–本堂と別館をつなぐシステムなど
IT関連
2022-04-16 20:34
RHEL互換ディストリビューション、SUSEも参入へ。制限なく誰でも利用できるRHEL互換OSを開発していくと
Linux
2023-07-18 20:20
⾃⾛型ロープウェイ「Zippar」設計・開発のZip Infrastructureが3000万円を調達
モビリティ
2021-03-18 12:13
アップル、Siriに「性別の区別が明確につかない声」を追加
IT関連
2022-02-27 08:58
「freee会計」、改正電子帳簿保存法対応のファイルボックス機能を全プランで提供開始
IT関連
2022-01-19 21:31
EUがAmazonに過去最大約971億円の罰金、ターゲット広告目的で顧客データを使用
ネットサービス
2021-08-01 18:31
コンカー、三村真宗氏が代表取締役社長を退任–橋本祥生氏が執行役員社長に
IT関連
2024-01-14 21:03
TwitterのCEOとラッパーのジェイ・Z氏がアフリカとインドにビットコイン開発基金を設立、500BTC(24.8億円相当)を投資
ブロックチェーン
2021-02-14 01:00
Rent the RunwayのiOSチームがアプリのリリースサイクルを管理するRunwayを開発
ソフトウェア
2021-03-13 08:16