Yandex Cloud
Поиск
Связаться с намиПодключиться
  • Документация
  • Блог
  • Все сервисы
  • Статус работы сервисов
    • Популярные
    • Инфраструктура и сеть
    • Платформа данных
    • Контейнеры
    • Инструменты разработчика
    • Бессерверные вычисления
    • Безопасность
    • Мониторинг и управление ресурсами
    • Машинное обучение
    • Бизнес-инструменты
  • Все решения
    • По отраслям
    • По типу задач
    • Экономика платформы
    • Безопасность
    • Техническая поддержка
    • Каталог партнёров
    • Обучение и сертификация
    • Облако для стартапов
    • Облако для крупного бизнеса
    • Центр технологий для общества
    • Облако для интеграторов
    • Поддержка IT-бизнеса
    • Облако для фрилансеров
    • Обучение и сертификация
    • Блог
    • Документация
    • Контент-программа
    • Мероприятия и вебинары
    • Контакты, чаты и сообщества
    • Идеи
    • Истории успеха
    • Тарифы Yandex Cloud
    • Промоакции и free tier
    • Правила тарификации
  • Документация
  • Блог
Проект Яндекса
© 2025 ООО «Яндекс.Облако»
Yandex Load Testing
  • Начало работы
    • Все инструкции
    • Создать агент тестирования
    • Настроить группы безопасности агента тестирования
    • Настроить группы безопасности цели тестирования
    • Создать тест с данными из бакета
    • Экспорт отчётов с результатами тестирования
    • Собрать пользовательские запросы с помощью Dispatcher
    • Создать и настроить дашборд регрессий
    • Проверить превышение порогов метрик регрессий
    • Сохранить артефакты теста в Object Storage
    • Посмотреть операции с ресурсами сервиса
  • Управление доступом
  • Правила тарификации
  • Справочник Terraform
  • Аудитные логи Audit Trails
  • История изменений
  • Обучающие курсы

В этой статье:

  • Перед началом работы
  • Сбор запросов
  1. Пошаговые инструкции
  2. Собрать пользовательские запросы с помощью Dispatcher

Подготовка тестовых данных с помощью инструмента Dispatcher

Статья создана
Yandex Cloud
Обновлена 6 июня 2024 г.
  • Перед началом работы
  • Сбор запросов

Инструмент dispatcher предназначен для сбора пользовательских запросов и их сохранения в файлы данных, предназначенные для последующего проведения нагрузочного тестирования.

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

Перед началом работыПеред началом работы

  1. Установите Go не ниже версии 1.22:

    wget https://go.dev/dl/go1.22.2.linux-amd64.tar.gz
    tar -C /usr/local -xzf go1.22.2.linux-amd64.tar.gz
    export PATH=$PATH:/usr/local/go/bin
    
  2. Установите Git с помощью команды:

    sudo apt install git
    

Сбор запросовСбор запросов

  1. Клонируйте репозиторий из GitHub и перейдите в папку yc-load-testing-dispatcher:

    git clone https://github.com/yandex-cloud-examples/yc-load-testing-dispatcher.git
    cd yc-load-testing-dispatcher
    
  2. Запустите dispatcher с нужными флагами:

    go run dispatcher.go -target '<адрес_цели>' -port <порт> -ssl -noproxy -saveall -nostatic
    

    Где:

    • target – адрес сервиса, для которого выполняется проксирование и сохранение запросов;
    • port – порт, на котором будет запущен сервер. По умолчанию используется порт 8888;
    • ssl – позволяет проксировать запросы через защищенное HTTPS-соединение;
    • noproxy – определяет, следует ли сохранять запросы без их проксирования;
    • saveall – позволяет сохранять все запросы независимо от HTTP-кода ответа на проксированный запрос;
    • nostatic – позволяет не сохранять запросы статического контента, такого как CSS, JS, JPEG, JPG, PNG, GIF, ICO, SVG, WOFF и WOFF2.

    Пример запуска:

    go run dispatcher.go -target 'yandex.ru' -port 8080 -nostatic
    

    Результат:

    Dispatcher listens to your requests
    

    После запуска все запросы для нагрузочного тестирования следует отправлять на адрес localhost:8080. Кроме того, вы можете открыть в браузере страницу localhost:8080, и там будет загружен сайт, указанный в флаге target.

    Все запросы записываются последовательно непосредственно после приема ответа. Следовательно, порядок параллельно выполняемых запросов может отличаться от порядка в финальном файле.

    Результат:

    The payload is written to a raw.payload file
    The payload is written to a httpjson.payload file
    The payload is written to a uri.payload file
    The payload is written to a uripost.payload file
    

    После выполнения всех необходимых запросов, нажмите Ctrl + C, чтобы закрыть dispatcher.

    Важно

    Следует избегать ситуаций, когда закрытие происходит до получения всех ответов, так как тестовые данные могут не успеть записаться.

    Cохранение запросов происходит в следующие файлы:

    • Файл uri.payload содержит запросы типа URI;
    • Файл uripost.payload содержит запросы типа URIPOST;
    • Файл raw.payload содержит запросы типа RAW;
    • Файл httpjson.payload содержит запросы типа HTTP_JSON.

Была ли статья полезна?

Предыдущая
Экспорт отчётов с результатами тестирования
Следующая
Создать и настроить дашборд регрессий
Проект Яндекса
© 2025 ООО «Яндекс.Облако»