静的サイトジェネレータのAstro、「Server Islands」を実験的実装。サーバで動的生成したコンポーネントをWebページ表示後に組み込み

今回は「静的サイトジェネレータのAstro、「Server Islands」を実験的実装。サーバで動的生成したコンポーネントをWebページ表示後に組み込み」についてご紹介します。

関連ワード (動的、環境、開発等) についても参考にしながら、ぜひ本記事について議論していってくださいね。

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


オープンソースで開発されている静的サイトジェネレータ「Astro」は、新機能の「Server Islands」を実験的実装した新バージョン「Astro 4.12」をリリースしました。

Full details on the blog:https://t.co/jd8GfFwbjB

— Astro (@astrodotbuild) July 18, 2024

Astroは、ReactやVue、Svelte、Alpine.js、TypeScriptなどのさまざまなフレームワークやライブラリに対応した静的サイトジェネレータです。

ビルド時にWebサイト全体のHTMLが生成され、しかもそのHTMLには全くJavaScriptが含まれないか、もしくはWebブラウザ上での動作に必要な最小限のJavaScriptのみが残されます。

JavaScriptによる動的な仕組みが必要なコンポーネントについては、Webブラウザ上に静的HTMLが表示された後など、開発者がHTML上のボタンなどのコンポーネントに対して任意のタイミングを選んで組み込むことができるようになっています。

そのため、非常に高速に表示できるWebサイトの生成を可能にしている点が、Astroの大きな特徴です。

AstroのIslandsはあとからJavaScriptを組み込み

この、あとからHTMLのコンポーネントに対してJavaScriptで動的な機能を組み込める仕組みは2021年からAstroに「Islands」という名前で組み込まれていました。

今回、Astro 4.12で実験的実装が行われた「Server Islands」は、ユーザーごとにパーソナライズされる情報など、サーバ側で動的に生成されるコンポーネントを、「Islands」と同様にWebページ上にあとから組み込むことで、高速なWebページの表示を維持したまま、より動的なWebサイトの構築を実現するための仕組みです。

一般に、ユーザーごとにパーソナライズされたWebページなど、サーバによる動的生成を必要とするWebページは、Webページ全体が動的生成され、それがWebブラウザへ送信されます。そのため、Webブラウザからのリクエストがサーバに届いてから、サーバがHTMLを動的に生成する時間が必要な分、HTMLがWebブラウザに送信開始されるまでに時間がかかります。

また、ユーザーごとに異なるHTMLが生成されるため、CDNなどのキャッシュもしにくくなります。

Server Islandsは先に静的HTMLを配信、あとから動的要素に置き換え

これに対してServer Islandsでは、Webブラウザからのリクエストに対して、まずすべてのユーザーに静的生成されたHTMLが返され、高速にWebページが表示されます。パーソナライズが必要なコンポーネントの部分にはプレイスホルダーが埋め込まれています。

fig

全ユーザーに同じHTMLが配信されるため、CDNなどによりシンプルなキャッシュが有効です。

その上で、あとからパーソナライズが必要なコンポーネントの部分に対して、サーバで生成されたコンポーネントが個別に置き換えられます。個別に配信されるため、サーバの動的生成に時間のかかるコンポーネントがあったとしても、全体のボトルネックになることはありません。

Astroの開発チームは、このServer Islandsを用いたデモサイト「server-islands.com」を公開し、同様のコンセプトであるNext.jsの「Next.js Partial Prerendering」よりも高速であると説明しています。

また、Astroの開発チームによるとServer islandsは移植性を念頭に置いて構築されておりサーバーインフラに依存せず、Node.jsから各種クラウドのサーバレスなどさまざまなホスト環境で実行可能だとしています。

COMMENTS


Recommended

TITLE
CATEGORY
DATE
クラウド契約サービス「クラウドサイン」、リコーのクラウドアプリケーションと連携
IT関連
2022-04-24 16:12
EA、サイバー攻撃で「FIFA 21」やゲームエンジンのソースコード780GBを盗まれる
セキュリティ
2021-06-12 10:57
ゲームで遊びながら算数や読解を学ぶEdTechプラットフォームSplashLearnが18.8億円調達
EdTech
2021-02-11 01:31
ソニーがフルサイズミラーレス一眼αを搭載するドローン「AirPeak」発表
ドローン
2021-01-13 19:41
Facebook、アカデミー初受賞 「Medal of Honor: Above and Beyond」内短編「Colette」で
アプリ・Web
2021-04-27 15:17
東芝データ、「スマートレシート」を東芝の社員食堂へ導入
IT関連
2021-01-19 04:23
SpaceXが「最も宇宙にいると感じられる」展望ドームをDragon宇宙船の先端に設置すると発表
宇宙
2021-04-01 19:32
WebブラウザのBrave、独自検索エンジン「Brave Search」構築に向けてTailcat買収
アプリ・Web
2021-03-05 22:53
複数のアップル製デバイスをシームレスに移動しながら作業できる「ユニバーサルコントロール」機能
ソフトウェア
2021-06-09 18:42
CTCと埼玉県横瀬町、「Fitbit」を活用した実証実験–健康意識の向上へ
IT関連
2023-02-23 05:25
GAFAの一角など売上高が急増–ネット広告への本格移行のための情報ソースとは?
IT関連
2021-08-23 10:44
「バーチャファイター」、eスポーツになって再始動 セガ、27日に正式発表
くらテク
2021-05-22 11:24
DataRobotとSBIホールディングス、生成AIで提携拡大–商品照会、文書要約などで活用
IT関連
2023-11-10 04:44
AWS Backupの新機能、Amazon RDSのデータベースを任意の時点に戻せる「継続的バックアップ」と「Point-in-timeリカバリ」が登場
AWS
2021-03-12 07:15