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
Momento Topics使ってみた
Search
bohnen
September 14, 2023
Programming
0
160
Momento Topics使ってみた
bohnen
September 14, 2023
Tweet
Share
More Decks by bohnen
See All by bohnen
Momento会 #9 TiDB ServerlessとMomentoの話
bohnen
0
56
Cloud on the beach - いろいろな雲のかたち
bohnen
1
61
TiUG #1 TiDB overview and update
bohnen
0
200
みんなのPython勉強会: 最近のDB事情 TiDB Serverlessの紹介
bohnen
1
620
Postman Tokyo Meetup - Serverless Integration with Flows
bohnen
2
180
Serverless Meetup Re:boot 福岡 TiDB Serverlessの紹介
bohnen
1
130
Serverless Meetup Fukuoka Workshop TiDB
bohnen
0
55
TiUG #0 発表資料: TiDBの紹介と最新情報
bohnen
0
240
Momento会 #8 Serverless with TiDB/Momento/Postman
bohnen
0
65
Other Decks in Programming
See All in Programming
ファインディの テックブログ爆誕までの軌跡
starfish719
2
1.1k
Formの複雑さに立ち向かう
bmthd
1
720
Compose でデザインと実装の差異を減らすための取り組み
oidy
1
300
【PHP】破壊的バージョンアップと戦った話〜決断と説得
satoshi256kbyte
0
120
Honoとフロントエンドの 型安全性について
yodaka
4
250
Bedrock Agentsレスポンス解析によるAgentのOps
licux
2
720
Lottieアニメーションをカスタマイズしてみた
tahia910
0
120
2024年のkintone API振り返りと2025年 / kintone API look back in 2024
tasshi
0
210
Immutable ActiveRecord
megane42
0
130
chibiccをCILに移植した結果 (NGK2025S版)
kekyo
PRO
0
210
お前もAI鬼にならないか?👹Bolt & Cursor & Supabase & Vercelで人間をやめるぞ、ジョジョー!👺
taishiyade
5
3.8k
XStateを用いた堅牢なReact Components設計~複雑なClient Stateをシンプルに~ @React Tokyo ミートアップ #2
kfurusho
1
770
Featured
See All Featured
Fontdeck: Realign not Redesign
paulrobertlloyd
82
5.4k
Docker and Python
trallard
44
3.3k
Six Lessons from altMBA
skipperchong
27
3.6k
What's in a price? How to price your products and services
michaelherold
244
12k
Building an army of robots
kneath
302
45k
Done Done
chrislema
182
16k
We Have a Design System, Now What?
morganepeng
51
7.4k
How to Think Like a Performance Engineer
csswizardry
22
1.3k
Bootstrapping a Software Product
garrettdimon
PRO
305
110k
Intergalactic Javascript Robots from Outer Space
tanoku
270
27k
Embracing the Ebb and Flow
colly
84
4.6k
Statistics for Hackers
jakevdp
797
220k
Transcript
Momento Topics 使ってみた bohnen
そもそもTopicsと ? • いわゆる Pub-Sub 型 メッセージチャネル 一つで、疎結合・非同期なシステム間連 携を実現する •
一つ メッセージを複数 宛先が読み取る ことが可能 • AWSだとSNSとかが該当 • 類似サービス ◦ JMS互換 キュー製品すべて ◦ Redis pub-sub ◦ Kafka ◦ SNS (AWS) ◦ EventBridge (AWS) エンタープライズアーキテクチャパターン より
金融業界で Topics 間に入っているKinesisがシ ステム間 連携を担ってい る。 ここで ポイント 、 •
データ みに依存し た処理(関数型っぽ い) • 並列に処理が実行で きる。例え 株ならそ れぞれ 銘柄毎 • 処理がしょっちゅう増 える・変わる。いわゆ るマイクロサービス AWS金融リファレンスアーキテクチャより
サンプルプログラム(Momento FX!) Rate Publisher Order Executor (本来 )LP 価格に利益を乗せて顧客に提供する 価格
topicsを使ってリアルタイ ムに同報通信 注文 RESTエンドポイントを呼び 出し 注文が実勢価格よりも一定以上 乖離しているとnothing(失効) 実際 LPに投げる LP(Liquidity Provider) 業者向けに価格を提供して、 そ 値段で注文を受け付け る業者 金融機関や取引所など
デモ
Rate Publisher 基本これだけ • TopicClient 初期化 • Publish 今回 websocketでレートを提供している
bitflyer lightning APIを使って、レートを取 得する度にpublishしている (同時に、最新価格を cacheにも保存し、 Execution時に参照する) ※ 全然関係ないけどレート 配信頻度低す ぎない...?
Token API Server Topicsにブラウザから直接アクセスするため に必要な一時トークンを発行する API Chatアプリ サンプルからコードを拝借 Next.js わからなかった
で使う を諦め、 fastify スタンドアロンサーバとして実装して います。 ここで 接続してきた人に 誰でもトークンを 返していますが、Chatアプリサンプル ように 認証済み 人に み返す がベターでしょ う。(認証APIも課金対象な かな?)
UI - トークン 取得 Chatアプリ サンプルからコードを拝借 先ほど REST APIからトークンを取得して、 CredentialProviderを初期化。
ここからtopicClientが取得できる ※変数 命名が変だったり、 cache使ってな い で不要だったり余計なも があります。
UI - Topicから 取得 topicClientを使って、topicにsubscribeしま す。こ ときにコールバック関数を渡して、そ れが価格が届いた時 処理になります。 UI側で
useEffect内でtopicにsubscribeし、 コールバックでStateを変更して画面に反映し ています。
使ってみて • Web-sdk 楽。間にいちいちwebsocket サーバを立てる必要がない で、テ ストも簡単(クライアントjavascriptだけ書いてでテストできる) • 実務で利用する場合 同時接続数を気にする必要がある。これが万単位まで
できるとかなり便利な で ?! • 一時トークン 発行がちょっと手間。Signed URLとかでAPIなしで初期化できる ようにならないかなあ • Typescriptサポートとcopilotが強力すぎて開発体験が爆上がり • レイテンシ 往復20ms位出る で気になる場合 AWS/GCP内でクライアント を動かした方がよいかもしれない。