従来のサーバレスよりさらに高効率で高速な「Fluid Compute」、Vercelが提供開始
Next.jsなどの開発で知られるVercelは、従来のサーバレスの利点を備えつつ、さらに高効率で高速な「Fluid Compute」の提供を開始したと発表しました。
Fluid: fast, cost-efficient compute.
— Vercel (@vercel) February 4, 2025
What you love about servers—combined with the best parts of serverless.https://t.co/GF2BZ5d3Gy
サーバレスにはまだ非効率なところがあるとVercel
サーバレスコンピューティングは一般に、あらかじめ登録されていた関数のコードを、何らかのイベントをきっかけにしてコンテナとして起動し、コードの実行が終了すればコンテナごと終了するという仕組みです。
これにより、イベントが何も発生していないときにはコンテナの実行はゼロとなり、大量のイベントが発生した場合にはそれに応じて大量のコンテナが実行されて処理をさばくことにより、効率的かつスケーラブルなコンピューティングリソースの消費を実現できることになります。
このように従来のサーバレスでは、イベントによりコンテナが起動し、そこで関数のコードが実行されることになります。

しかしVercelはこの従来のサーバレスの仕組みには、まだ非効率な点があるとしています。
具体的には、イベントによって起動したコンテナが例えばデータベースのクエリを行って結果を待っているときのアイドルタイムなど、コンテナ実行中のアイドルタイムの間は、コンピューティングリソースは無駄に待っていることになるとしました。
1つのインスタンスで複数の関数コードを実行
そこでFluid Computeでは、1つのコンテナのインスタンスにおいて複数の関数のコードを実行できるようにしています。

同社はこれを「In-function concurrency」と呼んで、次のように説明しています。
In-function concurrency enables a single Vercel Function to handle multiple invocations simultaneously, optimizing resource usage and turning efficiency gains into savings.
In-function concurrency(関数内並行処理)により、1つのVercel関数で複数の呼び出しを同時に処理できるため、リソースの使用が最適化され、効率化によるコンピューティングリソースの節約となります。
複数のリクエストを1つの同じインスタンスで処理することで、コールドスタートが減り、アイドルタイムの削減にもつながります。
これ以外にも、Fluid Computeでは関数コードを事前にコンパイルすることで起動をさらに高速化するバイトコードキャッシング、インスタンスプールなどの高速化の仕組みが備わっています。
Fluid ComputeはVercelが提供するサーバレスの仕組みである「Vercel Functions」で提供が開始されており、既存のコードを変更することなく利用可能とされています。
あわせて読みたい
VSCodeでコードを修正すると、次に修正すべきコードの場所を提案してくれる「Copilot Next Edit Suggetions」プレビュー公開
≪前の記事
Dockerfileの最適化やエラーの原因などの質問に答える「Docker AI Agent」ベータ公開、Docker Desktopで利用可能に