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
現場のデータを集める技術
Search
Sponsored
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
Yuta Shimakawa
November 07, 2023
Technology
210
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
現場のデータを集める技術
Yuta Shimakawa
November 07, 2023
More Decks by Yuta Shimakawa
See All by Yuta Shimakawa
How much English do you really need? - English for Engineering Career Meetup #1
bananaumai
0
140
モノレポによるマイクロサービスアーキテクチャの開発運用
bananaumai
2
6.4k
Build real world data collecting architecture with Goroutine and Channel
bananaumai
1
730
Other Decks in Technology
See All in Technology
フィジカル版Github Onshapeの紹介
shiba_8ro
0
330
コミュニティの有益性 ~JAWS Days 2026 での体験を通して~ / The Benefits of a Community ~Through My Experience at JAWS Days 2026~
seike460
PRO
0
270
AI-DLCを “そのまま導入しなかった”話 ~組織に合わせてアジャストした 私たちの実践共有~
hiroramos4
PRO
1
430
現場のトークンマネジメント
dak2
1
190
When Platform Engineering Meets GenAI
sucitw
0
180
4人目のSREはAgent
tanimuyk
0
180
AIのReact習熟度を測る
uhyo
2
690
2026 AI Memory Architecture
nagatsu
0
320
2026-06-24_人とAIの責務分離に基づく開発プロセスの提案.pdf
takahiromatsui
0
180
AI 不只幫你寫 Code: 當專案從 300 暴增到 1500, 我們如何撐住 DevOps
appleboy
0
240
MySQL & MySQL HeatWave Report - June 2026
freshdaz
0
150
Comment regagner la souveraineté de vos données tout en étant payé grâce à Nostr !
rlifchitz
0
200
Featured
See All Featured
Color Theory Basics | Prateek | Gurzu
gurzu
0
370
Visualization
eitanlees
152
17k
Claude Code どこまでも/ Claude Code Everywhere
nwiizo
65
56k
Fantastic passwords and where to find them - at NoRuKo
philnash
52
3.7k
Building Better People: How to give real-time feedback that sticks.
wjessup
370
20k
Code Review Best Practice
trishagee
74
20k
Designing Experiences People Love
moore
143
24k
Design in an AI World
tapps
1
250
Public Speaking Without Barfing On Your Shoes - THAT 2023
reverentgeek
1
430
Future Trends and Review - Lecture 12 - Web Technologies (1019888BNR)
signer
PRO
0
3.6k
Building AI with AI
inesmontani
PRO
1
1.1k
A Soul's Torment
seathinner
6
3k
Transcript
©2023 MODE, Inc. 現場のデータを集める技術 8th Nov, 2023 Findy IoTアーキテクチャ -
スケーラビリティ×⾼可⽤性を追求する Lunch LT Yuta Shimakawa (@banana_umai)
©2023 MODE, Inc. 2 • ソフトウェアエンジニア(バックエンド中心) 10年+ • MODE (2019~)
• SNS ◦ Twitter: @banana_umai ◦ GitHub: @bananaumai ◦ LinkedIn: Yuta Shimakawa 島川 悠太 Yuta Shimakawa
©2023 MODE, Inc. MODE, Inc. 3 「現場の」データを収集‧蓄積‧活⽤するための技術を軸に、現実世界のビジネス業務を改善するための IoT * DXなソリューションを提供。
©2023 MODE, Inc. 4
©2023 MODE, Inc. 5 MODEを⽀える技術的要素: データの到達保証 • エンタープライズ向けの⽤途で利⽤してもらうために重要な技術。 • データ到達保証をいかに安定的に実現するかは⾯⽩い技術的課題の⼀つ。
©2023 MODE, Inc. 6 MQTT Broker REST API Gateways MODEのデータフロー
Message Queues Micro- Services Frontend app
©2023 MODE, Inc. 7 どのようにデータ到達保証するか?
©2023 MODE, Inc. 8 基本的な仕組み - ゲートウェイ内でのバッファと再送機構 センサーデータをディスクにバッファ データ送信失敗時に再送信可能
©2023 MODE, Inc. 9 簡単
©2023 MODE, Inc. 10 簡単
©2023 MODE, Inc. 11 過去に起きた問題 1 • ⼀部のゲートウェイの下流のスループッ トを超えてデータを送り続けた結果、 (データロストは起こらなかったもの
の)システム全体のスループットの低下 を招く。 • ⼀部のゲートウェイのトラフィックが全 体に影響を及ぼさないよう、SQSのFIFO Queueを⽤いてデータ発⽣元のゲート ウェイ毎にQueue Groupを分けていた が、SQSのFIFOの仕様の⾒落しと、適切 なデータ送信に対してのリミット設定を しなかったことが原因で問題が発⽣させ てしまった。
©2023 MODE, Inc. 12 過去に起きた問題 2 • ⼀部のゲートウェイのデータについて下 流のコンポーネントでの処理が時間がか かり、データ送信の量‧頻度は⾼くな
かったものの、緩やかにMessage Queue のバックログサイズが増加。 • 最終的に、システム全体のスループット の低下を招いてしまう。
©2023 MODE, Inc. 13 ゲートウェイ単体の機構だけではなく、 システム全体としての考慮が必要
©2023 MODE, Inc. 14 より堅牢で安定性のあるつくりに MQTT Broker Ack Ack Nack
©2023 MODE, Inc. 15 より堅牢で安定性のあるつくりに MQTT Broker Ack Ack Nack
• Queueのバックログをカウント • SQS nativeには存在しないのでRedisでカウンターを保持
©2023 MODE, Inc. 16 より堅牢で安定性のあるつくりに MQTT Broker Ack Ack Nack
• MODEのMQTT BrokerはMQTTを喋るアプリケーションサーバー • Message Queueがフルの場合は、ゲートウェイのPublishを失敗させる ⼀般的なMQTT Brokerを⽤いる場合、同様のことをするにはMQTT5で導⼊された Request/Responseパターンのような⽅法が必要になるはず(未検証)
©2023 MODE, Inc. 17 より堅牢で安定性のあるつくりに MQTT Broker Ack Ack Nack
• ゲートウェイにデータ送信の失敗が伝わることで、時間を置いてから再送する などの制御が可能になる。
©2023 MODE, Inc. まとめ 18 • データの到達保証はエンタープライズ向けのIoTシステムとして重要な技術要素 • IoTゲートウェイ単体でのデータのバッファリング機能や再送機能がそのために必要 な要素。
• ただし、システム全体として安定‧堅牢な運⽤を⾏うためには、システム全体とし てデータパイプラインの下流の滞りを上流まで届ける仕組みが必要(バックプレッ シャー)。 • データ到達保証は⼀⾒簡単そうに⾒えて、⾯倒なことが沢⼭ある。 • 更に: 今⽇は触れられなかった内容 ◦ クラウドへのデータ送信が詰まった場合ゲートウェイ内でバックプレッシャーをどのよう に扱うかも結構難しい。 ◦ ゲートウェイの内部アーキテクチャについては @takeshinodaの多様なプロトコルと 駆動モ デルをサポートするIoTゲートウェイの開発と運⽤の知⾒ をご覧ください。
©2023 MODE, Inc. さいごに • なお、データ到達保証にまつわる技術要素はMODEのIoT技術要素のほんの⼀部。 • IoTは技術的なスタックが広くて⾯⽩い。 • StackOverflowには答えが載っていない問題も多く存在。
19
©2023 MODE, Inc. MODEに興味を持ってもらえた⽅は... 20 https://lp.tinkermode.jp/modenight/20231117
©2023 MODE, Inc. ご清聴ありがとうございました 21