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
TV連動サービスのリアルタイム通知を支える技術
Search
Tsuyoshi Torii
February 26, 2023
Technology
130
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
TV連動サービスのリアルタイム通知を支える技術
Tsuyoshi Torii
February 26, 2023
More Decks by Tsuyoshi Torii
See All by Tsuyoshi Torii
Claude Cowork全社展開のために、MCPゲートウェイを自作した話
toritori0318
2
110
作られては消えていく泡のように儚いクラスタの運用話
toritori0318
0
140
Shinken Monitoringについて真剣に調べてみた結果
toritori0318
0
360
Chef SoloからItamaeに完全移行した話+
toritori0318
0
140
Docker3兄弟
toritori0318
2
7.2k
TV視聴参加型システムを支えるSocket.IOクラスタの裏側
toritori0318
12
3.9k
Other Decks in Technology
See All in Technology
【FinOps】データドリブンな意思決定を目指して
z63d
0
350
自分が詳しくない領域でAIを使う #プロヒス2026
konifar
20
7.5k
Microsoft のサポートとフィードバック総まとめ
murachiakira
PRO
0
110
2026 AI Memory Architecture
nagatsu
0
270
アラート調査向けAIエージェントの本番導入とその後/AI Agents for Alert Investigation: Production Deployment and After
taddy_919
0
140
FPC(フレキシブル)基板にZephyr実装してみた。
iotengineer22
0
170
不要なレビューをAIにまかせて AIコーディングの環境改善を加速した
shoota
1
270
【セミナー資料】Claude Code をセキュアに使うための考え方と設定の勘どころ / Claude Code Webinar 20260616
masahirokawahara
2
470
AI-DLCを “そのまま導入しなかった”話 ~組織に合わせてアジャストした 私たちの実践共有~
hiroramos4
PRO
1
430
AIはどのように 組織のアジリティを変えるのか?
junki
4
1.4k
事業会社における 機械学習・推薦システム技術の活用事例と必要な能力 / ml-recsys-in-layerx-wantedly-2026
yuya4
0
160
BPaaSで進むAIオペレーションの現在地 AI実装が効く領域とスケーラビリティの選定と実装
kentarofujii
0
190
Featured
See All Featured
Tell your own story through comics
letsgokoyo
1
970
Chasing Engaging Ingredients in Design
codingconduct
0
230
The Pragmatic Product Professional
lauravandoore
37
7.3k
Navigating the Design Leadership Dip - Product Design Week Design Leaders+ Conference 2024
apolaine
1
360
コードの90%をAIが書く世界で何が待っているのか / What awaits us in a world where 90% of the code is written by AI
rkaga
62
44k
Easily Structure & Communicate Ideas using Wireframe
afnizarnur
194
17k
Thoughts on Productivity
jonyablonski
76
5.2k
SEO in 2025: How to Prepare for the Future of Search
ipullrank
3
3.5k
WENDY [Excerpt]
tessaabrams
11
38k
[RailsConf 2023] Rails as a piece of cake
palkan
59
6.7k
The Art of Programming - Codeland 2020
erikaheidi
57
14k
Intergalactic Javascript Robots from Outer Space
tanoku
273
27k
Transcript
TV連動サービスの リアルタイム通知を支える技術 2014/01/14 テレビ連動サーバ勉強会vol1 Tsuyoshi Torii (@toritori0318) Bascule Inc.
自己紹介 • 鳥居 剛司 @toritori0318 • 株式会社バスキュール • TV連動プラットフォームサーバ開発/運用 •
Lua / Python / Golang / Node.js / Perl / Ruby • 二児の父
アジェンダ • MIESについて • Sonicshooter基本機能/事例紹介 • Sonicshooter詳細構成/特徴 • お試し構成デモ •
まとめ
アジェンダ • MIESについて • Sonicshooter基本機能/事例紹介 • Sonicshooter詳細構成/特徴 • お試し構成デモ •
まとめ
MIES
MIES
アジェンダ • MIESのご紹介 • Sonicshooter基本機能/事例紹介 • Sonicshooter詳細構成/特徴 • お試し構成デモ •
まとめ
SonicShooter機能 • ユーザ管理/認証 • Push機能 • フレンド配信 • ブロードキャスト配信 •
Sync機能(New!) • P2Pっぽく、特定デバイスとの同期をリアルタイムに行う • Pull機能 • フレンドタイムライン • パブリックタイムライン • ブロードキャストデータ
SonicShooter機能 • ユーザ管理/認証 • Push機能 • フレンド配信 • ブロードキャスト配信 •
Sync機能(New!) • P2Pっぽく、特定デバイスとの同期をリアルタイムに行う • Pull機能 • フレンドタイムライン • パブリックタイムライン • ブロードキャストデータ
すごいTwitter っぽい
番組事例
事例: BloodyTube
紹介ムービー
プロジェクト構成概要
アジェンダ • MIESについて • Sonicshooter基本機能/事例紹介 • Sonicshooter詳細構成/特徴 • お試し構成デモ •
まとめ
Elastic Socket.ioクラスタ
S2構成
S2構成
特徴 • 同時数百万接続 • HTTPS対応 • 特定ユーザ(グループ)に対して通知 • 動的にノード追加可能 •
Weighted load balancing • 複数インスタンスタイプ対応
特定ユーザへ通知
動的にノード追加
ノード取得
Weighted load balancing
複数インスタンスタイプ対応
その他工夫しているところ • クライアントのフォールバックの仕組み • ハートビートが切れたら生きているノードを探しに行く • 別ノードへ再接続 • ソケットが切れている最中は、ポーリング間隔を短くする
アジェンダ • MIESについて • Sonicshooter基本機能/事例紹介 • Sonicshooter詳細構成/特徴 • お試し構成デモ •
まとめ
Docker+socket.ioデモ • Socket.ioも気軽にスケール出来たらいいよね • Socket.ioをDockerコンテナ化して、ポコポコ増やしてみる • スケールアウト/スケールインしたときに問題なく接続/再接続さ れる仕組み 昨日、さくっとプロトタイプ作ってみた
Docker+socket.ioデモ • Socket.io ロードバランサ問題 • ハンドシェイク > アップグレード の2回アクセス問題 •
公式はIP Hashで実現しているが、Sticky Sessionでやりたい • ※もっというと、コネクション数見ながら自前で制御したい • Openresty + Luaでコード書いてみた • Nginxのupstream更新はconsul-template + Registrator • Consul: クラスタされたサービス検出と設定のためのソリューション • consul-template: Consulイベントと連動してテンプレートを更新 • Registrator: Dockerコンテナ情報をconsul/etcdなどに適用 • 全体へのbroadcastはsocketio-redis adapter を使用
補足:sio-clientのsticky session
補足:Lua – sioノード決定コード
デモ構成
デモムービー
アジェンダ • MIESについて • Sonicshooter基本機能/事例紹介 • Sonicshooter詳細構成/特徴 • お試し構成デモ •
まとめ
まとめ • TV連動のリアルタイム通知を行うサービス/実装 /実例の紹介 • バージョンアップに向けてのデモンストレーション • まだまだ改善したいところたくさんある
ポエム • TV連動企画、人事ではない • 基本的には同じような企画が多いし、知見共有出来るところはたく さんあるはず • もっとこういう機会をふやしてこの業界全体の底上げしていきたい • もし次回があるなら聞きたい〜
• サーバ運用 • チート対策 • 集計 • 対談
宣伝その1
エンジニアサポート CROSS 2015 に登壇します! はやぶさ2開発者に聞く ~一度きりのテスト対策~
宣伝その2
None
ご清聴ありがとうございました