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
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
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
Claude Codeをどのように キャッチアップしているか
oikon48
13
8.8k
秘密度ラベル初心者が第1歩でつまづかないための「設計・運用」ポイント
seafay
PRO
1
460
自分が詳しくない領域でAIを使う #プロヒス2026
konifar
20
7.3k
水を運ぶ人としてのリーダーシップ
izumii19
4
950
コミットの「なぜ」を読む
ota1022
0
120
アジャイルな経理と Claude Code と経営の未来
kawaguti
PRO
3
190
Agile and AI Redmine Japan 2026
hiranabe
4
470
AIが自律的に回る開発ループを設計してチーム開発に組み込む
nekorush14
0
120
サイバーエージェントにおけるAI推進戦略と変革への取り組み
shotatsuge
0
490
時期が悪い!それでもRaspberry Piを買って遊んで活用するには / 20260627-osc26do-rpi-jikigawarui
akkiesoft
0
750
FPC(フレキシブル)基板にZephyr実装してみた。
iotengineer22
0
160
AIネイティブな開発のサプライチェーンリスク対策 〜激動の開発現場でリスクに立ち向かう〜【ZennFes】
cscengineer
PRO
2
150
Featured
See All Featured
Collaborative Software Design: How to facilitate domain modelling decisions
baasie
1
250
Refactoring Trust on Your Teams (GOTO; Chicago 2020)
rmw
35
3.5k
What does AI have to do with Human Rights?
axbom
PRO
1
2.2k
Max Prin - Stacking Signals: How International SEO Comes Together (And Falls Apart)
techseoconnect
PRO
0
190
How To Speak Unicorn (iThemes Webinar)
marktimemedia
1
490
個人開発の失敗を避けるイケてる考え方 / tips for indie hackers
panda_program
123
22k
Designing for humans not robots
tammielis
254
26k
Automating Front-end Workflow
addyosmani
1370
210k
The Curse of the Amulet
leimatthew05
2
13k
The #1 spot is gone: here's how to win anyway
tamaranovitovic
2
1.1k
How to Create Impact in a Changing Tech Landscape [PerfNow 2023]
tammyeverts
55
3.4k
What the history of the web can teach us about the future of AI
inesmontani
PRO
1
620
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