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
PostgreSQL 19 新機能概要 OSC Hokkaido 2026
nori_shinoda
0
250
自宅LLMの話
jacopen
1
720
“詰む”前に仕組みを作れ 〜技術の波に溺れないためのキャッチアップ術〜
takasyou
7
3.9k
From Prompt Engineering to Loop Engineering
shibuiwilliam
1
220
MySQL & MySQL HeatWave Report - June 2026
freshdaz
0
130
WebGIS AI Agentの紹介
_shimizu
0
560
BPaaSで進むAIオペレーションの現在地 AI実装が効く領域とスケーラビリティの選定と実装
kentarofujii
0
190
Kiro Ambassador を目指す話
k_adachi_01
0
130
飲食店もAIで。レジ締めやハンディシステムをつくってる話 / Using AI for restaurant management
vtryo
0
180
螺旋型キャリアの生存戦略 / kinoko-conf2026
rakus_dev
1
990
気軽に使える"情報のハブ"としてのNotion活用 〜フロー情報の集積点 と、 Claude Code × Notion AI〜
syucream
1
200
AIはどのように 組織のアジリティを変えるのか?
junki
4
1.4k
Featured
See All Featured
From π to Pie charts
rasagy
0
220
Jess Joyce - The Pitfalls of Following Frameworks
techseoconnect
PRO
1
170
Unsuck your backbone
ammeep
672
58k
Leadership Guide Workshop - DevTernity 2021
reverentgeek
1
310
Agile Actions for Facilitating Distributed Teams - ADO2019
mkilby
0
210
A Tale of Four Properties
chriscoyier
163
24k
No one is an island. Learnings from fostering a developers community.
thoeni
21
3.8k
Lessons Learnt from Crawling 1000+ Websites
charlesmeaden
PRO
1
1.3k
Bash Introduction
62gerente
615
220k
Groundhog Day: Seeking Process in Gaming for Health
codingconduct
0
220
How to Get Subject Matter Experts Bought In and Actively Contributing to SEO & PR Initiatives.
livdayseo
0
140
Docker and Python
trallard
47
3.9k
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
ご清聴ありがとうございました