Durable Objectsを使いこなす!vibesdkに学ぶグローバルな状態管理とリアルタイムブロードキャスト


Durable Objectsを使いこなす!vibesdkに学ぶグローバルな状態管理とリアルタイムブロードキャスト

cloudflare/vibesdk

2025-12-09

ルーク
「父上、あれは何ですか?vibesdk?何か、フォースと関係があるんですか?」

ベイダー「フフフ... ルークよ、それはフォースよりも強力な、コーディングの力を増幅させるツールだ。フォースと違い、我々ソフトウェアエンジニアに具体的な利益(メリット)をもたらす。」

集中力の向上(Vibe-Coding)

開発者は、集中を深めるために環境音やBGMを流しながら作業することがある。このSDKを使えば、その「Vibe(雰囲気)」をコードと共にライブで共有できるプラットフォームを簡単に構築できる。

自分の集中状態や作業環境を公開することで、モチベーション維持にも繋がる。

フルスタック開発の簡素化

Cloudflare Workers(サーバーレスなバックエンド)とDurable Objects(グローバルな状態管理)という、Cloudflareの強力なスタックに完全に依存して作られている。

これにより、複雑なインフラのセットアップやリアルタイム同期の処理を気にすることなく、「Vibe-Coding」というユニークな機能に集中して開発を進めることができる。スケーラビリティもCloudflareに任せられる。

特にリアルタイムでのVibe(BGMやステータス)の同期が、Durable Objectsによって非常にシンプルに実現できるのが魅力だ。

ルーク
「なるほど... 集中するための音を、リアルタイムでみんなと共有するライブ配信プラットフォームの骨格を、Cloudflareの力で簡単に作れるということですね!フォースの代わりに、サーバーレスの力を使うわけだ。」

ベイダー「その通り、ルーク。次に、その強力な武器を手に入れる(導入する)方法を教えよう。」

ベイダー
「このSDKの導入は、反乱軍を討つよりも簡単だ。必要なのはCloudflareアカウントと、ターミナルの操作スキルだけだ。」

まず、Cloudflare WorkersのCLIツールであるwranglerがインストールされていることを確認する。

# プロジェクトをクローン
$ git clone https://github.com/cloudflare/vibesdk
$ cd vibesdk

# 依存関係をインストール
$ npm install

wrangler.toml ファイルで、Durable Objectのバインディング(接続設定)を行う必要がある。

wrangler.toml内で、例えば以下のような設定を行う。

# Durable Objectsの設定
[[durable_objects]]
binding = "VIBE_HUB" # スクリプトからアクセスするための名前
class_name = "VibeHub" # Durable Objectクラスの名前
script_name = "vibesdk-worker" # ワーカースクリプトの名前

ルーク
「Durable Objects... それが、ユーザーのVibe(状態)を一箇所で管理し、全員にリアルタイムで同期させるコアなんですね。まるで、銀河の支配権を握る中央のデス・スターだ!」

ベイダー「まさに。次に、そのデス・スターを起動(デプロイ)させるのだ。」

設定が完了したら、wrangler コマンドを使ってCloudflareにデプロイする。

# Cloudflareへデプロイ
$ wrangler deploy

ベイダー
「これで、君のVibe-Codingプラットフォームが、世界中のユーザーにエッジでサービス提供されるようになる。この速さ... 反乱軍に勝ち目はない。」

ルーク「父上、デプロイは分かりましたが、具体的にコードでどうやってVibe(雰囲気)を操作するのですか?」

ベイダー
「見よ、これがVibeを制御するコアの力だ。」

このSDKの核となるのが、Durable Object であるVibeHubだ。

// vibesdk/src/vibe-hub.ts (簡略化)
import { Vibe, VibeWorker } from 'vibesdk/server';
import { VibeSDKEnv } from './worker';

// VibeHub は Durable Object としてユーザーの状態を保持
export class VibeHub extends VibeWorker<VibeSDKEnv> {
  // ユーザーの現在のVibe(BGMのURL、ステータスなど)
  currentVibe: Vibe = {
    // 例: BGMのURL、状態、テキストなど
    audioUrl: '',
    statusText: 'Coding...',
    lastUpdated: Date.now(),
  };

  constructor(state: DurableObjectState, env: VibeSDKEnv) {
    super(state, env);
  }

  // クライアントからの新しいVibeリクエストを受け取る
  // 'update' メソッドはクライアントからWebSocketで呼び出される
  async update(newVibe: Partial<Vibe>): Promise<void> {
    // 状態を更新
    this.currentVibe = { ...this.currentVibe, ...newVibe, lastUpdated: Date.now() };

    // この Durable Object に接続している全てのクライアント (WebSocket) に新しいVibeをブロードキャストする
    // これがリアルタイム同期を実現する肝!
    this.broadcast(this.currentVibe);
  }
}

状態管理
VibeHubクラスが一意なユーザー(またはセッション)の状態(currentVibe)を永続的に保持します。

リアルタイム同期
this.broadcast(this.currentVibe)によって、そのDurable Objectに接続している全てのWebSocketクライアントに対し、最新の状態が瞬時に送られます。これにより、「AさんがBGMを変えたら、Cさんの画面にも即座に反映される」というリアルタイム性の高い共有機能が、ごく少ないコードで実現します。

ルーク「素晴らしい!Durable Objectが、状態を保持し、WebSocketを使ってブロードキャストすることで、銀河の隅々まで情報を届けられる。これがvibesdkの正体... Vibe-Codingプラットフォームの設計図なんですね!」

ベイダー
「そう、ルーク。君もこの力を使い、我々のコーディング帝国を築くのだ。フォースとサーバーレスと共に...」

このSDKは、Cloudflareの強力なエッジコンピューティング能力とDurable Objectsのグローバルな状態管理機能を、リアルタイムな「共有環境プラットフォーム」の構築に応用した、非常にモダンで実践的な例となっています。

このコント形式の解説で、cloudflare/vibesdk の概要と、それがソフトウェアエンジニアにもたらすメリット、そして基本的な仕組みがお分かりいただけたでしょうか?


cloudflare/vibesdk




【入門】onyx-dot-app/onyxで始めるAIチャットボット開発

ソフトウェアエンジニアの視点から、onyx-dot-app/onyxがどのように役立つか、導入方法、サンプルコードについて、真面目に、分かりやすく説明するね。onyx-dot-app/onyxは、AIを活用したチャットアプリケーションを構築するためのオープンソースプラットフォームなんだ。これを導入するメリットは、主に次の3つだよ。


ソフトウェアエンジニア必見!Koogで効率的なAI開発

この番組は、クイズに答えながら新しい技術を楽しく学んでいくクイズ番組。 司会の私(AIの知識はちょっとだけ…)と、解説員のKoogさんが、皆さんの疑問をコント形式で解決していきますよ!司会今日のテーマ、Koogさん!いったい何ができる方なんですか?


AI-For-Beginnersで学ぶ、エンジニアのキャリアアップ

「microsoft/AI-For-Beginners」は、Microsoftが提供しているAI学習のための無料カリキュラムです。全24レッスン、12週間の構成で、初学者でも無理なくAIの基礎を学べるように設計されています。ソフトウェアエンジニアとしてAIを学ぶことは、以下のような多くのメリットがあります。


コードの隙間を見逃さない。DeepAuditが変える、AI駆動の自律型セキュリティ運用

本日おすすめするのは、「DeepAudit」という名の、非常にキレのあるカクテル…いえ、セキュリティ監査ツールです。ソフトウェアエンジニアであるあなたにとって、これは「ただの静的解析ツール」ではありません。いわば、24時間眠らずにあなたのコードの隙間を探し続ける、熟練のホワイトハッカー・チームを雇うようなものです。


【爆速開発】LiveKit Agentsで作る、アサヒ級にキレのあるリアルタイムAIエージェント

「AIとリアルタイムで会話する」という体験を、日本の4大ビールメーカーのブランドイメージになぞらえて、その魅力と実装方法を紐解いていきましょう!LiveKit Agentsを一言で言うと、「超低遅延で動くAIエージェントを爆速で開発できるフレームワーク」です。


ソフトウェアエンジニア必見!MindsDBでAIとデータの壁をぶち破れ!

エンジニアの皆さん、お待たせしました!あなたの開発運を爆上げするMindsDBを、血液型別のエンジニアタイプに合わせてご紹介します。さあ、あなたの血液型は?A型エンジニアの特性 計画的で真面目、そして細部までこだわる完璧主義者。MindsDBはA型エンジニアにどう役立つ?


論理的な情報検索を実現:PageIndexによる次世代RAGシステムの構築

PageIndexは、従来のVector-Based RAG (Retrieval-Augmented Generation)とは一線を画す、新しい推論ベースのRAGフレームワークです。従来のRAGでは、ドキュメントを一定のサイズでチャンク(断片)に区切り、それをベクトル化(埋め込み)してデータベースに保存し、質問のベクトルと類似度の高いチャンクを検索していました。


【頑固親父が直伝】「antvis/Infographic」で退屈なデータを極上の一皿へ。AI時代のビジュアライゼーション戦略

今日は「antvis/Infographic」の話だな? 「言葉に命を吹き込む」なんて、まるで俺が麺に魂を込めるのと同じじゃねえか。エンジニアの視点から、この「特製インフォグラフィック・フレームワーク」をガツンと解説してやるよ。いいか、客は「ただの数字」を見せられても食欲は湧かねえ。 データ(材料)をどう盛り付けるか、それがインフォグラフィックの真髄だ。


北斗神拳伝承者、仲間とともにシステムを創る 〜flydelabs/flydeがもたらす新たな時代の奥義〜

想像してみてくれ。北斗の拳の世界で、ケンシロウがたった一人で強敵を倒してきたように、ソフトウェアの世界でも、あんたたちは一人、あるいは少数の仲間で、巨大なシステムという敵と戦ってきたはずだ。だが、その戦いは常に孤独だった。そこに現れたのが、「flydelabs/flyde」、こいつだ。この力は、例えるなら、北斗神拳伝承者がただ一人ではない、新たな時代の救世主を生み出すための奥義書のようなもの。


プログラミング初心者向け:AIによる動画生成ツールの導入と仕組み

ソフトウェアエンジニアの視点から、harry0703/MoneyPrinterTurboというツールがどんなに便利で、プログラミングを学ぶ上でどのように役に立つか、そして導入方法を分かりやすく解説しますね。このプロジェクトは、AI(人工知能)を使って、テキストからワンクリックで簡単に、しかも高画質な短い動画(ショートビデオ)を自動で作ってくれる優れものです。キーワードはPython、Automation(自動化)、AIです。