当前位置:网站首页>Load test practice of pingcode performance test
Load test practice of pingcode performance test
2022-07-04 17:13:00 【InfoQ】
What is performance testing
The type of performance test
- The load test: Usually, the purpose of load testing is to understand the behavior of the system under a specific expected load . This load can be the expected number of concurrent users on the application , The application executes a specific number of transactions within a set duration . This test will give the response time of all important business critical transactions . The database will also be monitored during the test 、 Application server, etc , This will help identify bottlenecks in the application software and the hardware where the software is installed
- Pressure test: It is usually used to understand the capacity limit in the system . This test is conducted to determine the robustness of the system in terms of extreme loads , And help application administrators determine if the current load is much higher than the expected maximum , Whether the system can operate fully .
- Soak Test: Also known as durability test , It is usually used to determine whether the system can withstand the continuous expected load . During the soak test , Memory utilization is monitored to detect potential leaks . Equally important but often overlooked is performance degradation , That is to ensure that the throughput and response time after a long period of continuous activity are as good or better as at the beginning of the test . It essentially involves putting a lot of load on the system over a long period of time . The goal is to find out how the system behaves under continuous use .
- Peak test: By suddenly increasing or decreasing the load generated by a large number of users , And observe the behavior of the system to complete . The goal is to determine whether performance will be affected , The system will fail , Still able to deal with drastic changes in load .
- Breakpoint test: Breakpoint testing is similar to stress testing . Apply incremental loads over time , At the same time, the predetermined fault conditions of the monitoring system . Breakpoint testing is sometimes called capacity testing , Because it can be said that it determines the maximum capacity that the system will perform according to its required specifications or service level agreements . The breakpoint analysis results applied to the fixed environment can be used to determine the best expansion strategy according to the required hardware or the conditions that should trigger the horizontal expansion event in the cloud environment .
- Configuration testing: Instead of testing performance from a load perspective , Instead, create tests to determine the impact of configuration changes to system components on system performance and behavior . A common example is trying different load balancing methods .
- Isolation test: Isolation testing is not unique to performance testing , It involves repeating tests that cause system problems . Such a test can usually isolate and confirm the fault domain .
Basic process of performance test
data:image/s3,"s3://crabby-images/53213/53213697fcd5fd88c4540c372fedba46f8dd0e10" alt="null"
- Determining the test environment : By identifying available hardware 、 Software 、 Network configuration and tools , The test team can design tests and identify performance test challenges as early as possible . Performance test environment options include :
- Determine performance indicators : In addition to determining the response time 、 Throughput, constraints and other indicators , Also determine the success criteria for performance testing , According to the regulations of the team in the project .
- Plan and design performance tests : Considering the variability of users 、 Performance test scenarios for testing data and target metrics , You can create one or two models .
- Configure test environment : Prepare the test environment machines and tools needed to monitor resources .
- Develop test scripts
- Execute test plan : Running performance tests , Monitor and capture the generated data .
- analysis 、 The report 、 To test : Analyze the data and share the performance conclusions . Run the performance test again with the same parameters and different parameters .
Performance testing tools
- JMeter: It's a Apache Performance testing tools , It can be done to Web Load test with application services . JMeter Plug ins provide flexibility in load testing , And covers graphics 、 Thread group 、 timer 、 Functions and logic controllers . JMeter Support integrated development environment (IDE), For browser or Web Test the application , And for load testing based on Java Command line mode of the operating system .
- LoadRunner: from Micro Focus Development , Used to test and measure the performance of applications under load . LoadRunner It can simulate thousands of end users , And record and analyze the load test . As part of the simulation , The software generates messages between application components and end-user actions , Similar to key click or mouse movement . LoadRunner It also includes cloud oriented versions .
- NeoLoad: from Neotys Development , by Web And mobile applications to provide load and stress testing , Designed to test applications before release to achieve DevOps And continuous delivery IT The team can use this program to monitor Web、 Database and application server . NeoLoad It can simulate millions of users , And perform tests internally or through the cloud .
Performance test indicators
- throughput : How many information units does the system process in a specified time .
- response time : The amount of time elapsed between the request entered by the user and the system beginning to respond to the request .
- bandwidth : The amount of data that can be moved between workloads per second , Usually refers to through the network .
- Per second CPU Interruption times : The average value is taken . Refers to the number of hardware interrupts received and processed by the processor per second .
- Memory usage : The amount of physical memory available to processes on the computer .
- Disk usage : The amount of time the disk is busy executing read or write requests
A non systematic performance test practice
Test type
Test range
- Sub products involved : Project , Testhub , Wiki , Insight , Goals , Flow 6 Sub products .
- Basic services :Typhon service
Test purpose
- Ensure the reliability of the system in the case of multiple users : By implementing different performance test scenarios , Evaluate and verify the reliability of the core functions of the system under high load .
- Provide a round of system performance test , Provide baseline data for the next round of production environment performance testing .
- Evaluate the rationality of system deployment resources : Continuously collect and analyze performance test process data , Evaluate and make suggestions on the system resources required for the next system deployment .
- Optimize and solve system performance problems : During the test , Optimize the parameters of the system and solve the system performance problems found .
Test index standard
- According to the number of online users provided by operation and maintenance , To calculate the users of the production environment TPS, Pass the test of benchmark environment , To verify the real TPS Whether it meets the requirements of the production environment TPS demand , And whether our operation and maintenance structure and resource use are reasonable .
- Guaranteed at CPU The utilization rate is less than 80%, Memory less than 80%, And there is no mistake Http request .
Test practice
Testing tools
- use Jmeter + Grafana + Influxdb To complete the performance test .
- Jmeter GUI GUI tools : In order to facilitate development and debugging , Use the graphical interface to write the required test plan .
- Jmeter NO-GUI Pattern : Support large load test scenarios 、 Improve the efficiency of script execution and facilitate the subsequent configuration of scripts to Jenkins To achieve continuous integration on , Make automated testing .
Environment building
- install Java Of Jdk, Version follows Jmeter Version corresponding .
- install Jmeter Tools
Jmeter The value of the number of passes in the center line is based on
- First of all, understand the number of users 、 Number of threads 、TPS
data:image/s3,"s3://crabby-images/4507f/4507fac252cc948143f792a35dd94316967c28a7" alt="null"
- adopt TPS Calculate the number of threads of the press according to the benchmark
data:image/s3,"s3://crabby-images/ffd2b/ffd2b1cf20b1e2f00194134e28435230b4dd95fa" alt="null"
Jmeter Project directory structure
data:image/s3,"s3://crabby-images/a413f/a413f33007d6afe748a3f82149a71f1713dafd15" alt="null"
bin
templates
jmeter.properties
data:image/s3,"s3://crabby-images/d2476/d247696bd2f971f4629520937e4783327f9bd52f" alt="null"
templates.xml
data:image/s3,"s3://crabby-images/8c111/8c111637df6af0701b16f0ef3737ef2d267ae971" alt="null"
data:image/s3,"s3://crabby-images/7b488/7b488b6cce5248627fde28d4f7ff4597befda9da" alt="null"
Project preparation and configuration file modification
pc-perf
cd jmeter/bin
git clone [git Project address ]
- common Folder : It is used to store the test plan template and template configuration file templates.xml.
- Sub application directory : And common The peer directory is the sub application directory , As the goal Goals、 project Project etc. . This directory is used to store the corresponding .jmx Test plan file .
template.files = /bin/pc-perf/common/templates/templates.xml
JMeter Template development
data:image/s3,"s3://crabby-images/a5616/a561617f80b8aa7cb314ce515e0649a2d7469cf2" alt="null"
data:image/s3,"s3://crabby-images/62a74/62a7409e2fb54c5486bf69e6f145547d915ac1e9" alt="null"
data:image/s3,"s3://crabby-images/1d35e/1d35ea30d7cf10939315d4b85eee955cf726f6b8" alt="null"
data:image/s3,"s3://crabby-images/25550/25550ddac1f7db00abcc46e45137eb4e9a09dce5" alt="null"
data:image/s3,"s3://crabby-images/8cbb1/8cbb136bec36423e7a9b378d0da8819a13963c47" alt="null"
data:image/s3,"s3://crabby-images/e269e/e269e8a19830de645f1f6c7b36869ce790e5da37" alt="null"
- Open browser developer tools
data:image/s3,"s3://crabby-images/85837/858372aa4203f7c187170ef901c1ddb795a123c1" alt="null"
- obtain signin Information
data:image/s3,"s3://crabby-images/7ed3c/7ed3c98bebab9ea530d274a8a55cec236434e5c1" alt="null"
fetch("http://at.pingcode.fun/**/signin",
{
"credentials":"include",
"headers":{
"accept":"application/json, text/plain, */*",
"accept-language":"zh-CN,zh;q=0.9",
"content-type":"application/json"
},
"referrer":"http://at.pingcode.fun/signin",
"referrerPolicy":"no-referrer-when-downgrade",
"body":"{\"signin_name\":\"**\",\"password\":\"**\",\"captcha_code\":\"\"}",
"method":"POST",
"mode":"cors"
});
data:image/s3,"s3://crabby-images/fc018/fc018e96cd212dd5ebebeaa5ee691b6229bc1bf4" alt="null"
data:image/s3,"s3://crabby-images/bdcbf/bdcbf530fe0a073f881a6e919131e26314b7b06e" alt="null"
- You can use the previous step in the developer tool of the browser Copy request headers Get the complete request header information
data:image/s3,"s3://crabby-images/f8cf5/f8cf51d411f04e470cb53d53750622d938032654" alt="null"
- It comes with components “ Add... From the clipboard ” function , One click configuration request header information
data:image/s3,"s3://crabby-images/e0007/e00074ac663c89620a985098841ce5b9f4e15785" alt="null"
data:image/s3,"s3://crabby-images/d6739/d673963064348fddab1a800eb2c4611a2c482ec3" alt="null"
data:image/s3,"s3://crabby-images/41bbe/41bbe15db1073c8829d6c7e34aa444658d3f7ed6" alt="null"
data:image/s3,"s3://crabby-images/921f7/921f7b1a0534e622d3fe485d4b63d6b6e6a6cf63" alt="null"
data:image/s3,"s3://crabby-images/ac572/ac572e0a6d0df26804ad549b9dfb64346532465e" alt="null"
data:image/s3,"s3://crabby-images/23874/23874c4c223c016cd1c3bf094088c28cb3a7cb10" alt="null"
- Use Javascript Language to write scripts
data:image/s3,"s3://crabby-images/0c639/0c63951a64459c716f56c0fde4ea916a77c73406" alt="null"
- Extract users 、 The team 、token Information
data:image/s3,"s3://crabby-images/795ee/795ee04e1208a3812a9c7ff121688e38ea7e0d4c" alt="null"
// here loginResponse_1 It's from JSON The debugging results of the extractor can be obtained
var loginResponseString = vars.get("loginResponse_1")
var loginResponse = JSON.parse(loginResponseString)
log.info("loginResponseString:"+ loginResponseString)
// Set variables in this thread group
vars.put("user", JSON.stringify(loginResponse.user))
vars.put("team", JSON.stringify(loginResponse.team))
vars.put("access_token", loginResponse.access_token)
data:image/s3,"s3://crabby-images/3c66d/3c66d13c1e1f720abe1b4f976b49a05c3f80f59f" alt="null"
data:image/s3,"s3://crabby-images/b90d3/b90d36b79aa69c0a123b0daf79a7a86433a1b77c" alt="null"
// Will the user 、 The team 、token Information is declared as global variables , Used for later thread groups
${__setProperty(user, ${user})}
${__setProperty(team, ${team})}
${__setProperty(access_token, ${access_token})}
data:image/s3,"s3://crabby-images/7e546/7e546f93ec720e7940dde0ee20b31d13b14660a9" alt="null"
data:image/s3,"s3://crabby-images/7255b/7255b42b80c918c4bdfbef53d0d377d52e326be6" alt="null"
data:image/s3,"s3://crabby-images/4e7bc/4e7bc209674874fc121cc187a6220da5a41135c3" alt="null"
data:image/s3,"s3://crabby-images/c5fe3/c5fe3cd9c76e69817424779bc1cf5cc477ef9755" alt="null"
data:image/s3,"s3://crabby-images/6b1bc/6b1bcbb8ef5d11b34e70072399ea7b310866613a" alt="null"
data.value
loginResponse_1
- Modify user parameter processor
data:image/s3,"s3://crabby-images/8f9a4/8f9a4b24b137e8f34953f76c04b1dae8b4f8eaa2" alt="null"
data:image/s3,"s3://crabby-images/0d4be/0d4bee54aa3919245b63b0819c8daf6a5116efdc" alt="null"
Local variable calling method :
Use... In components :${key}
Use in script :vars.get(key)
- modify BeanShell Preprocessor
data:image/s3,"s3://crabby-images/9c37b/9c37bdc60fd6ae8fe05db50b7b56202577037f8a" alt="null"
data:image/s3,"s3://crabby-images/4d445/4d445026c01a4182d139ec99c74e21fe5372a90a" alt="null"
How to call global variables :
Use in components :${__P(key)}
Use... In scripts :props.get(key)
data:image/s3,"s3://crabby-images/37bfe/37bfea1c6e11ef85751588fe15cf06e30685c0a8" alt="null"
data:image/s3,"s3://crabby-images/b91f5/b91f5efc1026e5aa3a5b4a4d1f13b8cdf1caf204" alt="null"
data:image/s3,"s3://crabby-images/81b90/81b9090d001d79389cca66ac2e64b14a0e70cfe6" alt="null"
data:image/s3,"s3://crabby-images/66b8e/66b8ed33d037a730c6234660be8a30dc6718b090" alt="null"
data:image/s3,"s3://crabby-images/f04fd/f04fd6f419c9ff6734fa9d59524cfd61b1a8d3d9" alt="null"
data:image/s3,"s3://crabby-images/ad2a2/ad2a2e3ae35c7357469a555ae123f574f2d5c2fa" alt="null"
data:image/s3,"s3://crabby-images/b2d4e/b2d4eae98f387b95cf81f3045d1fdfa5eed40735" alt="null"
data:image/s3,"s3://crabby-images/47fec/47fec8304b70e9eb12c5ba08b126ea00afbc29c7" alt="null"
data:image/s3,"s3://crabby-images/c5ed7/c5ed71420602037162400e8b28d2bc3ab5758a9b" alt="null"
name: Template name , Used to display in the template list
fileName: The path of the test plan to be configured as a template
description: Template description
parameters: Template parameters , You can use the template UI Page to page test plan .jmx File dynamic transfer parameters .
data:image/s3,"s3://crabby-images/e65cd/e65cd660fa03f9037100aa46faaad3098f7b148d" alt="null"
adopt [=key] Receive template parameters in the form of
Development sub application API test plan
data:image/s3,"s3://crabby-images/b3d5c/b3d5c982aeb551e07aa3307759557267ebac612d" alt="null"
data:image/s3,"s3://crabby-images/a2e77/a2e772c760b9cd708f0bb7b8b94806ea196c83f3" alt="null"
data:image/s3,"s3://crabby-images/a721a/a721af90b97ac2874f273f29eea2856c9aa5df59" alt="null"
adopt Non-GUI Way to execute all test plans
jmeter -n -t <testfile> -l <logfile>
Example :jmeter -n -t test.jmx -l test.jtl
Explain : Run on the command line test.jmx Script and generate test.jtl Log report .
-h Print usage information and exit
-n Not GUI Pattern -> In Africa GUI Run in mode JMeter
-t The test file < Parameters > -> To run jmeter test (.jmx) file .
-l Log files < Parameters > -> Generated log files
-H Set the... To use JMeter proxy server
-P Set the... To use JMeter Proxy port
data:image/s3,"s3://crabby-images/63535/63535650199ffa7f8e6d2cc1705050b66c814304" alt="null"
Information
- wikipedia : https://en.wikipedia.org/wiki/Software_performance_testing
- Jmeter: https://jmeter.apache.org/
- LoadRunner: https://en.wikipedia.org/wiki/LoadRunner
- NeoLoad: https://www.tricentis.com/products/performance-testing-neoload/
边栏推荐
- Statistical learning: logistic regression and cross entropy loss (pytoch Implementation)
- 周大福践行「百周年承诺」,真诚服务推动绿色环保
- 表单传递时,如何隐式将值传过去
- Kunming Third Ring Road Closure project will pass through these places. Is there one near your home?
- 跳跃表实例
- GO开发:如何利用Go单例模式保障流媒体高并发的安全性?
- 51 single chip microcomputer temperature alarm based on WiFi control
- 程序员怎么才能提高代码编写速度?
- 2022年国内云管平台厂商哪家好?为什么?
- 第十八届IET交直流输电国际会议(ACDC2022)于线上成功举办
猜你喜欢
NoSQL之readis配置与优化(终章)
太方便了,钉钉上就可完成代码发布审批啦!
Analysis of abnormal frequency of minor GC in container environment
一加10 Pro和iPhone 13怎么选?
overflow:auto与felx结合的用法
照明行业S2B2B解决方案:高效赋能产业供应链,提升企业经济效益
Position encoding practice in transformer
Difference between redis' memory obsolescence strategy and expiration deletion strategy
The winning rate against people is 84%, and deepmind AI has reached the level of human experts in army chess for the first time
整理混乱的头文件,我用include what you use
随机推荐
APOC自定义函数和过程
Transformer中position encoding实践
周大福践行「百周年承诺」,真诚服务推动绿色环保
Is it safe to open an account online
Research Report on market supply and demand and strategy of China's Sodium Tetraphenylborate (cas+143-66-8) industry
容器环境minor gc异常频繁分析
跳跃表实例
力扣今日题-1200. 最小绝对差
C implementation defines a set of intermediate SQL statements that can be executed across libraries
Visual Studio 2019 (LocalDB)MSSQLLocalDB SQL Server 2014 数据库版本为852无法打开,此服务器支持782
Go语言循环语句(第10课下)
Configuration instance of Oracle listener server and client
PingCode 性能测试之负载测试实践
昆明三环闭合工程将经过这些地方,有在你家附近的吗?
Difference between redis' memory obsolescence strategy and expiration deletion strategy
【模板】【luogu P4630】Duathlon 铁人两项(圆方树)
世界环境日 | 周大福用心服务推动减碳环保
Firebird experience summary
安信证券属于什么档次 开户安全吗
MVC模式和三层架构