Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
20260228_JAWS_Beginner_Kansai
Search
Sponsored
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
Takuya Yonezawa
February 28, 2026
Programming
690
5
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
20260228_JAWS_Beginner_Kansai
Takuya Yonezawa
February 28, 2026
More Decks by Takuya Yonezawa
See All by Takuya Yonezawa
20260516_SecJAWS_Days
takuyay0ne
4
700
20260422_Midosuji_Tech
takuyay0ne
2
68
脱 雰囲気実装!AgentCoreを良い感じにWEBアプリケーションに組み込むために
takuyay0ne
3
540
20260204_Midosuji_Tech
takuyay0ne
1
230
20260129_CB_Kansai
takuyay0ne
1
360
20260126_JAWS_Osaka
takuyay0ne
1
60
こんな時代だからこそ! 想定しておきたいアクセスキー漏洩後のムーブ
takuyay0ne
4
800
セキュリティは全員参加!_JAWSのイベントサイトで脅威モデリングを学んでみよう!
takuyay0ne
0
200
20250920_ServerlessDays
takuyay0ne
9
4.3k
Other Decks in Programming
See All in Programming
net-httpのHTTP/2対応について
naruse
0
470
New "Type" system on PicoRuby
pocke
1
810
肥大化するレガシーコードに立ち向かうためのインターフェース分離と依存の逆転 / JJUG CCC 2026 Spring
hirokunimaeta
0
530
Lessons from Spec-Driven Development
simas
PRO
0
170
ローカルLLMを使ってB2Bサービスを作っていての学び
yaotti
0
160
The NotImplementedError Problem in Ruby
koic
1
700
キャリア迷子上等 ─ "ない道"は自分で作ればいい
16bitidol
3
1.9k
Signal Forms: Beyond the Basics @ngBaguette 2026 in Paris
manfredsteyer
PRO
0
240
AIとASP.NET Coreで雑Webアプリを作った話
mayuki
0
500
脅威をエンジニアリングの糧にして――現場編 / Turning Threats into Engineering Fuel — Field Edition
nrslib
0
270
気づいたらRubyで100作品 ー クリエイティブコーディングが生活の一部になるまで / 100 Ruby Sketches Later: How Creative Coding Became Part of My Life
chobishiba
3
560
Developing with AI Agents — Codex, Claude Code & Cowork Practical Guide
x5gtrn
PRO
0
1.2k
Featured
See All Featured
Pawsitive SEO: Lessons from My Dog (and Many Mistakes) on Thriving as a Consultant in the Age of AI
davidcarrasco
0
160
A designer walks into a library…
pauljervisheath
211
24k
Building a A Zero-Code AI SEO Workflow
portentint
PRO
0
570
How People are Using Generative and Agentic AI to Supercharge Their Products, Projects, Services and Value Streams Today
helenjbeal
1
210
Evolving SEO for Evolving Search Engines
ryanjones
0
210
Neural Spatial Audio Processing for Sound Field Analysis and Control
skoyamalab
0
330
Dominate Local Search Results - an insider guide to GBP, reviews, and Local SEO
greggifford
PRO
0
190
Organizational Design Perspectives: An Ontology of Organizational Design Elements
kimpetersen
PRO
1
720
JAMstack: Web Apps at Ludicrous Speed - All Things Open 2022
reverentgeek
1
470
Docker and Python
trallard
47
3.9k
Ecommerce SEO: The Keys for Success Now & Beyond - #SERPConf2024
aleyda
1
2k
We Are The Robots
honzajavorek
0
240
Transcript
1 © 2026 Japan Digital Design, Inc. Takuya Yonezawa 2026.02.28
苦しんで覚えるSSE × AgentCore 〜なぜアプリケーションがぬるぬる動くのか?〜 JAWS-UG初心者支部#77 関西 LT 大会
2 © 2026 Japan Digital Design, Inc. 米澤 拓也 Software
Engineer Technology & Development Div. and Corporate Culture室 プロフィール 前職ではCCoE、現職ではSoftware Engineer。 フロント/バックエンドの実装からインフラ構築など何でもやってます 証券系→銀行系 と 金融×IT なキャリアを歩んでいます 生息地:大阪 & 奈良 Community Builder (Serverless) 2023~ 資格は1冠です、優しくしてください。 takuya_y0ne
3 © 2026 Japan Digital Design, Inc. 0 はじめに
4 © 2026 Japan Digital Design, Inc. 3週間前にAgentCoreとStrandsに入門しました もう時代の流れに逆らいきれない
5 © 2026 Japan Digital Design, Inc. AI Agentを いい感じに動かすための
フルスタック基盤 AI Agentを超楽に実装するための AWS謹製フレームワーク 一言でAgentCoreとStrandsについて
6 © 2026 Japan Digital Design, Inc. つまるところ 「Strandsで作ったAI Agent
を AgentCore上で動かす」 のである ちなみに私は今月まで 「StrandsとAgentCoreって何が違うねん?」という状態でした 笑
7 © 2026 Japan Digital Design, Inc. 1 とりあえずこれを見てくれ
9 © 2026 Japan Digital Design, Inc. 公開用スクショ
10 © 2026 Japan Digital Design, Inc. 今見せたのは米澤がAgentCore×Strandsで “人力”作成した検証用アプリ (私自身がKiroになればいいのである。0円,
0クレジット) ぬるぬる動いてましたよね?
11 © 2026 Japan Digital Design, Inc. 2 ぬるぬるの正体
12 © 2026 Japan Digital Design, Inc. Server Sent Eventは
技術としては昔からあるもの Server Sent Event (SSE) 2004年に初めて仕様化 ※1 ※2 サーバからクライアントに逐次的に データを送信するための仕組み HTTPベースで実現される サーバ→クライアントの単方向通信 ▪ なんで今さら? LLMの回答生成には時間がかかる。 回答生成が完了してから一発で レスポンスを返すような従来方式だと、 UX的に微妙なので再注目されている。 ※1 https://html.spec.whatwg.org/multipage/server-sent-events.html Client Server https://developer.mozilla.org/ja/docs/ Web/API/Server-sent_events/Using_server-sent_events ※2 HTTPで接続 データ データ データ HTTP接続終了 ・・・
13 © 2026 Japan Digital Design, Inc. WebSocketは? クライアント側のポーリングは? 玄人の方向け
WebSocketやクライアント側の ポーリングだと、 - 双方向のハンドシェイク - クライアント側の処理負荷増大 などをケアして上げる必要があり、 アプリケーションが複雑になる WebSocketに対応していない プラットフォームもある その点 Server Sent Eventは単方向の HTTPベースなのでトータルすっきりする (らしい) Client Server データ取得 データ取得 データ取得 ・・・ Client Server WebSocketコネクション確立 データ送受信 WebSocket Client Polling
14 © 2026 Japan Digital Design, Inc. Server Sent Eventの中身
https://developer.mozilla.org/ja/docs/Web/API/Server-sent_events/Using_server-sent_events
15 © 2026 Japan Digital Design, Inc. Server Sent Eventの中身
https://developer.mozilla.org/ja/docs/Web/API/Server-sent_events/Using_server-sent_events AgentCoreで特に意識しないといけないのは この”data”という項目
16 © 2026 Japan Digital Design, Inc. 実際に Strands on
AgentCore が 返してくるSSEデータの中身を眺めてみる
17 © 2026 Japan Digital Design, Inc. AWSドキュメント内のサンプルコード から一部修正したもの
18 © 2026 Japan Digital Design, Inc. わあ。。。
19 © 2026 Japan Digital Design, Inc. すこし整理してみる
20 © 2026 Japan Digital Design, Inc. この細切れのデータを組み立てると 「こんにちは!今日はお手伝いできることはありますか」 になる(=Strandsの応答)
キー名が”event”のデータのみ抽出 Agent実行で消費されたトークン数 キー名が”event”のデータのみ抽出
21 © 2026 Japan Digital Design, Inc. キー名が”event”のテキストを組み合わせれば アプリケーション上でいい感じに表示できそう
22 © 2026 Japan Digital Design, Inc. 3 が、この細切れのデータを組み立てるのが大変。。
23 © 2026 Japan Digital Design, Inc. そもそも event: messageStartとか
event: contentBlockDeltaとか って何?
24 © 2026 Japan Digital Design, Inc. https://docs.aws.amazon.com/ja_jp/bedrock/latest/userguide/ conversation-inference-call.html#conversation-inference-call-response 実態はBedrockのConverseStream
25 © 2026 Japan Digital Design, Inc. messageStart contentBlockStart contentBlockDelta
contentBlockStop messageStop metadata ▪ メッセージ開始イベント アプリケーション上は無視してOK ▪ ツール利用時に出力される どのツールを利用するか?等が出力される ▪ 回答生成時/ツール利用時に出力される モデルの回答やツールへのインプットなどが出力される ▪ 回答生成時/ツール利用時に出力される モデルの回答停止やツール利用時の停止イベント ▪ メッセージの停止イベント 各ブロック毎にモデルの回答生成が完了したら出力される ▪ モデル回答が完了する際に出力される トークン利用量やレイテンシーが出力される
26 © 2026 Japan Digital Design, Inc. 参考:Tool利用も含めた際のペイロード
27 © 2026 Japan Digital Design, Inc. フロント側で、前述のように流れてくるデータを イベントタイプに合わせてハンドリングする必要がある
28 © 2026 Japan Digital Design, Inc. targetText という変数の中に「を使用」が格納される
29 © 2026 Japan Digital Design, Inc. サンプルのReact側コード。辛い。。
30 © 2026 Japan Digital Design, Inc. 検証している時の私の叫び
31 © 2026 Japan Digital Design, Inc. 4 まとめ
32 © 2026 Japan Digital Design, Inc. AgentCoreのストリーミングレスポンスの特性上、 どんなイベントデータがフロント側に届くかが分からない 本来バックエンド側で担わないといけないデータ整形処理を
フロント側に押し付ける形になる (本来フロント側にロジックを多く持たせるべきではない)
33 © 2026 Japan Digital Design, Inc. ぬるぬるした画面表示、本当に必要ですか? ローディング画面→一括表示 で代替できるなら
そちらのほうが遥かにシンプルにできる
34 © 2026 Japan Digital Design, Inc. x おまけ ~
今回組んだシステム構成 & Demo ~
35 © 2026 Japan Digital Design, Inc. お試しで作ってたらエライことになった。。
36 © 2026 Japan Digital Design, Inc. Strandsの中の構成。米澤の興味領域とも言える Master Agent
WEB検索Agent (MCP) What’s New 検索Agent AWS環境 調査Agent 不動産情報 取得Agent フロント実装Tips 取得Agent Knowledge Bases Knowledge Bases StrandsTools RSS tavily
37 © 2026 Japan Digital Design, Inc. - なんでHonoとかFastAPI使ってるの? -
なんでAPI-GW分けてるの? - Lambdaの中で何しているの? - KnowledgeBaseの精度向上Tips? - Bedrockモデルの選定は? などもネタとしては有るのですが、 明らかに今回は場違いなレベルになるのでまたの機会に
Thank you. 38 © 2026 Japan Digital Design, Inc.