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
グローバル展開を支える量子的なサービス設計 #mercariday / mercariday2...
Search
Hiraku NAKANO
January 20, 2017
Technology
14k
22
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
グローバル展開を支える量子的なサービス設計 #mercariday / mercariday2017-api
Mercari DAY 2017の登壇資料です。
Hiraku NAKANO
January 20, 2017
More Decks by Hiraku NAKANO
See All by Hiraku NAKANO
iD決済を支える技術 / #merpay_techtalk
hirak
33
7.2k
github.com/mercari の今と昔 /github-mercari
hirak
8
3.2k
PHPStanで始める継続的静的解析 #phperkaigi /php-static-analysis
hirak
14
54k
極める!メソッドチェーン #phpstudy / fluent-interface
hirak
8
3k
evalこそパワー #phpkansai / phpkansai2017
hirak
2
1.7k
PHPのエラーと例外再入門 / php-error-and-exception
hirak
19
20k
メルカリ JP Tech Side / mercari-jp-tech-side
hirak
7
2k
Composerプラグインを作ってみよう /phpcon2016
hirak
5
14k
packagist.jpの紹介と新機能 /#phpblt
hirak
4
2.9k
Other Decks in Technology
See All in Technology
Disciplined Vibes: Scaling AI-Assisted Engineering
sheharyar
0
150
連合学習と機密コンピューティング
lycorptech_jp
PRO
0
120
脆弱性対応、どこで線を引くか
rymiyamoto
1
400
AIはどのように 組織のアジリティを変えるのか?
junki
4
960
LayerX コーポレートエンジニアリング室におけるサプライチェーンセキュリティへの取り組み / Supply Chain Security at LayerX Corporate Engineering
yuyatakeyama
2
610
Kiroで書いた 設計書 が AI レビューの 採点基準 になる
ezaki
0
120
Bucharest Tech Week 2026 - Reinventing testing practices in the AI era
edeandrea
PRO
1
160
Claude Codeをどのように キャッチアップしているか
oikon48
13
8.3k
Claude Code の Sandbox 機能を Anthropic Sandbox Runtime(srt) で試そう!/lets-play-anthropic-sandbox-runtime
tomoki10
1
620
Kubernetesにおける学習基盤とLLMOpsの概要
ry
1
310
2026 TECHFRESH 畢業分享會 - 開發日常大解密!從領域驅動到企業級上線
line_developers_tw
PRO
0
1.1k
200個のGitHubリポジトリを横断調査したかった
icck
0
130
Featured
See All Featured
How to Align SEO within the Product Triangle To Get Buy-In & Support - #RIMC
aleyda
2
1.5k
Exploring the relationship between traditional SERPs and Gen AI search
raygrieselhuber
PRO
2
4k
Breaking role norms: Why Content Design is so much more than writing copy - Taylor Woolridge
uxyall
0
320
Leveraging Curiosity to Care for An Aging Population
cassininazir
1
270
SEOcharity - Dark patterns in SEO and UX: How to avoid them and build a more ethical web
sarafernandez
0
200
Max Prin - Stacking Signals: How International SEO Comes Together (And Falls Apart)
techseoconnect
PRO
0
180
Bash Introduction
62gerente
615
220k
AI Search: Implications for SEO and How to Move Forward - #ShenzhenSEOConference
aleyda
1
1.3k
Reality Check: Gamification 10 Years Later
codingconduct
0
2.2k
Automating Front-end Workflow
addyosmani
1370
210k
Git: the NoSQL Database
bkeepers
PRO
432
67k
[SF Ruby Conf 2025] Rails X
palkan
2
1.1k
Transcript
άϩʔόϧల։Λࢧ͑Δ ྔࢠతͳαʔϏεઃܭ 2017/01/20 Mercari DAY Hiraku NAKANO
About Me • த (@Hiraku) • ϝϧΧϦͷJP൛ BizDevνʔϜॴଐ • αʔόʔαΠυ୲ɺPHP͔Γॻ͍ͯΔ
• ೖࣾͯ͠Ұͪΐͬͱ
όοΫΤϯυܥͷ৬छ 43& αʔόʔαΠυ w ৴པੑʹϑΥʔΧε w ύϑΥʔϚϯενϡʔχϯά ͕ओઓ w 0QT݉ͶΔ
w ػೳ։ൃʹϑΥʔΧε w υϝΠϯϩδοΫ͕ओઓ w 1ͱηοτͰಈ͘ ࢲͬͪ͜ʹॴଐ
άϩʔόϧల։Λࢧ͑Δ ྔࢠతͳαʔϏεઃܭ 2017/01/20 Mercari DAY
None
"FacebookͩͱɺԿສͱ͍͏ ABςετ͕ಉ࣌ʹ͍ͬͯΔɻ ϝϧΧϦͰेຊͬͯΔɻ ύλʔϯେʹ͋Δ"
ͬ͘ ͑ΜͲ Web൛
ͬ͘ ͑ΜͲ Web൛ ͦ͏͍͏Πϝʔδ͡Όͳ͍
ͬ͘ ͑ΜͲ Web൛ ͳΜ͔ྠֲ͕ Α͔͘Βͳ͍…
ͬ͘ ͑ΜͲ • ຊ൛ʹΞΫηε • ΫϥΠΞϯτόʔδϣϯ͕XX • ϩάΠϯதͷϢʔβʔID͕YY • ͕ZZ
• ΞΫηεͨ࣌͠ࠁ͕TT • etc ͬͱྠֲ͕ ݟ͑ͯ͘Δ
"ྔࢠత"ͱ͍͏ൺᄻ • ݟΔਓʹΑͬͯҧ͏ಈ͖ʹͳΔ • ؍ଌ͠ͳ͍ͱΑ͔͘Βͳ͍ • શύλʔϯʹରͯ͠ໃ६ͳ͘ಈ࡞͢Δ
ͳͥ"ྔࢠత"ͳͷ͔ • Ծઆ࣮ݧओٛ • ࣮ݧͨ͠΄͏͕͘ਖ਼ղʹͨͲΓண͚Δ • ֎෦ڥͷಈ͖ෆ࣮֬ • ಥવͷোɾ֎෦͔Βͷ߈ܸ •
શͯఆ͢Δͷࠔ
"ྔࢠత"ͳιϑτΣΞ • ෳࡶɾϝϯςϯφϯεେม • ߟྀ࿙Εͱ͔ى͖ͳ͍ͷʁ • ϝϧΧϦͲ͏࣮ݱ͍ͯ͠Δͷ͔ʁ
ࠓ ͢͜ͱ 1. ϞόΠϧΞϓϦͷόοΫΤϯυʹ ٻΊΒΕΔ͜ͱ 2. ॏཁͰͳ͔ͬͨ͜ͱ 3. mercari-apiͷࢥ 4.
ࠓΛੜ͖ΔͨΊʹ
ٻΊΒΕ͍ͯΔ͜ͱ
ͬ͘ ͑ΜͲ • ϦϦʔεͷίετ͕͍ • શʹίϯτϩʔϧԼ • ϦϦʔεޙؚΉ • ඇެ։ʹͰ͖Δ
όοΫΤϯυ͔ͩΒͰ͖Δ͜ͱ • ࢪࡦΛଧͭͨΊͷ • ʮࠓ͙͢ϦϦʔεʯ͕ৗʹՄೳͳଘࡏ • ΞυϗοΫͳোରԠྗ • σʔλͷ࠷ऴน
ͪΖΜલఏͱͯ͠ • ࣭ • ύϑΥʔϚϯε • কདྷతʹഁ͠ͳ͍ݟ௨͠ • Լ͠ͳ͍։ൃ •
ηΩϡϦςΟ߈ܸͷରԠ
None
શͯରॲ͢Δͷେม
࣮ॏཁͰͳ͔ͬͨ͜ͱ
ίʔυతʹඒಙͱ͞ΕΔͷ • ൚༻ੑ • ඒ͠͞ • Ұ؏ੑ ϝϧΧϦͰ Ձ͕Ί
൚༻ੑͳͲͳ͍ • ެࣜΫϥΠΞϯτͷΈߟྀ • ͔͠αϙʔτόʔδϣϯͷΈ • ͦΕҎ֎͔Β͑ͳ͍͠ɺ ͏͜ͱఆ͠ͳ͍
WebAPIͱͯ͠ͷඒ͠͞ • RESTful, HATEOASͱ͍ͬͨ ϕετϓϥΫςΟε…ͱ͞ΕΔͷ • શવकͬͯͳ͍ • ࠷ॳ͋ͬͨͣͳͷ͕ͩ •
ެࣜΫϥΠΞϯτʹ߹Θͤͯվम͠·͘ΕΔ͜ͱ ͷ΄͏͕ॏཁ
Ұ؏ੑͷͳ͞ • ※σʔλҰ؏ੑࢮकͰ͢Α • ίʔυͱͯ͠ேྩվ ͲΜͱདྷ͍ʂ • Ή͠ΖҰ؏ੑͷͳ͍मਖ਼ʹ͑ΒΕΔΑ͏ʹ ίετΛࢧ͏͖
ϓϩάϥϚͱͯ͠ͷ৺ڥ • ͪΖΜɺඒ͘͠Ұ؏ͯ͠நԽ͞Εͨͷ Λ࡞Γ͍ͨ… • ৽ن։ൃͳΒɺ͍ͭເΛ٧ΊࠐΉΑ͏ʹ ͍ͯ͠Δ • ʮमਖ਼͍ͨ͠ʯͱ͍͏νέοτΛʑ࡞ͬͯ ͍Δ
PragmaticͰ͋Δ͜ͱ DogmaticʹͳΒͳ͍͜ͱ • ϦϦʔεΛ᪳͠ͳ͍ • ෆશͰಈ͍͍ͯΔํ͕ΑͬΆͲ͍͍ • Be Professional Day
Ͱ៉ྷʹ͢Δ
mercari-api
ιʔείʔυඇެ։ ͳͷͰɺུ͚֓ͩ
ٕज़తΩʔϫʔυ • ಠ࣮ࣗͷJSON over HTTPS WebAPI • nginx/OpenResty, Go, PHP,
MySQL, Q4M, Parallel-Prefork, Memcached, Solr, ... • DietCakeϕʔεͷϑϨʔϜϫʔΫ
None
࣮ࡍͷߏ ൃදଟ͍ͷͰׂѪ
mercari-api ͷࢥ
ࢥతΩʔϫʔυ • ബ͍ϑϨʔϜϫʔΫɾ۪ͳ࣮ • ͕͞શͯΛղܾ͢Δ • Ψʔυઅͷଟ༻ • ୯ҰϦϙδτϦͱ͍͏ᐫ
None
DietCake • ඇৗʹബ͘ɺ༨ܭͳ͜ͱԿ͠ͳ͍ • શମతʹ۪ͳ࣮ • ϑϩϯτίϯτϩʔϥʔ͔Βॱ൪ʹಡΈਐ Ί͍͚ͯඞͣѲͰ͖Δ • ϑϨʔϜϫʔΫଆ͕͋·Γറͬͯ͜ͳ͍
͕͞શͯΛղܾ͢Δ • APIࣗମͷ͞ • ଟগͷແཧ͕Ͱ͖Δঢ়ଶΛอͭ • ։ൃͷ͞ • ͙͢ʹফ͢ͳΒΞυϗοΫͳରԠՄೳ
Α͋͘Δޫܠ • 1ि͙ؒΒ͍Ͱ։ൃ+QA -> ϦϦʔε • Ωϟϯϖʔϯ͕ऴΘͬͨͷͰશআ
Ψʔυઅͷଟ༻ • if (ఆͱҧ͏) { throw new Error; } •
Α͋͘Δྫ • ʮUSͰͷΈʯ • ʮABςετέʔε˓˓൪ͷAύλʔϯʯ • ʮ࠷৽ͷΞϓϦΛ͓͍Լ͍͞ʯ
୯ҰϦϙδτϦͱ͍͏ᐫ • JP/US/GBઃఆͱDBͰΓସ͑ • αʔόʔߏɺ։ൃڥɺϊϋڞ௨Խ • ฐ͋Δ͕ࠓͷͱ͜Ζڐ༰ൣғ
mercari-api ۪ͳ࣮ ˣ ։ൃͷॠൃྗ ੑೳ Ψʔυઅଟ༻ ˣ গ͠ͰෳࡶΛԼ͛Δ ୯ҰϦϙδτϦ ˣ
ഁ͠ͳ͍ઃܭΛ ڧཁ͞ΕΔ
ࠓΛੜ͖ΔͨΊʹ
ϝϧΧϦʹશ͘༨༟ͳ͍ • USϓϩμΫτ·ͩ·ͩେޭͰͳ͍ • ۪ͳվળʹΑΓɺ֯Λ͞ΒʹߴΊͳ ͍ͱɺγϦίϯόϨʔͷڝ߹ʹ͋ͬͱ͍͏ؒ ʹෛ͚Δ • ݶΒΕͨϦιʔεΛͬͯɺҰยͷແବͳ͘ ࣄΛਐΊΔ͜ͱ͕ۃΊͯॏཁɻ
Ͱ͖ͳ͍͜ͱଟ͍ • খखઌͷςΫχοΫͰෳࡶԼ͕Βͳ͍ • όάΛϦϦʔεͯ͠͠·͏͜ͱ͋Δ • ࣦഊͩͬͨͷ͑Εͣ • ͔͠͠ڝ߹ͬͯ͘Εͳ͍
None
ʮΤϯδχΞϦϯά͚ͩͰ ղܾ͠Α͏ͱ͠ͳ͍ʯ
ʮ࡞ΓతʹࣗಈςετͭΒ͍ʯ ˣ ؾ߹͍ͰϨϏϡʔ͠·͢ QAͰ֬ೝ͠·͢
ʮ࣭ʹෆ͕҆Δ…ʯ ↓ ͦ͏ͳΒ͙͢͠· ͠ΐ͏ ෛՙࢹ͠·͢
Τοδέʔεͷ࣮͕େม ↓ ☺CSखΦϖͳΒରॲ͍͚ͦ͏ ରԠϚχϡΞϧͰ͖ͨΑʔ
None
େࣄʹ͍ͯ͠Δ͜ͱ • ԿΑΓϓϩμΫτͱͯ͠ޭ͢Δ͜ͱ • 80% ͰϦϦʔεͯ͠ɺલʹਐΊΔ • ΓผͷखஈΛ୳ͯ͠र͏ or མͱ͢
• ৽ػೳچΫϥΠΞϯτͰಈ͔ͳ͍͚Ͳɺ Ϋϥογϡͤ͞ͳ͍
·ͱΊ
Ҏ্ࢲֶ͕Μͩ͜ͱ • ࢲͷೖࣾͨ͠ࠒʹطʹ͋ͬͨจԽ • ͓ͦΒ͘ૂͬͨ෦ͱɺ݁Ռతʹͦ͏ͳͬͨ෦ ͕͋Δ • ྠֲͷᐆດͳྔࢠతͳαʔϏε • ͜Ε͔Βͦ͏Ͱ͋Γଓ͚ΔͩΖ͏͠ɺ
ࢧ͑ΔͨΊͷίετࢧ͏