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
Recommendation_of_Gatling.pdf
Search
Sponsored
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
cupper
July 10, 2020
Technology
560
2
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
Recommendation_of_Gatling.pdf
cupper
July 10, 2020
More Decks by cupper
See All by cupper
kintoneでAWSリソースを管理する
cupperservice
0
110
History of HTTP
cupperservice
0
86
Let's get started with Scala
cupperservice
0
400
All in Scala
cupperservice
0
56
Golang on AWS
cupperservice
0
49
What's scala.js?
cupperservice
0
59
How to work in local
cupperservice
0
63
Make a REST Server on Golang
cupperservice
0
95
Why do you use JavaScript
cupperservice
0
35
Other Decks in Technology
See All in Technology
不要なレビューをAIにまかせて AIコーディングの環境改善を加速した
shoota
1
260
インシデントレスポンス演習 I / Incident Response Exercise I
ks91
PRO
0
110
現場のトークンマネジメント
dak2
1
170
FPC(フレキシブル)基板にZephyr実装してみた。
iotengineer22
0
160
SONiCで構築・運用する生成AI向けパブリッククラウドネットワーク ~実装編~
sonic
0
340
起点・思考・出力で分解する 〜PM業務の自動化設計〜
kazu_kichi_67
1
1k
クラウドファンディング版StackChan 3体(4体)をインタラクティブな体験型作品にして展示もした話 / スタックチャンお誕生日会2026
you
PRO
0
180
技術・能力を向上する原理原則 #きのこセッションa #きのこ2026
bash0c7
0
110
AIが自律的に回る開発ループを設計してチーム開発に組み込む
nekorush14
0
120
事業会社における 機械学習・推薦システム技術の活用事例と必要な能力 / ml-recsys-in-layerx-wantedly-2026
yuya4
0
160
脱SaaS!FDEを支えるプロビジョニングと分離設計
knih
0
260
AIAU_UMEMOGU_ninomiya_slide
ninomiya_ii
0
260
Featured
See All Featured
Faster Mobile Websites
deanohume
310
32k
Odyssey Design
rkendrick25
PRO
2
700
The Impact of AI in SEO - AI Overviews June 2024 Edition
aleyda
5
1.1k
Test your architecture with Archunit
thirion
1
2.3k
Conquering PDFs: document understanding beyond plain text
inesmontani
PRO
4
2.8k
10 Git Anti Patterns You Should be Aware of
lemiorhan
PRO
659
62k
Why You Should Never Use an ORM
jnunemaker
PRO
61
9.9k
Self-Hosted WebAssembly Runtime for Runtime-Neutral Checkpoint/Restore in Edge–Cloud Continuum
chikuwait
0
610
Crafting Experiences
bethany
1
190
Lessons Learnt from Crawling 1000+ Websites
charlesmeaden
PRO
1
1.3k
ReactJS: Keep Simple. Everything can be a component!
pedronauck
666
130k
First, design no harm
axbom
PRO
2
1.2k
Transcript
Gatling Recommendation of gatling
今日やること
Gatlingいいぞ! あるプロジェクトの負荷試験でGatlingというツールを使ってみた。 https://gatling.io/ 良いツールなので社内に普及させたい!
自己紹介
あんただれ? • 名前 :川嶋 一寿 • チーム :sst(sstってなんのこと?) • 生息地 :静岡県静岡市 • 趣味 :酒、ジョギング
• 好きな言語 :Scala • その他 :専門学校講師、Scalapediaの記事執筆 • Twitter :@cupperservice
Gatlingってなに?
Gatlingとは GatlingはHTTPサーバのための負荷テストツールの一種 負荷テストツールは他にも多くのツールが存在する • JMeter • Locust • ab •
etc... awesome-http-benchmark 主要なツールについてまとめられている
JMeter https://jmeter.apache.org/
Locust https://locust.io/
シナリオは スクリプトで!
シナリオをスクリプトで書けるもの 名前 スクリプトの種類 ライセンス Gatling Scala Apache 2.0 Locust Python
MIT Artillery JavaScript MPL2 k6 JavaScript AGPL3 wrk Lua Apache 2.0
なぜGatling?
Locustは嫌だ!
Locustの問題 去年からシステムの限界性能の測定のためにLocustを使用していたが、測定に非常に 時間がかかる問題があった。 測定時間10分のデータを取るために1時間ほどの作業が必要だった。
Problem 1 手動でユーザー数を変更しrps, response time, cpu利用率等を観測しながら同時に 実行するユーザー数の限界値を決めるため、測定に多くの時間を必要とした。 以下の手順で限界性能を測定していた。 1. 以前の計測結果からユーザー数を決定して測定
(測定時間: 1分程度) 2. CPUに余裕があり、レイテンシーが悪化していなければユーザー数を増やして再度 測定 3. CPUに余裕がなかったり、レイテンシーが悪化した場合は、ユーザー数を減らして 再度測定 4. 一番性能が良いユーザー数で再度測定 (測定時間: 10分程度)
Problem 2 テストの経過時間を軸にしたデータ(rpsやresponse time)がレポートに出力されないた め、ある時点で問題があってもレポートを取得した時点で問題がなければレポートから 判断できない。 画面には表示されているため、必要であればスクリーンショットを採ってエビデンスにす る。(スクリーンショット職人になりたいなら問題ない)
Problem 3 テストの実施時間を指定できない。 実施時間を確認し手動でテストを停止する必要がある。 そのため、テストを流しておいて他の作業をすることが難しい。(テストを止めるのを忘れ る可能性がある) 長時間ランニングテストの場合は、夜間流しておいて朝に手動で停止した。
Problem 4 Pythonのインデント構文が肌に合わない @task(1) def scenario1(self): response = self.login("login_id00", "password00")
token = response["token"] print(token) self.logout(token) こういうの書けない Dottyはインデント構文サポートするんだよね。。。
他のツールを探す
Locust以外のツールを探す! 次の条件に当てはまるツールを探した。 • シナリオをスクリプトで書くことができること • 十分な負荷をかけることができること • 詳細なレポートが出力されること
Locust以外のツールを探す前に。。。 Scalaでシナリオを書くツールを作ろうと思っていた。。。 すでにあった。。。
Gatlingは使えそう! • 次の条件はクリアしている ◦ シナリオをスクリプトで書くことができること ◦ 十分な負荷をかけることができること ◦ 詳細なレポートが出力されること •
お客様の他のプロジェクトでも使っているそうなので、使うこと に問題はなさそう 面倒な調整不要!
検証結果
ちまちました作業が不要! 以下のシナリオを用意することで、作業時間を短縮 ・5日かかっていた作業を2日に短縮(予定) • 測定するユーザー数の最小値と最大値を決める • ユーザー数を最小値から最大値まで徐々に増やしながら測定 ユーザー数の範囲が100〜4,000 10秒ごとに100ユーザーずつ増やして測定 このシステムの限界値は
ユーザー数 4,000 RPS 10,000 rps
Gatlingの特徴
商用利用 • OSS版とEnterprise版がある • OSS版のライセンスはApache 2.0 • OSS版で利用できない機能 ◦ 分散モード
◦ モニタリング項目(TCP connection, DNS resolutions, ...) ◦ ライブレポート ◦ 実行履歴の管理 ◦ LDAP認証 ◦ 他
マルチスレッド • JavaVM上でマルチスレッドで動作する locustはシングルスレッド • Akka / Nettyを使った非同期処理
シナリオ シナリオはScalaで記述する package cupper.scenario import io.gatling.core.Predef._ import io.gatling.http.Predef._ import scala.concurrent.duration._
class FirstTest extends Simulation { val protocol = http .baseUrl(http://localhost:3000) .headers(Map( HttpHeaderNames.ContentType -> HttpHeaderValues.ApplicationJson, HttpHeaderNames.UserAgent -> "gatling" )) val user1 = scenario("first test") .exec(http("get movies") .get("/movies") .check(status.is(200)) ) setUp(user1.inject(rampUsers(1000) during(30 seconds)).protocols(protocol)) }
レポート とても素敵なグラフィカルなレポートが作成される。 OSS版でも同じ!
多くの測定パターン • ユーザー数の指定 • 実施回数指定 • 期間内のユーザー数の分布(一定、ランダム) • 実施時間の指定 •
経過時間とともにユーザー数を増やす
Closed/Open Workload Models • Closed Workload Model 一定数のユーザーが連続的にリクエストを発行するケース。 同じユーザーからのリクエストは、前のリクエストが完了した後に発行される。 社内システムなど同時ユーザー数を制限するシステムに対するテストで有効
• Open Workload Model システムが現在処理しているリクエスト数に関係なくユーザーがリクエストを発行す るケース。 同時ユーザー数を宣言できないシステムに対するテストで有効 多くの一般向けのWebサイトのテストで有効
Jenkinsとの連携 Jenkinsと連携してGatlingを起動することができる
分散構成 複数のマシンを使用してGatlingを実行できる。 [Enterprise版] クラウド環境(AWS, GCP, Azureなど)にインスタンスをデプロイし てテスト終了後にインスタンスを閉じる機能が提供されている。 [OSS版] 自分でスクリプトを組む必要がある。
Scala...難しそう
怖がらなくても大丈夫! • とっても簡単(Easy) • モナドとか圏論とかわからなくても大丈夫 公式ページにも下のように書かれている Gatling simulation scripts are
written in Scala, but don’t panic! You can use all the basic functions of Gatling without knowing much about Scala. In most situations the DSL will cover most of your needs and you’ll be able to build your scenarios.
Sample
Sample code package cupper.scenario import io.gatling.core.Predef._ import io.gatling.http.Predef._ import scala.concurrent.duration._
class FirstTest extends Simulation { val protocol = http .baseUrl(http://localhost:3000) .headers(Map( HttpHeaderNames.ContentType -> HttpHeaderValues.ApplicationJson, HttpHeaderNames.UserAgent -> "gatling" )) val user1 = scenario("first test") .exec(http("get movies") .get("/movies") .check(status.is(200)) ) setUp(user1.inject(rampUsers(1000) during(30 seconds)).protocols(protocol)) } ベースURL 共通のリクエストヘッダー テストシナリオ リクエストURL レスポンスの確認 シナリオのシミュレーション 30秒間で1,000ユーザーがシナリ オを実行する Simulationをextends
Execution result
Concepts
Main concepts Name Description Virtual User シナリオを実行するユーザーを表す 独自のデータ(パラメータやCookieなど)を持つ Scenario ユーザーの行動を表す一連の操作を記述する
Simulation どのように負荷をかけるのかを記述する Session ユーザーごとのデータ Feeders 外部(ファイルなど)からSessionにデータを注入する Checks レスポンスをチェックしたり、チェック結果を Sessionに格納する Assertions テストの成否条件を記述する
Demo
シナリオ テスト対象は以下のシナリオ オープンモデルで限界値を測定する 1. ECサイトにログイン 2. 商品を検索 3. 商品の内容を確認 4.
ショッピングカートに登録 5. 購入 or 取り消し 6. ログアウト Github: https://github.com/cupperservice/gatling-sample
必要なソフトのインストール Gatlingを実行するには以下が必要 • Java 64 bit Open JDK 8 ro
Open JDK 11 • sbt 0.13.6以上 今回はSDKMANを使ってインストールする
注意点
OS Turning GatlingはFDを多く消費するため、OSのチューニングが必要 チューニング内容は参照URLを参照
Session is immutable Sessionはimmutable exec(session => { session.set(“key1”, “value1”) session.set(“key2”,
“value2”) }) exec(session => { session .set(“key1”, “value1”) .set(“key2”, “value2”) }) exec(session => { session.setAll( (“key1” -> “value1”), (“key2” -> “value2”)) }) NGなコード key1の値は無効 OKなコード
コネクション注意! shareConnectionsを有効にしたほうが良いかも。。。 Gatlingは仮想ユーザーごとにコネクションプールを持つ。 これが原因かはわからないが、shareConnectionsを有効にしな いと十分な負荷がかからなかった。
今後の課題
テストの中断 Assertionsでテストの成否は判定することができる。 しかし、テストを中断することはできない。 ↓↓↓ システムの限界を超えた負荷をかけ続けることになる。無駄 ↓↓↓ テストに失敗(例えば、500系のステータスコードが帰った場合な ど)した場合、その後のテストを中断する仕組みを入れたい。
分散構成の自動化 OSS版で分散構成を組むにはスクリプトを組む必要がある。 ↓↓↓ 非常に面倒くさい! ↓↓↓ Enterprise版のように自動で必要なEC2インスタンスを立ち上げ て、Gatlingを実行するようにしたい。
最後に
これを機にScala使ってみない? 2020年度内にScala 3がリリースされる予定 ロードマップ 興味のある方がいれば勉強会を開きます! こちらもよろしく! scalapedia
Thank you for listening