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
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
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
10年間のブログ発信を振り返って見えたWebアプリケーションエンジニアとしての軌跡
stefafafan
0
150
When Platform Engineering Meets GenAI
sucitw
0
120
【Snowflake Summit 2026 Recap!!】Snowflake Summit Deep Dive: Security & Governance
civitaspo
1
250
【2026年版】 ベクトル検索とEmbedding最前線
mocobeta
14
3.8k
IaC コードを資産へ:AWS CDK 社内ライブラリと横断展開 / aws-summit-japan-2026
gotok365
2
720
SONiCの統計情報を取得したい
sonic
0
220
200個のGitHubリポジトリを横断調査したかった
icck
0
130
Android の公式 Skill / Android skills
yanzm
0
160
入門!AWS Blocks
ysuzuki
1
150
気軽に使える"情報のハブ"としてのNotion活用 〜フロー情報の集積点 と、 Claude Code × Notion AI〜
syucream
1
150
アンオフィシャルな、オフィシャルからのお願い
wyamazak_devrel
0
140
小さく始める AI 活用推進 ― 日経電子版 Web チームの事例/nikkei-tech-talk47
nikkei_engineer_recruiting
0
300
Featured
See All Featured
GitHub's CSS Performance
jonrohan
1033
470k
First, design no harm
axbom
PRO
2
1.2k
Efficient Content Optimization with Google Search Console & Apps Script
katarinadahlin
PRO
1
630
Designing Experiences People Love
moore
143
24k
A better future with KSS
kneath
240
18k
Optimizing for Happiness
mojombo
378
71k
Into the Great Unknown - MozCon
thekraken
41
2.6k
The Impact of AI in SEO - AI Overviews June 2024 Edition
aleyda
5
1.1k
16th Malabo Montpellier Forum Presentation
akademiya2063
PRO
0
150
Beyond borders and beyond the search box: How to win the global "messy middle" with AI-driven SEO
davidcarrasco
3
160
SEO for Brand Visibility & Recognition
aleyda
0
4.6k
Game over? The fight for quality and originality in the time of robots
wayneb77
1
200
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
ご清聴ありがとうございました