Введение в волшебную работу по стресс-тестированию Linux
Введение в волшебную работу по стресс-тестированию Linux

Введение в волшебную работу по стресс-тестированию Linux

Введение

"подготовить официальное представление": wrk это современный HTTP Инструмент для тестирования производительности, способный запускать несколько ядер на одном CPU Создает большую нагрузку при работе. Он сочетает в себе многопоточный дизайн с масштабируемой системой уведомлений о событиях, такой как epoll и kqueue) вместе взятые. Необязательный LuaJIT Скрипт может быть выполнен HTTP Генерация запросов, обработка ответов и настраиваемые отчеты. Подробности доступны на SCRIPTING Найдено в , несколько примеров находятся в scripts/ середина.

работать над позиционированием

  • Легкий инструмент для тестирования производительности
  • Поддерживает только протокол HTTP
  • Поддерживается только нагрузочное тестирование на одном компьютере. Нагрузочное тестирование на нескольких машинах требует ручного выполнения команды wrk на каждом компьютере.
  • Не может заменить профессиональные инструменты повышения производительности, такие как Jmeter и LR.

Основное использование

wrk --help

Язык кода:shell
копировать
[windealli@VM-52-29-centos workspace]$ wrk --help
Usage: wrk <options> <url>                            
  Options:                                            
    -c, --connections <N>  Connections to keep open  Количество соединений 
    -d, --duration    <T>  Duration of test   Время испытания давлением        
    -t, --threads     <N>  Number of threads to Использование открывает количество потоков  
                                                      
    -s, --script      <S>  Load Lua script file  Используйте Lua-скрипт     
    -H, --header      <H>  Add header to request   
        --latency          Print latency statistics   
        --timeout     <T>  Socket/request timeout     
    -v, --version          Print version details      
                                                      
  Numeric arguments may include a SI unit (1k, 1M, 1G)
  Time arguments may include a time unit (2s, 2m, 2h)

Базовый пример

Примеры ниже,использоватьwrkЗаказверноhttp://127.0.0.1:80/sayHello?power=10Провести стресс-тестирование。

Язык кода:shell
копировать
wrk -t12 -c1000 -d30s http://127.0.0.1:80/sayHello?power=10

в:

-t12: Указывает, что клиент запустил 12 потоков для стресс-тестирования.

-c1000: Показывает, что открыто 1000 соединений.

-d30s: Указывает, что время испытания давлением составляет 30 с.

Анализ результатов
Язык кода:txt
копировать
[windealli@VM-52-29-centos workspace]$ wrk -t12 -c1000 -d30s http://127.0.0.1:80
/sayHello?power=10
Running 30s test @ http://119.91.66.202/sayHello?power=10
  12 threads and 1000 connections
  Thread Stats   Avg      Stdev     Max   +/- Stdev
    Latency   172.14ms  317.41ms   1.99s    92.37%
    Req/Sec    88.75     96.55     2.39k    91.91%
  29616 requests in 30.10s, 36.59MB read
  Socket errors: connect 0, read 0, write 0, timeout 1278
Requests/sec:    983.92
Transfer/sec:      1.22MB
[windealli@VM-52-29-centos workspace]$ 

Описание результатов:

В ходе 30-секундного стресс-теста было инициировано в общей сложности 29 616 запросов и прочитано 36,59 МБ данных.

Среднее количество запросов в секунду 983,92,Requests/sec: 983.92

Средняя задержка: 172,14 мс, максимальная задержка 1,99 с.

работа и luaJIT

wrk поддерживает написание сценариев на основе luaJIT для реализации сложных тестов производительности.

Официальная документацияwrk/SCRIPTINGпредставить свойиспользоватьметод。

Возможности создания сценариев wrk можно свести к следующим частям:

  1. определяет глобальнуюtalbe:wrk
  2. Предоставляется небольшая сумма(три)реализовывать определенные функцииAPI:wrk.format(),wrk.lookup(),wrk.connect
  3. Согласен что-тофункция Интерфейс для реализации пользователями,wrk вызовет эти функциональные интерфейсы на согласованном этапе.

Глобальная таблица и API

в работе,Интерфейс разработки,глобальнымtableиглобальный наборфункциякомпозиция:

глобальная таблица wrk
Язык кода:txt
копировать
 wrk = {
    scheme  = "http",
    host    = "localhost",
    port    = nil,
    method  = "GET",
    path    = "/",
    headers = {},
    body    = nil,
    thread  = <userdata>,
  }
function wrk.format(method, path, headers, body)
Язык кода:lua
копировать
-- wrk.format Создайте http-запрос на основе входных параметров. Присоединяйтесь к встрече и работайте над глобальной таблицейслить, 
-- @param method : http method, Такие как POST, GET
-- @param method : запрошенный путь
-- @parma headers : Запросить заголовки для переноса, это стол
-- @param body : Тело запроса пакета
-- @return : Возвращает пакет запроса, который можно выбрать и использовать в request() при запускеэтапа.
function wrk.format(method, path, headers, body)
function wrk.lookup(host, service)
Язык кода:lua
копировать
-- wrk.lookup : Возвращает всю согласованную адресную информацию согласно параметру хостисервис, Соответствует POSIX getaddrinfo() функция
function wrk.lookup(host, service)
function wrk.connect(addr)
Язык кода:lua
копировать
-- wrk.connect : Проверьте, можно ли успешно подключить адрес addr.
-- @param addr : Целевой адрес для проверки должен быть адресом, возвращаемым wrk.lookup.
-- @return : Если соединение успешное, оно возвращает true, в противном случае — false. 
function wrk.connect(addr)

Три этапа запуска скрипта wrk

wrk поддерживает запуск сценариев luaJIT на следующих трех этапах:

  • setup: Стартовый этап,(IP-адрес назначения был разрешен,Поток, выполняющий тест, инициализирован.,Но исполнение еще не началось)
  • running: Запустите этап, отправьте запрос и получите ответ.
  • done: Каждый тестовый поток завершился, и была получена таблица различных данных результатов тестирования.

каждыйэтап Некоторые соответствующиефункцияинтерфейс,Эти интерфейсы будут вызываться на соответствующем этапе при запуске теста wrk.

setup и done этап работает в независимой скриптовой среде и не участвует в running процесс. Таким образом, глобальные переменные не являются общими.

setup этап

setupэтап Он начинается, когда анализируется IP-адрес назначения, и заканчивается, когда тестовый поток инициализируется (но еще не запускается).

В настройкеэтап согласовали интерфейс

Язык кода:lua
копировать
-- setup Вызывается каждый раз при запуске потока.
-- @param thread Объект пользовательских данных, используемый для представления текущего потока. 
function setup(thread)

thread.addr      -- get or set the thread's server address
thread:get(name)  -- Получите значение из переменной среды потока.
thread:set(name, value) -- Установите переменные среды для потоков,
thread:stop()          -- Остановите ветку.

потому чтоfunction setup(thread)находится вsetupэтапвызов,При запускеэтап в автономной среде сценариев середина.

На этот раз разные потоки используют общие глобальные переменные. Мы можем пронумеровать каждого здесь.

running этап

runningэтап Инициализация из потокаinit()начинать,Затем повторитеrequest()иresponse()цикл

runningэтап Было согласовано следующеефункцияинтерфейс:

Язык кода:lua
копировать
-- init Инициализация потока
-- @param args Используется для получения параметров строки заказа, переданных пользователем.
function init(args)

-- delay Используется для указания времени задержки отправки следующего запроса.
-- @return Время задержки возврата, единица измерения — мс
function delay()

-- request Используется для создания текущего HTTP для отправки. request, С помощью запроса можно добиться эффекта разного контента для каждого запроса. Однако, поскольку при построении запроса возникают некоторые накладные расходы, тестирование лучше всего проводить путем предварительного создания пакета запроса в init()этап (через wrk.format()), а затем быстрого опроса/выбора там. 
-- @return HTTP для отправки request
function request()

-- response Этот метод вызывается, когда wrk получает ответ на запрос, где можно выполнить статистику и анализ ответа.
-- @param status : Код состояния HTTP
-- @param headers : заголовки ответов
-- @param body : тело ответа
function response(status, headers, body)

done этап

Когда работа каждого теста потока завершена (время заканчивается), начинается этот этап.

doneэтап Договорились о следующеминтерфейс

Язык кода:lua
копировать
-- done Тест завершается вызовом, а на основе входных параметров осуществляется анализ данных и отображение этого бенчмарк-теста.
-- @params summary : Сводка результатов тестирования (общее количество запросов, различные индикаторы ошибок и т. д.)
-- @params latency : Сводная информация о задержке. (максимальная задержка, минимальная задержка, средняя задержка и т. д.)
-- @params requests : Сводка результатов испытаний
function done(summary, latency, requests)

Расширенное использование

Отправить POST-запрос

Язык кода:lua
копировать
-- post.lua
wrk.method="POST"
wrk.headers["Content-Type"] = "application/json"
wrk.body = "{\"UserId\":1001}"
Язык кода:lua
копировать
wrk  -t2 -c1000 -d10s -s test.lua http://127.0.0.1:8080/sayHello

Создавайте разные запросы и отправляйте их случайным образом

Тестовый скрипт:

Язык кода:lua
копировать
local index = 0

function init(args)
    -- Создайте 4 разных запроса
    req = {}
    req[0] = wrk.format("GET", "/?userId=1001", nil, nil) 
    req[1] = wrk.format("GET", "/?userId=1002", nil, nil) 
end

function request() 
    index = index + 1
    return req[index%2]
end

Тестовая команда:

Язык кода:lua
копировать
wrk  -t2 -c1000 -d10s -s test.lua http://127.0.0.1:8080/

Серверная программа, написанная на go:

Язык кода:lua
копировать
package main

import (
	"fmt"
	"net/http"
)

func handle(w http.ResponseWriter, r *http.Request) {
	userId := r.URL.Query().Get("userId")
	fmt.Printf("userId: %s\n", userId)
	w.Write([]byte("hello " + userId))
	// return
}

func main() {
	http.HandleFunc("/", handle)
	fmt.Println("http server start, :8080")
	http.ListenAndServe(":8080", nil)
}

Подсчитайте количество вопросов без ответа

Скрипт стресс-теста

Язык кода:lua
копировать
local count_thread = 0
local threads = {}


function setup(thread)
    thread:set("id", count_thread)
    table.insert(threads, thread)
    count_thread = count_thread + 1
end

function init(args)
    res_a = 0
    res_b = 0
end

function response(status, headers, body)
    if body == "a" 
    then
        res_a = res_a + 1
    else
        res_b = res_b + 1
    end
end

-- Подсчитайте количество ответов «а» и «б»
function done(summary, latency, requests)
    for index, thread in ipairs(threads) do
        local res_a = thread:get("res_a") -- Получите значение переменной res_a потока.
        local res_b = thread:get("res_b") 
        print("res_a: " .. res_a)
        print("res_b: " .. res_b)
     end
end

Серверная программа, написанная на Go:

Язык кода:go
копировать
func handle(w http.ResponseWriter, r *http.Request) {
	if time.Now().Unix()%5 == 0 {
		w.Write([]byte("a"))
	} else {
		w.Write([]byte("b"))
	}
}

func main() {
	http.HandleFunc("/", handle)
	fmt.Println("http server start, :8080")
	http.ListenAndServe(":8080", nil)
}

Посмотреть результаты теста,можно увидетьbКоличество ответов’a‘из4О временах,Как и ожидалось.

Язык кода:shell
копировать
➜  wrk git:(main) ✗ wrk  -t2 -c1000 -d10s -s test.lua http://127.0.0.1:8080/
Running 10s test @ http://127.0.0.1:8080/
  2 threads and 1000 connections
  Thread Stats   Avg      Stdev     Max   +/- Stdev
    Latency     5.92ms    3.79ms  39.29ms   74.21%
    Req/Sec    47.40k    13.73k  126.56k    82.63%
  921607 requests in 10.05s, 102.83MB read
  Socket errors: connect 0, read 1023, write 80, timeout 0
Requests/sec:  91722.38
Transfer/sec:     10.23MB
res_a: 92497
res_b: 372194
res_a: 93570
res_b: 363346
➜  wrk git:(main) ✗ 
boy illustration
Неразрушающее увеличение изображений одним щелчком мыши, чтобы сделать их более четкими артефактами искусственного интеллекта, включая руководства по установке и использованию.
boy illustration
Копикодер: этот инструмент отлично работает с Cursor, Bolt и V0! Предоставьте более качественные подсказки для разработки интерфейса (создание навигационного веб-сайта с использованием искусственного интеллекта).
boy illustration
Новый бесплатный RooCline превосходит Cline v3.1? ! Быстрее, умнее и лучше вилка Cline! (Независимое программирование AI, порог 0)
boy illustration
Разработав более 10 проектов с помощью Cursor, я собрал 10 примеров и 60 подсказок.
boy illustration
Я потратил 72 часа на изучение курсорных агентов, и вот неоспоримые факты, которыми я должен поделиться!
boy illustration
Идеальная интеграция Cursor и DeepSeek API
boy illustration
DeepSeek V3 снижает затраты на обучение больших моделей
boy illustration
Артефакт, увеличивающий количество очков: на основе улучшения характеристик препятствия малым целям Yolov8 (SEAM, MultiSEAM).
boy illustration
DeepSeek V3 раскручивался уже три дня. Сегодня я попробовал самопровозглашенную модель «ChatGPT».
boy illustration
Open Devin — инженер-программист искусственного интеллекта с открытым исходным кодом, который меньше программирует и больше создает.
boy illustration
Эксклюзивное оригинальное улучшение YOLOv8: собственная разработка SPPF | SPPF сочетается с воспринимаемой большой сверткой ядра UniRepLK, а свертка с большим ядром + без расширения улучшает восприимчивое поле
boy illustration
Популярное и подробное объяснение DeepSeek-V3: от его появления до преимуществ и сравнения с GPT-4o.
boy illustration
9 основных словесных инструкций по доработке академических работ с помощью ChatGPT, эффективных и практичных, которые стоит собрать
boy illustration
Вызовите deepseek в vscode для реализации программирования с помощью искусственного интеллекта.
boy illustration
Познакомьтесь с принципами сверточных нейронных сетей (CNN) в одной статье (суперподробно)
boy illustration
50,3 тыс. звезд! Immich: автономное решение для резервного копирования фотографий и видео, которое экономит деньги и избавляет от беспокойства.
boy illustration
Cloud Native|Практика: установка Dashbaord для K8s, графика неплохая
boy illustration
Краткий обзор статьи — использование синтетических данных при обучении больших моделей и оптимизации производительности
boy illustration
MiniPerplx: новая поисковая система искусственного интеллекта с открытым исходным кодом, спонсируемая xAI и Vercel.
boy illustration
Конструкция сервиса Synology Drive сочетает проникновение в интрасеть и синхронизацию папок заметок Obsidian в облаке.
boy illustration
Центр конфигурации————Накос
boy illustration
Начинаем с нуля при разработке в облаке Copilot: начать разработку с минимальным использованием кода стало проще
boy illustration
[Серия Docker] Docker создает мультиплатформенные образы: практика архитектуры Arm64
boy illustration
Обновление новых возможностей coze | Я использовал coze для создания апплета помощника по исправлению домашних заданий по математике
boy illustration
Советы по развертыванию Nginx: практическое создание статических веб-сайтов на облачных серверах
boy illustration
Feiniu fnos использует Docker для развертывания личного блокнота Notepad
boy illustration
Сверточная нейронная сеть VGG реализует классификацию изображений Cifar10 — практический опыт Pytorch
boy illustration
Начало работы с EdgeonePages — новым недорогим решением для хостинга веб-сайтов
boy illustration
[Зона легкого облачного игрового сервера] Управление игровыми архивами
boy illustration
Развертывание SpringCloud-проекта на базе Docker и Docker-Compose