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
·
SiteGround - Reliable hosting with speed, security, and support you can count on.
→
teru0x1
December 13, 2022
Technology
2.1k
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
スタブサーバ自動生成ツール 〜負荷試験をもっと楽に〜
DMM.go #5
https://www.youtube.com/watch?v=EZyKip6dmMs
teru0x1
December 13, 2022
More Decks by teru0x1
See All by teru0x1
開発効率と信頼性を両立する Ubieのプラットフォームエンジニアリング
teru0x1
0
600
マルチクラスタの認知負荷に立ち向かう! Ubieのプラットフォームエンジニアリング
teru0x1
4
4.9k
ブラウザの外側でWasmを使おう
teru0x1
0
400
バッチシステムをクラウドネイティブにするために考えたこと
teru0x1
17
8.6k
クラウド環境をFargateに 移行して得た知見
teru0x1
0
1.6k
Goと定数 DMM.go #3
teru0x1
0
2.8k
はてなインターン2020成果発表
teru0x1
0
1.2k
入門QUIC
teru0x1
0
600
【衝撃】Archlinuxをインストールした結果がヤバすぎた!
teru0x1
0
140
Other Decks in Technology
See All in Technology
Agentic Defenseとともにセキュリティエンジニアが輝き続けるには / How Security Engineers Can Keep Excelling with Agentic Defense
yuj1osm
0
130
GoとSIMDとWasmの今。
askua
3
520
AI-DLCを活用した高品質・安全なAI駆動開発実践 / AI Driven Development with AI-DLC
yoshidashingo
0
160
製造業のクラウド活用最適解〜AI,DXを加速するデータ基盤の作り方〜
hamadakoji
0
420
AIを「創る」と「使う」の循環 — HRテックが実践するリアルなAI組織実装
taketo957
0
1.8k
noUncheckedIndexedAccess、3時間、1万円。 / noUncheckedIndexedAccess, 3 Hours, 10,000 JPY.
kaonavi
1
340
チームで実践する AI-DLC 思考の軌跡を残すチェックポイント設計
belongadmin
0
3.1k
Rubyで音を視る
ydah
1
220
Microsoft Build Keynoteふりかえり
tomokusaba
0
120
NAB Show 2026 動画技術関連レポート / NAB Show 2026 Report
cyberagentdevelopers
PRO
0
130
ポケモンの型をTypeScriptの型システムで表現してみた
subroh0508
0
360
DevOps Agentで始めるAWS運用 〜フロンティアエージェントが変える運用の現場〜
nyankotaro
1
340
Featured
See All Featured
The Cult of Friendly URLs
andyhume
79
6.9k
Cheating the UX When There Is Nothing More to Optimize - PixelPioneers
stephaniewalter
287
14k
Game over? The fight for quality and originality in the time of robots
wayneb77
1
190
Neural Spatial Audio Processing for Sound Field Analysis and Control
skoyamalab
0
330
世界の人気アプリ100個を分析して見えたペイウォール設計の心得
akihiro_kokubo
PRO
71
40k
Are puppies a ranking factor?
jonoalderson
1
3.5k
Money Talks: Using Revenue to Get Sh*t Done
nikkihalliwell
0
250
Color Theory Basics | Prateek | Gurzu
gurzu
0
360
Designing Experiences People Love
moore
143
24k
Navigating the Design Leadership Dip - Product Design Week Design Leaders+ Conference 2024
apolaine
1
340
How to optimise 3,500 product descriptions for ecommerce in one day using ChatGPT
katarinadahlin
PRO
1
3.6k
RailsConf & Balkan Ruby 2019: The Past, Present, and Future of Rails at GitHub
eileencodes
141
35k
Transcript
© DMM © DMM スタブサーバ自動生成ツール 〜負荷試験をもっと楽に〜 DMM.go #5
© DMM 2 小野 輝也 合同会社DMM.com SRE 2021年新卒入社 Twitter: @teru0x1
https://cha-shu00.hatenablog.com/
今日のテーマ 負荷試験
© DMM 想定する負荷試験対象 4 • ベンチマークサーバ ◦ リクエストをたくさん投げる • 試験対象システム
(SUT: System Under Test) • 外部API ◦ 別の組織が管理してるAPI ◦ 勝手に変更できない Amazon Web Services、“Powered by AWS”ロゴ、[およびかかる資料で使用されるその他のAWS商標] は、米国その他の諸国における、Amazon.com Inc.またはその関連会社の商標です。
© DMM 想定する負荷試験対象 5 • ベンチマークサーバ ◦ リクエストをたくさん投げる • 試験対象システム
(SUT: System Under Test) • 外部API ◦ 別の組織が管理してるAPI ◦ 勝手に変更できない このまま負荷試験をするとどうなるか? → 外部APIに猛烈な負荷がかかる → 外部APIの死、課金増 などが発生
© DMM 負荷試験アーキテクチャ 6
© DMM 7 外部APIと同等の振る舞いを するサーバ →スタブサーバ 負荷試験アーキテクチャ
© DMM スタブサーバ • 外部のAPIと同等の振る舞いをするサーバ • 外部のAPI数が少なくて単純、OpenAPIなどの定義がある場合 • →普通に手作業で作ってもそこまで大変でない •
外部のAPI数が多い(10以上)、複雑、ドキュメントも充実してない場合 • 試験対象のコード(つまり外部APIに対するクライアント側)を見て実装する • →つらい • 外部APIに対するリクエスト/レスポンスをプロキシでキャプチャし、そこから生成 • →業務ではmitmproxyのキャプチャからスクリプトで生成した • https://mitmproxy.org/ • →行き当たりばったり 8
gstbgen
© DMM 10 gstbgen := “go stub server generator” スタブサーバのGoコードをいい感じに生成
負荷試験の面倒な作業を大幅短縮!!! https://github.com/teru01/gstbgen で公開中
© DMM gstbgenがやること 11 • SUTと外部APIの間に挟まるプロキシとなる • SUTと外部APIとのリクエスト・レスポンスを記録する • 記録が終わると、スタブサーバのGoコードを出力する
© DMM 使い方(1/4) 12 1. 適当なサーバにgstbgenを起動し、 SUTのフォワードプロキシとして 指定する $ export
http_proxy=http://xx.xx.xx.xx:yyyy $ export https_proxy=http://xx.xx.xx.xx:yyyy
© DMM 使い方(2/4) 13 2. ベンチマークサーバで負荷試験 シナリオを負荷にならない程度に 流す gstbgenにリクエスト/レスポンス の記録が溜まり始める
© DMM 使い方(3/4) 14 3. gstbgenを終了させると、記録 したリクエスト・レスポンスから スタブサーバのコードが出力される
© DMM 使い方(4/4) 15 4. 生成されたコードでスタブサーバ を起動し、SUTで外部APIとして 使う接続先をスタブサーバに向ける あとは負荷試験するだけ
© DMM ポイント1: いい感じのコード生成 • スタブサーバを生成するのではなく、スタブサーバのGoコードを生成 する • 自由に編集できる •
記録したHTTPのフローをそのまま再現するだけでは不適切な場合も あるため • コード生成にはdave/jenniferを利用 16 If(Id("i").Op("==").Id("j")).Block( Return(Id("i")), ) if i == j { return i }
© DMM コード生成 17 GET http://external.com/foo mux.HandleFunc("/foo", func(rw http.ResponseWriter, r
*http.Request) { if r.Method == "GET" { rw.WriteHeader(200) fmt.Fprint(rw, "{\"contents\":\"hello\"}") return } }) リクエスト レスポンス 200 OK {“contents”: “hello”}
© DMM 全体のコード生成イメージ host path method query param reqbody response
host path method query param reqbody response host path method query param reqbody response host path method query param reqbody response method query param reqbody response path method query param reqbody response mux.HandleFunc("/", func(rw http.ResponseWriter, r *http.Request) { body, _ := stringify(r.Body) if r.Method == "GET" { if q, _ := stringifyUrlValues(r.URL.Query()); q == "{}" { if body == "{\"token\":\"abc\"}" { rw.WriteHeader(200) fmt.Fprint(rw, "{\"foo\":\"bar\"}") return } } } if r.Method == "POST" { if q, _ := stringifyUrlValues(r.URL.Query()); q == "{}" { if body == "{\"token\":\"abc\"}" { rw.WriteHeader(200) fmt.Fprint(rw, "{\"foo\":\"bar\"}") return } } } }) mux.HandleFunc("/hoge", func(rw http.ResponseWriter, r *http.Request) { body, _ := stringify(r.Body) if r.Method == "GET" { if q, _ := stringifyUrlValues(r.URL.Query()); q == "{}" { if body == "{\"token\":\"abc\"}" { rw.WriteHeader(200) fmt.Fprint(rw, "{\"foo\":\"bar\"}") return } } } }) 溜まっていく 深さ優先でツリーを巡回して生成
© DMM ポイント2: HTTPS対応 • 普通、プロキシでHTTPS通信の中身は取得できない • 通信はE2Eで暗号化されている • 暗号化された通信内容は取得できる
• どうするか: サーバー証明書を偽造する • TLSをgstbgenで終端させて、SUTには偽の証明書を返す • 偽の証明書をSUTが信頼すれば良い • gstbgen側に持たせたCA証明書を信頼させる 19
© DMM 20 1 2 3 4 5
© DMM その他話してないこと • コマンドラインツール製作にはurfave/cli/v2を使用 • 引数の処理、自動help生成などが便利 • プロキシのベースとしてはelazarl/goproxyを使用 •
TLS、 証明書周りは標準ライブラリに入っている • crypto/tlsやcrypto/x509など • GoではOpenSSLに依存せず、自前実装している • そのためGoのスクリプトだけで鍵ペアを生成できる 21
© DMM おわりに • 負荷試験をはじめとするシステムの解析に使えるツールをGoで作成 • Google SREのプラクティス: 50%ルール •
業務時間の50%はソフトウェアエンジニアリングに使おう • パワーではなくてツールで解決することも重要 22
© DMM We are hiring! 大規模なサービスや新事業の立ち上げなど規模の大小、ジャンル・フェーズ が存在するDMM.comでSREを実践してみませんか? https://dmm-corp.com/recruit/engineer/8/
Thank You !