網站首頁 編程語言 正文
Jmeter簡介
Jmeter是Apache開源的一個使用純Java編寫的壓力測試工具,它最初是為測試web應用程序而設計的,但后來擴展到了其他測試功能。例如,可用于測試靜態和動態資源以及web動態應用程序的性能等。Jmeter可以用來模擬對服務器、服務器組、網絡或對象上的重負載,以測試其強度或分析服務在不同負載類型下的總體性能。
如今Jmeter是一個主流的、功能完善且強大的壓測工具,由于是使用Java編寫的,所以具有跨平臺特性,可以運行在Windows、Mac、Linux等操作系統上。并且支持豐富的協議,如:HTTP/HTTPS、FTP、JDBC、SOCKET、SOAP。。。等,此外還有許多第三方插件支持以及第三方集成
前言
surging是異構微服務引擎,提供了模塊化RPC請求通道,引擎在RPC服務治理基礎之上還提供了各種協議,并且還提供了stage組件,以便針對于網關的訪問, 相對于功能,可能大家更想知道能承受多大的并發,大家也會各自進行壓測,當碰上一些問題,導致壓測結果不理想就會扣帽子給框架引擎,這個性能不行,那么上一個帖子回應了@wen-wen 所貼的壓測報告,針對于壓測結果,很多人不明所以,都是以一筆帶過的方式告訴大家結果,那么這次從頭至尾,把環境和測試過程進行梳理,通過此篇文章進行發布,也請各大同行監督。
環境
處理:Intel(R) Core(TM) i7-8750H CPU @ 2.20GHz 2.20 GHz
內存:16.0 GB
語言:.NET 6.0
下載配置源碼
1.通過surging 下載最新的源碼, 下載完之后,選擇測試ManagerService 模塊服務中的Say服務,而測試的代碼也比較簡單,就是返回一字符串,代碼如下
public async Task<string> Say(string name)
{
return await Task.FromResult($"{name}: say hello");
}
2. 把日志級別提高,因為這會影響性能,比如設置的info 就要比error 級別低三倍,以測試的日志配置為例,測試使用的是NLog, 在Nlog.config 下把coloredConsole改成error級別,代碼如下
<?xml version="1.0" encoding="utf-8" ?> <nlog xmlns="http://www.nlog-project.org/schemas/NLog.xsd" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> <targets> <target name="coloredConsole" xsi:type="ColoredConsole" useDefaultRowHighlightingRules="false" layout="${longdate}|${pad:padding=5:inner=${level:uppercase=true}}|${message}" > <highlight-row condition="level == LogLevel.Debug" foregroundColor="DarkGray" /> <highlight-row condition="level == LogLevel.Info" foregroundColor="Gray" /> <highlight-row condition="level == LogLevel.Warn" foregroundColor="Yellow" /> <highlight-row condition="level == LogLevel.Error" foregroundColor="Red" /> <highlight-row condition="level == LogLevel.Fatal" foregroundColor="Red" backgroundColor="White" /> </target> <target name="file" xsi:type="File" archiveAboveSize="10240" layout="${date}|${level:uppercase=true}|${message} ${exception}|${logger}|${all-event-properties}" fileName="c:\surging1\${level}\_${shortdate}.log" /> </targets> <rules> <logger name="*" minlevel="error" writeTo="file" /> <logger name="*" minlevel="error" writeTo="coloredConsole" /> </rules> </nlog>
3. release類型下 發布server,之后通過dotnet Surging.Services.Server.dll 命令進行運行,運行成功之后,通過瀏覽器是否可訪問
JMeter和JDK下載
1、JMeter下載地址:http://jmeter.apache.org/download_jmeter.cgi
2、JDK下載地址:https://www.oracle.com/technetwork/cn/java/javase/downloads/index.html
JDK+Jmeter安裝
1、windows安裝(以win 7為例)
1、 安裝jdk、配置java環境變量(步驟略)
2、 解壓apache-jmeter-2.13.zip到D盤
3、 桌面選擇“計算機”(右鍵)--高級系統設置--環境變量
4、 在”系統變量“---”新建“,在變量名中輸入:JMETER_HOME,變量值中輸入:D:\apache-jmeter-2.13
5、 修改CLASSPATH變量,變量值中添加 %JMETER_HOME%\lib\ext\ApacheJMeter_core.jar;%JMETER_HOME%\lib\jorphan.jar;%JMETER_HOME%\lib\logkit-2.0.jar; 再點確定。
6、 進入到D:\apache-jmeter-5\bin下運行jmeter.bat即可打開JMeter
Jmeter非GUI運行壓測
創建配置jmx 文件
1. 新增Thread Group
配置thread group的user thread為2000
2. 在thread group 下新增Http Request
配置Http Request,壓測接口為http://localhost:281/api/manager/say?name=fanly,記得勾上Use KeepAlive
3. 然后點擊save as 達到D:\
4.運行jmeter 控制臺進行壓測,代碼如下
jmeter -n -t D:\HTTP.jmx -l D:\read.csv -e -o D:\ResultReport
5. 運行結果如下
以上看不懂,可以把生成的read.csv 加載到jmeter 生成報告進行查看,如下圖
從以上圖可以看出surging 的http 壓測的吞吐量是12589/s
結尾
也歡迎同行,粉絲,客戶們可以按照以上的配置方式進行壓測,也提醒各位不要開啟info 級別日志,因為這會造成性能上大幅降低,壓測只有4000/s ,只有error 級別差不多1/6 ,也透露下surging 后續會提供平臺可視化,以下是部分模塊
原文鏈接:https://www.cnblogs.com/fanliang11/p/16488905.html
相關推薦
- 2022-06-19 C++深入探究引用的本質與意義_C 語言
- 2023-02-28 ts之 Mixin混入(ts對象的混入、類的混入)
- 2023-07-07 maven項目如何引入項目本地jar包
- 2023-03-22 nginx.conf配置兩個前端路徑_nginx
- 2022-05-23 python中的netCDF4批量處理NC文件的操作方法_python
- 2022-09-29 關于react?ant?組件?Select下拉框?值回顯的問題_React
- 2022-05-23 React中setState同步異步場景的使用_React
- 2022-10-16 Python3列表刪除的三種方式實現_python
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支