DHH氏がRails 8の新機能を解説。Redisなど不要になり、SQLite対応でよりシンプルな構成に。Rails World 2024
今回は「DHH氏がRails 8の新機能を解説。Redisなど不要になり、SQLite対応でよりシンプルな構成に。Rails World 2024」についてご紹介します。
関連ワード (丁寧、十分、検索等) についても参考にしながら、ぜひ本記事について議論していってくださいね。
本記事は、Publickey様で掲載されている内容を参考にしておりますので、より詳しく内容を知りたい方は、ページ下の元記事リンクより参照ください。
9月26日と27日の2日間、カナダのトロントで開催されたRails World 2024の基調講演で、Ruby on Rails(以下Rails)の作者であるDHH(David Heinemeier Hansson)氏が「Rails 8」の主な新機能を紹介しました。
The #RailsWorld 2024 Opening Keynote with @dhh is now online. Rails 8 beta shipped with Authentication, Propshaft, Solid Cache, Solid Queue, Solid Cable, Kamal 2.0, and Thruster. #NoPaaS needed in the One Person Framework. Watch it here: https://t.co/cjpDgczX9Z pic.twitter.com/Iubd6zhbEh
— Ruby on Rails (@rails) September 27, 2024
2021年に登場したRails 7では、JavaScriptの進化やHTTP/2の普及などによりトランスバイラやバンドリングをなくしてNode.jsを用いない構成がデフォルトとなることで、Railsのビジョンとしてシンプルなシステムを指向することが明確に示されました。
参考:Rails 7.0正式リリース、Node.js不要のフロントエンド開発環境がデフォルトに
Rails 8ではこのシンプルな構成がさらに推し進められ、いままで高速なデータ操作のために必要とされてきたRedisおよびMySQLやPostgreSQLの機能や性能をSQLiteだけで置き換えることを可能にする「Solid」や、よりシンプルで高速になったデプロイツール「Kamal 2」、高速なHTTP/2プロキシ「Thurster」などの新機能が組み込まれています。
DHH氏によるRails 8の新機能の紹介を短くまとめました。

Rails 8の主な新機能
DHH氏が1つ目に減給したRails 8の新機能はAuthentication(認証)でした。

DHH氏は、プログラマは認証についてなにが起きているのかを知らなければならないとして、Rails 8では認証機能をコードの生成によって提供すると紹介しました。
これによりプログラマはどのように認証が行われるのかをコードを見て学ぶことができます。
DHH氏はコードを示しながら「美しいコードだ。なぜなら、私が心を込めて丁寧に手作りでコーディングしたからね」と観客の笑いを誘いました。

DHH氏が次に言及したのが「Propshaft」です。

Propshaftはアセットパイプラインと呼ばれるツールで、JavaScriptとCSSをWebブラウザに効率的に配信するために使われます。
Rails 7まではSprocketsと呼ばれるツールが使われていましたが、Rails 8ではビルドをなくすというRailsのビジョンに沿って、よりシンプルなツールとしてのPropshaftがデフォルトで採用されることになりました。
Rails 8はSQLiteだけでデータベースを完結
続いてDHH氏はSolidツール群の説明に移ります。

これまでモダンなWebアプリケーションではキューやキャッシュやジョブ管理にさまざまなデータベースが用いられていました。
しかし現代のデータベースは十分に高速になったことで、これらを1つのデータベースシステムにまとめることが可能になったとDHH氏。
Rails 8においては、ソケットによる通信のための「Solid Cable」、キャッシングのための「Solid Cache」、ジョブ管理のための「Solid Queue」はすべて1つのデータベースシステムで支えられるようになりました。
そしてそれをSQLite上に構築できるようになりました。
Rails 8ではプライマリデータベース、キャッシュ、キュー、ケーブルのすべてがSQLiteでまかなえるようになったとコンフィグレーションが示されました。それを実現するのがSolidツール群です。

Solidツール群の1つ目は「Solid Cable」です。

RailsにはWebSocketを用いてクライアントとサーバ間の通信をリアルタイムに行える仕組みがあります。これまでその通信メッセージをリレーするPubSubサーバとしてインメモリデータベースのRedisが必要でした。
Solid CableはSQLiteを用いてもRedis並の速度を実現できるというものです。

Solid Cacheは、これまでRedisやMemcachedなどのインメモリデータベースにHTMLフラグメントをキャッシュする仕組みを置き換えます。

Solid Cacheの導入により、このタイミングでWebサイトのリクエストに対するレイテンシが400ミリ秒から200ミリ秒になったことが示されました。

Solid Queueはジョブ管理のためのツールで、これまで必要だったRedisを不要にし、MySQL、PostgreSQL、SQLiteのメジャーなデータベース上で高速に動作します。

ThrusterとKamal 2
Thrusterは、デフォルトで導入される高速でセキュアな通信を実現するHTTP/2プロキシです。

参考:Railsを高速かつセキュアにするHTTP/2プロキシ「Thruster」、37signalsがオープンソースとして公開
Kamal 2はクラウドやコンテナやさまざまな環境にスケールアップでもスケールダウンでも指定して簡単にデプロイできるデプロイツールです。

DHH氏はこの基調講演と同時に、Rails 8のベータ版が公開されたことも発表し、さらにRails 8の次のRails 8.1の機能についても言及しています。
それについては別記事「Rails 8の次、Rails 8.1にはWebプッシュ通知、Elasticsearchを不要にするActive Record検索などを搭載するとDHH氏が説明」をご参照ください。