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
Server-sent eventsを使ってみた / I tried using Server...
Search
Sponsored
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
Endo_Hizumi
September 04, 2019
Technology
1.3k
1
Share
Server-sent eventsを使ってみた / I tried using Server-sent event
Endo_Hizumi
September 04, 2019
More Decks by Endo_Hizumi
See All by Endo_Hizumi
欲しいを叶える個人開発の進め方 / How to Run an Indie Project That Brings Your Ideas to Life
endohizumi
0
860
JSでギャルゲー!~JavaScriptでノベルゲーエンジン作ったった~
endohizumi
1
410
意志の力が9割。アニメから学ぶAI時代のこれから。
endohizumi
1
170
JSでギャルゲーをつくろう!(第3版)
endohizumi
0
250
JSでギャルゲーをつくろう!(第2版)
endohizumi
0
94
JSでギャルゲーをつくろう!
endohizumi
0
480
テレビを飲み込め! Webの嵐!! / Swallow the TV! Web storm! !!
endohizumi
1
130
OK:Googleから始めるスマートホーム生活 / OK: Smart home life starting from Google
endohizumi
0
360
クソアプリで基礎固め / Tutorial in your joke app for Vue.js
endohizumi
0
260
Other Decks in Technology
See All in Technology
React、まだ楽しくて草
uhyo
7
2.2k
探して_入れて_作って_使う_Agent_Skills___LT.pdf
peintangos
2
110
電子辞書Brainをネットに繋げてみた(自力編)
raspython3
0
380
大規模災害時でも高い信頼性を維持するアプリケーション基盤の実現/nikkei-tech-talk46
nikkei_engineer_recruiting
0
120
『家族アルバム みてね』における インシデント対応との向き合い方 / Approach incident response in Family Album
kohbis
2
280
Claude Codeですべての日常業務を爆速化しよう!
minorun365
PRO
17
16k
JEP 522 Deep Dive - G1 GC同期コスト削減によるスループット向上を徹底検証&解説
tabatad
1
480
AIプラットフォームを運用し続けるための可観測性
tanimuyk
4
770
GoとSIMDとWasmの今。
askua
1
170
基礎から解説!Icebergで紐解くSnowflake×Databricks連携の現在地
cm_yasuhara
0
410
TypeScript Compiler APIとPHP-Parserを活用し、TypeScriptとPHPで型を共有する
shuta13
0
270
Terraformモジュールは、なぜ「魔境」化するのか
hayama17
1
130
Featured
See All Featured
The Myth of the Modular Monolith - Day 2 Keynote - Rails World 2024
eileencodes
28
3.5k
Facilitating Awesome Meetings
lara
57
6.9k
Raft: Consensus for Rubyists
vanstee
141
7.5k
HU Berlin: Industrial-Strength Natural Language Processing with spaCy and Prodigy
inesmontani
PRO
0
390
Collaborative Software Design: How to facilitate domain modelling decisions
baasie
1
230
Navigating the moral maze — ethical principles for Al-driven product design
skipperchong
2
370
Practical Orchestrator
shlominoach
191
11k
Navigating Team Friction
lara
192
16k
RailsConf & Balkan Ruby 2019: The Past, Present, and Future of Rails at GitHub
eileencodes
141
35k
Color Theory Basics | Prateek | Gurzu
gurzu
0
320
How to audit for AI Accessibility on your Front & Back End
davetheseo
0
390
職位にかかわらず全員がリーダーシップを発揮するチーム作り / Building a team where everyone can demonstrate leadership regardless of position
madoxten
62
54k
Transcript
Server-sent eventsを 使ってみた 2019年9月4日(水)残暑に負けるな!自由研究 LT大会 遠藤ヒズミ 1
2 こんばんは、遠藤ヒズミと言います。
3 都内で、SESのWebエンジニアしてます
4 今日は、紹介も兼ねて Server-sent eventsを使った 感想を話します。
5 なぜ、Server-sent eventsなの? GameClient GameServer Jinro JinroResponcer.php Broadcast.php member activity_logs
triggerで 書き込む 発言・投票などの行動 書き込み レコード 取得 JSONで送信 5 今、開発している人狼のWebアプリの仕組みがこうなって います。
6 なぜ、Server-sent eventsなの? GameClient GameServer Jinro JinroResponcer.php broadcast.php member activity_logs
triggerで 書き込む 発言・投票などの行動 書き込み レコード 取得 JSONで送信 6 プレイヤーの行動をサーバーに送るには、何も考えず に、HTTPリクエストを送れば良い。
7 なぜ、Server-sent eventsなの? GameClient GameServer Jinro JinroResponcer.php Broadcast.php member activity_logs
triggerで 書き込む 発言・投票などの行動 書き込み レコード 取得 JSONで送信 7 では、サーバーに届いたプレイヤーの行動を どうやって、他のプレイヤーに伝えたらよいのか?
なぜ、Server-sent eventsなの? サーバーから情報を取得する方法 • ポーリング • comet • WebSocket •
Server-sent events 8
なぜ、Server-sent eventsなの? ポーリング・Comet →あるかわからない情報のために、周期的にリクエスト送るのは、面倒・ ムダが多い・しんどい →できれば、能動的にサーバーから送ってほしい 9
なぜ、Server-sent eventsなの? 選ばれたのは、綾鷹Server-sent eventsでした。 • 従来の延長でとっつきやすい・理解しやすい • サーバー・クライアント共に容易に実装できる • 切断時に再接続を行ってくれる
• HTTP通信なので、HTTPレスポンスコードで制御できる • 独自にイベントを定義できる。 10
なぜ、Server-sent eventsなの? 選ばれたのは、綾鷹Server-sent eventsでした。 • 従来の延長でとっつきやすい・理解しやすい • サーバー・クライアント共に容易に実装できる • 切断時に再接続を行ってくれる
• HTTP通信なので、HTTPレスポンスコードで制御できる • 独自にイベントを定義できる。 → 簡単でとっつきやすかった 11
なぜ、Server-sent eventsなの? 選ばれたのは、綾鷹Server-sent eventsでした。 → 送信側はAjaxで実装済みなので、WebSocketで再実装はやる気が 起きなかった(一番の理由) 別に独自プロトコルにひよったわけじゃねーし 12
Server-sent eventsとは クライアントからのリクエスト無しに、サーバーからデータを送信できる HTML5のAPIの1つです。 13
Server-sent eventsとは クライアントと張ったコネクションにchunkedデータを送信することで、コ ネクションを終了させずに、サーバーを始点としたデータを送信を実現し ています。 Client Http Server 接続要求 14
Server-sent eventsとは クライアントと張ったコネクションにchunkedデータを送信することで、コ ネクションを終了させずに、サーバーを始点としたデータを送信を実現し ています。 Client Http Server chunked 15
Server-sent eventsとは クライアントと張ったコネクションにchunkedデータを送信することで、コ ネクションを終了させずに、サーバーを始点としたデータを送信を実現し ています。 Client Http Server chunked chunked
16
Server-sent eventsとは クライアントと張ったコネクションにchunkedデータを送信することで、コ ネクションを終了させずに、サーバーを始点としたデータを送信を実現し ています。 Client Http Server chunked chunked
chunked 17
Server-sent eventsとは クライアントと張ったコネクションにchunkedデータを送信することで、コ ネクションを終了させずに、サーバーを始点としたデータを送信を実現し ています。 Client Http Server chunked chunked
chunked chunked 18
従来技術と比較 19 リクエストの 有無 レスポンスの 種類 送信後の コネクション 返答 タイミング
ポーリング 毎回必要 通常のHTTP レスポンス 終了 可及的速や かに comet (ロング ポーリング) 毎回必要 通常のHTTP レスポンス 終了 更新まで 保留可 Server-sent events 初回のみ chunked 継続 更新まで 保留可
利用局面と活用事例 利用局面 • チャットアプリで、メッセージの送信 • センサーデータをリアルタイム表示するWebアプリ • 並列でのWebAPIの呼び出し • その他、非同期でサーバーからデータを受信する処理
活用事例 • GREEチャット(2014年6月時点) • 某電気通信事業者のトイレの空室確認システム 20
21 容易に実装できる
22 どれだけ簡単なのかというと・・・
EventSourceコンストラクタの引数に通信先を渡す 23
onmessageのコールバックに受信後の処理を書く 24
ヘッダーにContent-Type: text/event-streamを記述 25
あとは、送信したい内容を書けばおk 26
27 簡単でしょ?
注意! データの末行を空行(\n)で区切らないと送信されない。 このことに気がつくまでが、2日くらいかかって、しんどかった。 あと、Internet ExplorerとEdgeでは、ひと手間かける必要がある。 28
まとめ • Server-Sent eventsは、コネクションを張りっぱなしにして、サー バーから能動的にデータを送れる技術 • 数行のコードでサーバー・クライアント共に容易に実装できる • センサーデータのリアルタイム表示など、テキストでの非同期での データ受け取りが得意
29
まとめ • Server-Sent eventsは、コネクションを張りっぱなしにして、サー バーから能動的にデータを送れる技術 • 数行のコードでサーバー・クライアント共に容易に実装できる • センサーデータのリアルタイム表示など、テキストでの非同期での データ受け取りが得意
30 終わり!聞いてくれてありがとう!