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:

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:

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:

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:

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:

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 AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Roblox: Bubble Gum Simulator Infinity - How To Get And Use Royal Keys
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Mandragora: Whispers Of The Witch Tree - How To Unlock The Grappling Hook
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Nordhold: Fusion System, Explained
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

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)

Hot Topics

Java Tutorial
1668
14
PHP Tutorial
1273
29
C# Tutorial
1256
24
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

Reading and writing files safely in Go is crucial. Guidelines include: Checking file permissions Closing files using defer Validating file paths Using context timeouts Following these guidelines ensures the security of your data and the robustness of your application.

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 pooling for Go database connections? Use the DB type in the database/sql package to create a database connection; set MaxOpenConns to control the maximum number of concurrent connections; set MaxIdleConns to set the maximum number of idle connections; set ConnMaxLifetime to control the maximum life cycle of the connection.

How to save JSON data to database in Golang? How to save JSON data to database in Golang? Jun 06, 2024 am 11:24 AM

JSON data can be saved into a MySQL database by using the gjson library or the json.Unmarshal function. The gjson library provides convenience methods to parse JSON fields, and the json.Unmarshal function requires a target type pointer to unmarshal JSON data. Both methods require preparing SQL statements and performing insert operations to persist the data into the database.

Golang framework vs. Go framework: Comparison of internal architecture and external features Golang framework vs. Go framework: Comparison of internal architecture and external features Jun 06, 2024 pm 12:37 PM

The difference between the GoLang framework and the Go framework is reflected in the internal architecture and external features. The GoLang framework is based on the Go standard library and extends its functionality, while the Go framework consists of independent libraries to achieve specific purposes. The GoLang framework is more flexible and the Go framework is easier to use. The GoLang framework has a slight advantage in performance, and the Go framework is more scalable. Case: gin-gonic (Go framework) is used to build REST API, while Echo (GoLang framework) is used to build web applications.

Transforming from front-end to back-end development, is it more promising to learn Java or Golang? Transforming from front-end to back-end development, is it more promising to learn Java or Golang? Apr 02, 2025 am 09:12 AM

Backend learning path: The exploration journey from front-end to back-end As a back-end beginner who transforms from front-end development, you already have the foundation of nodejs,...

Golang framework development practical tutorial: FAQs Golang framework development practical tutorial: FAQs Jun 06, 2024 am 11:02 AM

Go framework development FAQ: Framework selection: Depends on application requirements and developer preferences, such as Gin (API), Echo (extensible), Beego (ORM), Iris (performance). Installation and use: Use the gomod command to install, import the framework and use it. Database interaction: Use ORM libraries, such as gorm, to establish database connections and operations. Authentication and authorization: Use session management and authentication middleware such as gin-contrib/sessions. Practical case: Use the Gin framework to build a simple blog API that provides POST, GET and other functions.

Golang's Purpose: Building Efficient and Scalable Systems Golang's Purpose: Building Efficient and Scalable Systems Apr 09, 2025 pm 05:17 PM

Go language performs well in building efficient and scalable systems. Its advantages include: 1. High performance: compiled into machine code, fast running speed; 2. Concurrent programming: simplify multitasking through goroutines and channels; 3. Simplicity: concise syntax, reducing learning and maintenance costs; 4. Cross-platform: supports cross-platform compilation, easy deployment.

Which libraries in Go are developed by large companies or provided by well-known open source projects? Which libraries in Go are developed by large companies or provided by well-known open source projects? Apr 02, 2025 pm 04:12 PM

Which libraries in Go are developed by large companies or well-known open source projects? When programming in Go, developers often encounter some common needs, ...

See all articles