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
65
Cloud on the beach - いろいろな雲のかたち
bohnen
1
69
TiUG #1 TiDB overview and update
bohnen
0
220
みんなのPython勉強会: 最近のDB事情 TiDB Serverlessの紹介
bohnen
1
660
Postman Tokyo Meetup - Serverless Integration with Flows
bohnen
2
190
Serverless Meetup Re:boot 福岡 TiDB Serverlessの紹介
bohnen
1
130
Serverless Meetup Fukuoka Workshop TiDB
bohnen
0
65
TiUG #0 発表資料: TiDBの紹介と最新情報
bohnen
0
250
Momento会 #8 Serverless with TiDB/Momento/Postman
bohnen
0
72
Other Decks in Programming
See All in Programming
新卒から4年間、20年もののWebサービスと 向き合って学んだソフトウェア考古学
oguri
8
7.2k
AHC045_解説
shun_pi
0
460
Coding Experience Cpp vs Csharp - meetup app osaka@9
harukasao
0
730
これだけは知っておきたいクラス設計の基礎知識 version 2
masuda220
PRO
24
6k
Building Scalable Mobile Projects: Fast Builds, High Reusability and Clear Ownership
cyrilmottier
2
250
List とは何か? / PHPerKaigi 2025
meihei3
0
670
Enterprise Web App. Development (1): Build Tool Training Ver. 5
knakagawa
1
110
Kamal 2 – Get Out of the Cloud
aleksandrov
1
170
スモールスタートで始めるためのLambda×モノリス
akihisaikeda
2
130
海外のアプリで見かけたかっこいいTransitionを真似てみる
shogotakasaki
1
160
エンジニア未経験が最短で戦力になるためのTips
gokana
0
260
MCP調べてみました! / Exploring MCP
uhzz
2
2.2k
Featured
See All Featured
Mobile First: as difficult as doing things right
swwweet
223
9.6k
I Don’t Have Time: Getting Over the Fear to Launch Your Podcast
jcasabona
32
2.2k
Design and Strategy: How to Deal with People Who Don’t "Get" Design
morganepeng
129
19k
Fireside Chat
paigeccino
37
3.4k
Making Projects Easy
brettharned
116
6.1k
No one is an island. Learnings from fostering a developers community.
thoeni
21
3.2k
Site-Speed That Sticks
csswizardry
5
480
Docker and Python
trallard
44
3.3k
Improving Core Web Vitals using Speculation Rules API
sergeychernyshev
13
660
Bootstrapping a Software Product
garrettdimon
PRO
307
110k
[RailsConf 2023 Opening Keynote] The Magic of Rails
eileencodes
29
9.4k
Put a Button on it: Removing Barriers to Going Fast.
kastner
60
3.8k
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内でクライアント を動かした方がよいかもしれない。