Home Backend Development Golang Golang Learning Web Application Performance Testing Practice

Golang Learning Web Application Performance Testing Practice

Jun 24, 2023 am 11:18 AM
golang Performance Testing web application

Golang Learning Web Application Performance Testing Practice

With the development of the Internet era, the importance of Web applications has become more and more prominent. Web applications in production environments need to have high performance and high performance. Concurrency capabilities to meet user needs. If you want to ensure the high performance and high concurrency of web applications, you must conduct performance testing.

This article will introduce how to use Go language to perform performance testing of web applications and provide readers with some practical experience.

1. Preparation

First, we need to install the Go language development environment and some commonly used frameworks for this type of application development. It is recommended to use the Gin framework for web application development.

After installing the Go language environment and Gin framework, we need to install some performance testing tools, commonly used ones include ApacheBench (ab), wrk, etc.

2. Performance Test

Before using the performance testing tool, we need to start our web application. The following is a sample code for a web application built using the Gin framework:

1

2

3

4

5

6

7

8

9

10

11

12

13

package main

 

import "github.com/gin-gonic/gin"

 

func main() {

    r := gin.Default()

    r.GET("/hello", func(c *gin.Context) {

        c.JSON(200, gin.H{

            "message": "Hello world!",

        })

    })

    r.Run() // listen and serve on 0.0.0.0:8080

}

Copy after login

This simple web application only provides a GET method for returning "Hello world!" information in JSON format.

Next, we can use the ApacheBench tool to conduct performance testing. ApacheBench is a tool developed by the Apache Software Foundation for quickly and easily stress testing web servers. Under the command line, we can use the following command to test:

1

ab -n 1000 -c 100 http://localhost:8080/hello

Copy after login

Among them, -n represents the number of requests, -c represents the number of concurrency, http://localhost:8080/hello is the number of our web application address.

After executing this command, we can see that ApacheBench will output the following results:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

Server Software:       

Server Hostname:        localhost

Server Port:            8080

 

Document Path:          /hello

Document Length:        26 bytes

 

Concurrency Level:      100

Time taken for tests:   0.431 seconds

Complete requests:      1000

Failed requests:        0

Total transferred:      190000 bytes

HTML transferred:       26000 bytes

Requests per second:    2321.25 [#/sec] (mean)

Time per request:       43.128 [ms] (mean)

Time per request:       0.431 [ms] (mean, across all concurrent requests)

Transfer rate:          431.51 [Kbytes/sec] received

 

Connection Times (ms)

              min  mean[+/-sd] median   max

Connect:        0    0   0.2      0       2

Processing:     8   42  11.1     40      71

Waiting:        8   42  10.8     40      71

Total:          8   42  11.1     40      72

 

Percentage of the requests served within a certain time (ms)

  50%     40

  66%     49

  75%     53

  80%     55

  90%     60

  95%     68

  98%     71

  99%     72

 100%     72 (longest request)

Copy after login

Among them, the meaning of each indicator is as follows:

  • Server Software: The software name of the server.
  • Server Hostname: The host name of the server.
  • Server Port: The port number of the server.
  • Document Path: The requested document path.
  • Document Length: Requested document length.
  • Concurrency Level: Number of concurrencies.
  • Time taken for tests: Time taken for tests.
  • Complete requests: Number of completed requests.
  • Failed requests: Number of failed requests.
  • Total transferred: The amount of data transferred.
  • HTML transferred: The amount of HTML data transferred.
  • Requests per second: Number of requests per second.
  • Time per request: The time spent on each request.
  • Time per request: The average time taken by each request (including all concurrent requests).
  • Transfer rate: transfer rate.

Among them, the most important indicator is Requests per second. It represents the processing power of the server, and the higher it is, the better the performance of the server. At the same time, Time per request (time taken for each request) and Time per request (average time taken for each request) are also very important indicators. They represent the processing performance of a single request, that is, the response speed of the server. The lower it is, the slower the server is. The better the performance.

In addition to ApacheBench, we can also use the wrk tool to perform performance testing of web applications. wrk is a modern HTTP benchmark testing tool with the advantages of high concurrency and high performance.

Again, we need to start our web application first. Under the command line, we can use the following command to test:

1

wrk -t 4 -c 1000 -d 10s http://localhost:8080/hello

Copy after login

Among them, -t represents the number of threads, -c represents the number of concurrency, and -d represents the test duration, http://localhost:8080/hello is the address of our web application.

After executing this command, we can see that wrk will output the following results:

1

2

3

4

5

6

7

8

9

Running 10s test @ http://localhost:8080/hello

  4 threads and 1000 connections

  Thread Stats   Avg      Stdev     Max   +/- Stdev

    Latency     4.97ms   51.05us   5.57ms   78.15%

    Req/Sec    50.73k     2.10k   54.41k    79.00%

  2034638 requests in 10.00s, 381.47MB read

  Socket errors: connect 748, read 1969, write 0, timeout 0

Requests/sec: 203513.06

Transfer/sec:     38.14MB

Copy after login

Among them, the meaning of each indicator is as follows:

  • Thread Stats: Thread statistics.
  • Latency: Processing delay.
  • Req/Sec: Number of requests per second.
  • requests in 10.00s: Number of requests within 10 seconds.
  • MB read: The amount of data read.
  • Requests/sec: Number of requests per second.
  • Transfer/sec: transfer rate.

Similarly, Requests/sec (number of requests per second) and Latency (processing delay) are the most important indicators. Among them, Requests/sec (number of requests per second) is also an important indicator for measuring server performance.

3. Summary

This article introduces how to use Go language for performance testing of web applications, including methods and precautions for performance testing using ApacheBench and wrk. When conducting performance testing, we need to pay attention to the hardware and software configuration of the test environment, as well as parameter settings and result interpretation during the test process. At the same time, in practice we also need to conduct performance testing based on different business needs and scenarios in order to improve the performance and reliability of web applications.

The above is the detailed content of Golang Learning Web Application Performance Testing Practice. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot Article Tags

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

How to configure connection pool for Golang database connection? How to configure connection pool for Golang database connection? Jun 06, 2024 am 11:21 AM

How to configure connection pool for Golang database connection?

How to safely read and write files using Golang? How to safely read and write files using Golang? Jun 06, 2024 pm 05:14 PM

How to safely read and write files using Golang?

Similarities and Differences between Golang and C++ Similarities and Differences between Golang and C++ Jun 05, 2024 pm 06:12 PM

Similarities and Differences between Golang and C++

How steep is the learning curve of golang framework architecture? How steep is the learning curve of golang framework architecture? Jun 05, 2024 pm 06:59 PM

How steep is the learning curve of golang framework architecture?

How to generate random elements from list in Golang? How to generate random elements from list in Golang? Jun 05, 2024 pm 04:28 PM

How to generate random elements from list in Golang?

Comparison of advantages and disadvantages of golang framework Comparison of advantages and disadvantages of golang framework Jun 05, 2024 pm 09:32 PM

Comparison of advantages and disadvantages of golang framework

golang framework document usage instructions golang framework document usage instructions Jun 05, 2024 pm 06:04 PM

golang framework document usage instructions

What are the best practices for error handling in Golang framework? What are the best practices for error handling in Golang framework? Jun 05, 2024 pm 10:39 PM

What are the best practices for error handling in Golang framework?

See all articles