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
決済のトランザクション管理術 / How to Manage Payment Transaction
Search
Masato Ohba
September 27, 2018
Technology
3
6.8k
決済のトランザクション管理術 / How to Manage Payment Transaction
Meguro.rb#19で発表した資料です。
https://megurorb.connpass.com/event/100401/
Masato Ohba
September 27, 2018
Tweet
Share
More Decks by Masato Ohba
See All by Masato Ohba
Unlocking Potential of Property Based Testing with Ractor
ohbarye
2
60
プロトタイピングによる不確実性の低減 / Reducing Uncertainty through Prototyping
ohbarye
5
420
My Favorite Protocol: Idempotency-Key Header
ohbarye
6
4.8k
エンジニア9名でプロポーザル提出8件, 採択3件を支える技術と文化 / Proposal Fight Culture
ohbarye
1
4.8k
管理機能アーキテクチャパターンの考察と実践 / Learn Architecture through Admin
ohbarye
33
15k
サブスクリプションサービスをつくる時にエンジニアが考えること / Behind the Scenes: Engineering a Subscription Service
ohbarye
15
17k
RuboCop Custom Formatter for Reviewdog Diagnostic Format
ohbarye
2
1.8k
DB外の副作用をトランザクションから分離しよう / Isolate out-of-DB side effects from transactions
ohbarye
7
3.8k
Balance Security and Usability in the Field of 3D Secure
ohbarye
5
3.5k
Other Decks in Technology
See All in Technology
SLOいつ決めましょう?
abnoumaru
3
180
QAエンジニアが伝えたい品質保証の羅針盤 / Compass for Quality Assurance
mii3king
1
330
OPENLOGI Company Profile for engineer
hr01
1
2.2k
Google Cloud Next '24 Recap in ZOZO AIにより変わる開発 運用/Development and operation changed by AI
gachimuchiengineer
0
190
AWS アーキテクチャ作図入門/aws-architecture-diagram-101
ma2shita
16
6.7k
株式会社EventHub・エンジニア採用資料
eventhub
0
2.1k
【リラン】AIの光と闇?失敗しないために知っておきたいAIリスクとその対応 ①政府の動き編
tkhresk
0
140
CockroachDB はどのくらい「しぶとい」のか? / How tough is CockroachDB?
kota2and3kan
13
4.9k
サービス開発におけるVue3とTypeScriptの親和性について
tsukuha
10
1.8k
本当のガバクラ基礎
toru_kubota
0
310
Money-saving tips for the frugal serverless developer
theburningmonk
0
150
Observabilityジャーニーを実現するためのAWSサービス:OSS編
o11yfes2023
0
110
Featured
See All Featured
The Brand Is Dead. Long Live the Brand.
mthomps
49
30k
Java REST API Framework Comparison - PWX 2021
mraible
PRO
18
7k
Building a Modern Day E-commerce SEO Strategy
aleyda
22
6.5k
Building Adaptive Systems
keathley
32
1.9k
Documentation Writing (for coders)
carmenintech
60
4k
Helping Users Find Their Own Way: Creating Modern Search Experiences
danielanewman
21
2k
Side Projects
sachag
451
41k
Being A Developer After 40
akosma
67
580k
Gamification - CAS2011
davidbonilla
77
4.6k
Dealing with People You Can't Stand - Big Design 2015
cassininazir
358
22k
4 Signs Your Business is Dying
shpigford
176
21k
Sharpening the Axe: The Primacy of Toolmaking
bcantrill
22
1.4k
Transcript
#megurorb 決済のトランザクション管理術 決済のトランザクション管理術 @ohbarye Meguro.rb#19
#megurorb 決済のトランザクション管理術 すべてを 記録する
#megurorb 決済のトランザクション管理術 決済処理を例にした 分散トランザクション管理の一例 話すこと
#megurorb 決済のトランザクション管理術 分けることのできない 一連の情報処理の単位 トランザクションとは
#megurorb 決済のトランザクション管理術 こんなやつ この block に含まれるタスクが全て実行 されるか、あるいは全く実行されないこと を保証しなければならない
#megurorb 決済のトランザクション管理術 トランザクション単位 シーケンス図にすると 簡単? >
#megurorb 決済のトランザクション管理術 難しいのは “分散”トランザクション ネットワーク上の2つ以上の ホストが関連するトランザクション
#megurorb 決済のトランザクション管理術 トランザクション単位 クレカ決済の一例
#megurorb 決済のトランザクション管理術 *トランザクション単位がでか い *通信を挟む 最初の例との差分 *データを記録するホストが複数 *両者で整合性を保ちたい *システム境界をまたぐ *外的要因に影響を受ける
#megurorb 決済のトランザクション管理術 考えうる失敗例 ネットワーク通信は基本的に失敗する可 能性がある 決済ゲートウェイ側でエラー 事業者側でエラー 一方からは成功に見えるがもう一方からは 失敗扱いになる、なんてことも
#megurorb 決済のトランザクション管理術 障害が起きることを 前提とした設計にする すべての障害可能性を事前に潰すのは不可能
#megurorb 決済のトランザクション管理術 具体的な方針 ➔ 1. 進行状況をできる限り詳細に記録する ◆ (optional) 疑わしくてもサービス役務提供しておく ➔
2. データ不整合を検知できるようにする ◆ 偽陽性を許容する ➔ 3. 検知されたものについては一つ一つ精査する
#megurorb 決済のトランザクション管理術 1. 進行状況をできる限り詳細に記録する 購入要求受付 与信成功 確定要求成功 サービス提供
#megurorb 決済のトランザクション管理術 2. データ不整合を検知できるようにする
#megurorb 決済のトランザクション管理術 3. 検知されたものについては一つ一つ精査する 一重積んではユーザーのため 二重積んでは金のため... 続けるとパターンが見えてくる。 より精度の高いやり方や、自動化の兆 しが出てきます
#megurorb 決済のトランザクション管理術 記録さえ残しておけば、あとでどうにかできる 記録がなければ、どうしようもない なので すべてを記録する のが第一歩
#megurorb 決済のトランザクション管理術 Thank you!