«Хаммер» в мире инструментов стресс-тестирования: wrk использует
«Хаммер» в мире инструментов стресс-тестирования: wrk использует

В предыдущей статье Начало работы с OpenResty и методами обеспечения безопасности шлюзов, которые должен знать каждый бэкэнд , я представил тебе OpenResty Вводное употребление – это WAF Практика защиты, эта статья продолжит знакомить вас с ней. OpenResty Начало работы с тестированием производительности статьи.

Тестирование производительности является неотъемлемой частью разработки программного обеспечения. Оно может помочь нам оценить производительность, стабильность, масштабируемость и другие показатели системы, а также обеспечить основу для оптимизации и улучшения. Однако тестирование производительности также, скорее всего, будет неточным, поскольку на него влияют многие факторы, такие как сетевое окружение, конфигурация сервера, инструменты стресс-тестирования, сценарии стресс-тестирования и т. д. Если мы выберем неподходящие инструменты стресс-тестирования или не сможем разработать сценарии стресс-тестирования, результаты, которые мы получим, могут быть далеки от реальной ситуации или даже привести к неверным суждениям и решениям.

Как говорится, если хочешь хорошо выполнять свою работу, сначала нужно заточить инструменты. Так как же выбрать подходящий инструмент для измерения давления? первый OpenResty да fork с Nginx разработан на основе Nginx Оригинальная мощная производительность (сопрограмма + IO Мультиплексирование Epoll),Чтопроизводительность Тоже очень Итак, нам нужно издаа с производительностью тела, достаточно сильной, чтобы максимизировать выжимку. досуха OpenResty Производительность программы, сервер cpu Инструменты стресс-тестирования ресурсов.

Здесь я хотел бы представить вам «Хаммер» в мире опрессовочных инструментов. —— wrk。wrk да Один за HTTP Инструмент для тестирования протоколов,который может работать на одной машине с несколькими ядрами. CPU изв условиях,использоватьсистемасприноситьизвысокая производительность I/O такие механизмы, как epoll,kqueue и т. д., посредством многопоточности и режима событий, создавая большую нагрузку на целевую машину. работать поддерживать Lua-скрипт для создания сложных тестовых сценариев (это похоже на OpenResty поддерживать То же, что и Lua-скрипт), который также может выводить подробную статистику времени отклика. работать Преимущества заключаются в следующем:

  • высокая производительность:wrk Может использовать преимущества нескольких ядер CPU возможность параллельных вычислений, использование нескольких потоков и подключение для одновременной отправки запросов, а также эффективное использование I/O модель для обработки ответа. так wrk На одной машине можно создать до сотен тысяч или даже миллионов уровней. QPS (запросов в секунду), намного превышающий другие распространенные инструменты стресс-тестирования, такие как ab、siege、jmeter ждать.
  • гибкий:wrk поддерживатьиспользовать Lua-скрипт для настройки сценариев стресс-тестирования, например определения HTTP метод、Динамически генерировать параметры запроса、Измените заголовок запроса ожидание Вот так Мы. можем моделировать различные сложные и реальные действия пользователей и бизнес-логику.,Это приближает результаты стресс-тестов к реальной ситуации.
  • краткий:wrk установкаиспользовать очень просто и требует всего лишь нескольких команд. работать из Результат также очень ясени Интуитивный,Может отображать каждый поток и общее время ответа и количество запросов в секунду.,И вы можете распечатать распределение времени отклика,Нам удобно анализировать узкое место.

wrk установка

wrk Устанавливается только на классы. Unix система, поэтому нам нужен Linux или MacOS среда。установка виндовс 10 Нужно пристегнуть ремень безопасности Ubuntu подсистема.

установка Linux

В системах Ubuntu/Debian wrk можно установить с помощью следующей команды:

Язык кода:javascript
копировать
sudo apt-get install build-essential libssl-dev git -y
git clone https://github.com/wg/wrk.git wrk
cd wrk
make
# Переместите исполняемый файл в /usr/local/bin Расположение
sudo cp wrk /usr/local/bin

Для систем CentOS/RedHat/Fedora wrk можно установить с помощью следующей команды:

Язык кода:javascript
копировать
sudo yum groupinstall 'Development Tools'
sudo yum install -y openssl-devel git
git clone https://github.com/wg/wrk.git wrk
cd wrk
make
# Переместите исполняемый файл в /usr/local/bin Расположение
sudo cp wrk /usr/local/bin

Установка MacOS

Mac систему также можно скомпилировать, предварительно скомпилировав ее, но мы рекомендуем использовать brew установить, Шаги следующие:

  • Установить Homebrew, Официальный сайт ссылки на метод установки https://brew.sh (Это всего лишь одна линия командования и всё);
  • Установить wrk: brew install wrk;

установка виндовс 10

Windown 10 нужно быть внутри Windows Функция Проверьте здесь Применимо к Linux из Windows подсистема, тогда пройди bash команда переключается на Ubuntu подсистема Далее см. установка Linux из Этапы эксплуатации,Установить wrk。

Подготовка перед испытанием под давлением

Прежде чем начать стресс-тестирование, нам все равно необходимо внести некоторые изменения в тестовую среду и воспользоваться инструментом стресс-тестирования. wrk Выжать досуха OpenResty Программа изпроизводительность。

Максимальное количество файлов на процесс

Linux По умолчанию система имеет ограничение на количество файлов, которые может открыть каждый процесс, обычно да. 1024 индивидуальный. Этот предел повлияет на количество соединений, которые сервер может обрабатывать одновременно, поэтому этот предел необходимо увеличить. Добавлено из метода модификации /etc/security/limits.conf файл, добавьте следующее содержимое:

Язык кода:javascript
копировать
* soft nofile 65535
* hard nofile 65535

в * Число указывает на изменение всех пользовательских ограничений, программных или hard Укажите, следует ли изменить мягкое или жесткое ограничение, 65536. Затем вы указываете, что хотите изменить новое предельное значение, то есть Максимальное. количество открытых файлы (обратите внимание, что значение мягкого ограничения должно быть меньше или равно жесткому пределу). Сохраните файл после внесения изменений.

Таким образом вы сможете добавить всех пользователей в один процесс Максимальное количество открытых лимит файлов установлен на 65535 индивидуальный. если этого недостаточно, вы можете продолжать увеличивать это значение, но будьте осторожны, чтобы не превысить уровень системы из Максимального. количество открытых лимит файлов, можно пройти cat /proc/sys/fs/file-max команда для просмотра этого предела.

Максимальное количество открытых файлов

Проверять Linux системасортиз Максимальное количество открытых лимит файлов, используйте следующим образом:

Язык кода:javascript
копировать
[root@VM-16-5-centos ~]# cat /proc/sys/fs/file-nr
2112 0 369508

Последняя цифра здесь да Максимальное количество открытых файлы. Если ваше число в вашей машине относительно невелико, поэтому его необходимо изменить. /etc/sysctl.conf Чтобы увеличить размер файла:

Язык кода:javascript
копировать
fs.file-max = 1020000
net.ipv4.ip_conntrack_max = 1020000
net.ipv4.netfilter.ip_conntrack_max = 1020000

После завершения модификации необходимо перезапустить системную службу, чтобы изменения вступили в силу:

Язык кода:javascript
копировать
sysctl -p /etc/sysctl.conf

Количество рабочих процессов Nginx и количество подключений

Внесите некоторые изменения в файл конфигурации Nginx следующим образом:

Язык кода:javascript
копировать
# Количество процессов задания конфигурации
worker_processes  1;

...

events {
    # Количество соединений, обрабатываемых одним процессом задания
    worker_connections  1024;
}

По умолчанию Nginx иметь master и worker Два процесса, мастер процесс управления worker Процесс, рабочий процесс Используется для обработки внешних запросовда Предоставление услуг сторонним сторонам。

worker_processes 1 из Конфигурация Описание Номер процесса задания По умолчанию: 1. На многоядерной машине мы можем установить ее как сервер CPU из Количество ядер для улучшения Nginx из Количество процессов подключения.

worker_connections 1024 из Описание конфигурации Количество соединений, которые может обработать один процесс да 1024. В сценариях высокого давления мы можем увеличить это значение и изменить его на 10240。

наконец,оптимизацияиз Nginx Конфигурационный файл выглядит следующим образом:

Язык кода:javascript
копировать
# Автоматически устанавливать количество заданий в зависимости от количества ядер ЦП.
worker_processes  auto;

...

events {
    # Количество соединений, обрабатываемых одним процессом задания
    worker_connections  10240;
}

wrk Использование

работа по базовому использованию:

Язык кода:javascript
копировать
wrk <options> <url>

<options> данекоторые дополнительныеизпараметр,Используется для управления конфигурацией измерения давления.,<url> да Провести стресс-тестирование целевого URL.

Часто используемые параметры

wrk поддерживатьниже Часто используемые параметры:

  • -c, --connections <N>:Укажите, чтобы оставить открытымиз Количество соединений;
  • -d, --duration <T>:Указанное испытание давлениемизпродолжительность;
  • -t, --threads <N>:обозначение Чтобы использовать Количество потоков;
  • -s, --script <S>:обозначениезагрузитьиз Файл сценария Lua;
  • -H, --header <H>:обозначениедобавить к запросуиз HTTP голова;
  • --latency:обозначение Чтобы распечататьвремя ответа Статистика;
  • --timeout <T>:обозначениерозетка/Запросить тайм-аут;

в,числопараметр Можетиспользовать SI Единица (1 тыс., 1M, 1G), параметр времени может использовать единицу времени (2 с, 2m, 2h)。

Пример стресс-теста

Теперь нам предстоит OpenResty Программа из hello Чтобы выполнить стресс-тестирование интерфейса, мы можем использовать следующую команду:

Язык кода:javascript
копировать
wrk -c 100 -d 30s -t 4 --latency http://121.4.xxx.xx/hello

Эта команда указывает, что wrk используется для запуска стресс-теста со 100 соединениями и 4 потоками продолжительностью 10 секунд и вывода статистики времени ответа.

После запуска мы видим следующий результат:

Язык кода:javascript
копировать
Running 30s test @ http://121.4.xxx.xx/hello
  4 threads and 100 connections
  Thread Stats   Avg      Stdev     Max   +/- Stdev
    Latency    60.74ms   94.62ms   1.82s    88.81%
    Req/Sec   710.91    118.29     1.02k    69.08%
  Latency Distribution
     50%   26.22ms
     75%   32.99ms
     90%  176.28ms
     99%  475.41ms
  84967 requests in 30.02s, 15.40MB read
  Socket errors: connect 0, read 0, write 0, timeout 2
Requests/sec:   2829.91
Transfer/sec:    525.08KB

Из вывода мы можем увидеть следующую информацию:

  • Стресс-тест конфигурации и целевого URL,
Язык кода:javascript
копировать
Running 30s test @ http://121.4.xxx.xx/hello
  4 threads and 100 connections
  • в среднем за поток из、стандартное отклонение、Максимум и плюс-минус один стандартное отклонение Аккаунта из Время ответа (задержка),
Язык кода:javascript
копировать
  Latency    60.74ms   94.62ms   1.82s    88.81%

Эти данные и QPS Так же важно,Представляет скорость реакции системы,Чем меньше это значение, тем лучше.

  • Распределение времени ответа: то есть какая доля запросов выполняется в течение определенного периода времени.,Подробная распечатка процентного распределения задержки также показана ниже.,
Язык кода:javascript
копировать
  Latency Distribution
     50%   26.22ms
     75%   32.99ms
     90%  176.28ms
     99%  475.41ms
  • Общее количество запросов,
Язык кода:javascript
копировать
Requests/sec:   2829.91

Эти данные показывают, сколько запросов сервер обрабатывает в секунду. Чем больше значение, тем лучше.

Из этой информации мы можем видеть OpenResty Программа изпроизводительностьвозвращатьсядаочень хорошоиз,Время отклика составляет порядка нескольких миллисекунд.,QPS Тоже очень высокий.

Учитывая, что я из OpenResty Конфигурация сервера имеет только 2 ядра, 4G, память 5 МБ. приносить Ширина,Каждый должен относиться к результатам теста рационально,Каждый желающий может проверить это на себе.

Lua-скрипт

wrk поддерживатьиспользовать Lua-скрипт для настройки сценариев стресс-тестирования, например определения HTTP метод, динамически генерировать параметры запроса и изменять заголовки запросов. Таким образом, мы можем моделировать различные сложные и реальные действия пользователей и бизнес-логику, приближая результаты стресс-тестирования к реальной ситуации. работать из исходного кода приведены некоторые примеры скриптов, вы можете обратиться к https://github.com/wg/wrk/tree/master/scripts。

Чтобы использовать Lua-скрипт, необходим быть внутриуказан в командной строке -s Параметры и укажите путь к файлу скрипта. Например, мы можем использовать post.lua скрипт для отправки POST просить:

Язык кода:javascript
копировать
wrk -c 100 -d 10s -t 4 -s post.lua http://121.4.xxx.xx/hello

post.lua содержание следующее:

Язык кода:javascript
копировать
wrk.method = "POST"
wrk.body   = "name=tom"
wrk.headers["Content-Type"] = "application/x-www-form-urlencoded"

Таким образом, мы можем имитировать отправку POST Просьба о переносеприноситьданные формыизсцена。

некоторые часто задаваемые вопросы

Как выбрать подходящие параметры?

Параметр wrk из повлияет на результаты стресс-теста,Поэтому нам необходимо выбрать соответствующие параметры в соответствии с реальной ситуацией. Вообще говоря,Мы можем сослаться на следующие шаги:

  • Сначала один поток, чтобы постоянно измерять количество соединений, пока QPS (количество запросов в секунду) остается стабильным, а время ответа превышает ограничения бизнес-требований. Получить оптимальное количество однопоточных соединений при текущем значении.
  • Количество одиночных потоков подключения остается неизменным, а количество потоков постоянно увеличивается (рекомендуется достичь количества ядер ЦП) до тех пор, пока не появится общий уровень QPS.
  • если QPS По мере увеличения количества потоков производительность целевого сервера достигла узкого места, wrk Один поток может провести стресс-тестирование оптимальной целевой машины. QPS ценить.
  • если QPS По мере увеличения количества потоков, да wrk Производительность машины достигла узкого места и ее необходимо увеличить. wrk Обновление номера машины или замены высокое производительностьиз wrk машина.

Как решить ошибки, возникающие во время стресс-тестирования?

wrk Во время стресс-теста могут возникнуть некоторые ошибки.,Например, тайм-аут соединения、В соединении отказано、Ожидание сброса соединения Эти ошибки могут быть связаны с недостаточной производительностью целевого сервера.、Сетевое окружение нестабильно、Вызвано ограничениями брандмауэра и другими причинами. Чтобы устранить ошибку, мы можем попробовать следующие методы:

  • Корректирование работы параметров, таких как уменьшение количества подключений、Увеличить таймаут и т.д.;
  • Проверьте состояние ресурса целевого сервера,Такие как процессор, память, диск, сеть и т. д.,Оптимизировать конфигурацию сервера и расширить сервер;
  • Проверьте сетевое окружение,Например, пропускная способность, задержка, потеря пакетов и т. д.,Оптимизировать сетевое оборудование и заменить сетевые линии;
  • Проверьте настройки брандмауэра, такие как открытие портов, ограничения трафика и т. д., и отпустите wrk из Прав доступа или Отключите брандмауэр;

Подвести итог

wrk в праве OpenResty Программа во время испытания под давлением,Не подвел и показал сильную проверку давлениемпроизводительность。Я надеюсь, что благодаря этой статье каждый сможет понять суть wrk Инструмент тестирования производительности для более полного понимания.

·END·

Рекомендуем оригинальные популярные статьи из предыдущих выпусков:

  1. Используйте диаграмму, чтобы объяснить, что происходит, когда вы вводите URL-адрес в браузере.
  2. Начало работы с OpenResty и методами обеспечения безопасности шлюзов, которые должен знать каждый бэкэнд
  3. Представляем пять очень практичных советов изIDEAиспользовать
  4. API key и token иметь, какая разница?
  5. Объясните 8 популярных сетевых протоколов с помощью одной картинки
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