Как написать инструмент стресс-тестирования веб-сайта с помощью PHP
Как написать инструмент стресс-тестирования веб-сайта с помощью PHP

Инструкция по увольнению

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

Этот инструмент стресс-тестирования использует расширение сопрограммы PHP Swoole и пул соединений Swoole для достижения количества одновременных запросов через пул соединений. Это только для тестирования вашего собственного сайта, незаконное использование запрещено, в противном случае вы будете нести ответственность за последствия!

Инструкция по применению

  • phpВерсия>=7.2,И установил расширение swoole (если вы находитесь в среде пагоды).,Вы можете установить его самостоятельно в php-расширении)
  • Загрузите загруженный код инструмента в любое место, а затем разархивируйте все это.
  • Выполните команду php start.php в корневом каталоге.
  • Закройте инструмент и запустите его где угодно: kill -9 (ps -ef|grep test|gawk '0 !~/grep/ {print
Язык кода:javascript
копировать
Метод запроса:
GETстресс-тест:http://серверIP:9000/?url={проситьURLадрес}&action=get&time={Время испытания давлением}&num={Количество параллелизма}
POSTстресс-тест:http://серверIP:9000/?url={проситьURLадрес}&action=post&time={Время испытания давлением}&num={Количество параллелизма}&data={urlencodeпозжеpostданные}
Язык кода:javascript
копировать
//Изменяем текущий лимит ресурсов файла
shell_exec("ulimit -n 100960");

$http = new Swoole\Http\Server("0.0.0.0", 9000, SWOOLE_BASE);

$http->on("start", function (\Swoole\Http\Server $server) {
    swoole_set_process_name("test");
    echo "start success!\n";
});

$http->set(['daemonize' => 1]);

$http->on("request", function (\Swoole\Http\Request $request, \Swoole\Http\Response $response) {
    $response->header("Content-Type", "text/plain");
    $url = (string)$request->get['url'];
    $action = strtolower((string)$request->get['action']);
    $time = (int)$request->get['time'] + time(); //Если это время меньше текущего времени, значит, оно истекло.
    $num = (int)$request->get['num'];
    $data = urldecode((string)$request->get['data']);
    if ($action != "get" && $action != "post") {
        $response->end("action error");
        return;
    }
    \Swoole\Coroutine::create(function () use ($data, $action, $num, $url, $time) {
        $connectionPool = new \Swoole\ConnectionPool(function () use ($url, $time) {
            return new Request($url);
        }, $num);
        $connectionPool->fill();
        $i = 1;
        while (true) {
            if ($time < time()) {
                $connectionPool->close();
                break;
            }
            $request = $connectionPool->get();
            if ($request instanceof Request) {
                \Swoole\Coroutine::create(function () use ($data, $action, $connectionPool, $i, $request) {
                    try {
                        if ($action == 'get') {
                            $request->get();
                        } else if ($action == 'post') {
                            $request->post($data);
                        }
                        $connectionPool->put($request);
                    } catch (Exception $e) {
                        $connectionPool->put($request);
                    }
                });
            }
            $i++;
        }
    });
    $message = sprintf('stress tests url:%s - thread:%s - expire:%s', $url, $num, date("Y/m/d H:i:s", $time));
    @$response->end((string)$message);
});

$http->start();
boy illustration
Учебное пособие по Jetpack Compose для начинающих, базовые элементы управления и макет
boy illustration
Код js веб-страницы, фон частицы, код спецэффектов
boy illustration
【новый! Суперподробное】Полное руководство по свойствам компонентов Figma.
boy illustration
🎉Обязательно к прочтению новичкам: полное руководство по написанию мини-программ WeChat с использованием программного обеспечения Cursor.
boy illustration
[Забавный проект Docker] VoceChat — еще одно приложение для мгновенного чата (IM)! Может быть встроен в любую веб-страницу!
boy illustration
Как реализовать переход по странице в HTML (html переходит на указанную страницу)
boy illustration
Как решить проблему зависания и низкой скорости при установке зависимостей с помощью npm. Существуют ли доступные источники npm, которые могут решить эту проблему?
boy illustration
Серия From Zero to Fun: Uni-App WeChat Payment Practice WeChat авторизует вход в систему и украшает страницу заказа, создает интерфейс заказа и инициирует запрос заказа
boy illustration
Серия uni-app: uni.navigateЧтобы передать скачок значения
boy illustration
Апплет WeChat настраивает верхнюю панель навигации и адаптируется к различным моделям.
boy illustration
JS-время конвертации
boy illustration
Обеспечьте бесперебойную работу ChromeDriver 125: советы по решению проблемы chromedriver.exe не найдены
boy illustration
Поле комментария, щелчок мышью, специальные эффекты, js-код
boy illustration
Объект массива перемещения объекта JS
boy illustration
Как открыть разрешение на позиционирование апплета WeChat_Как использовать WeChat для определения местонахождения друзей
boy illustration
Я даю вам два набора из 18 простых в использовании фонов холста Power BI, так что вам больше не придется возиться с цветами!
boy illustration
Получить текущее время в js_Как динамически отображать дату и время в js
boy illustration
Вам необходимо изучить сочетания клавиш vsCode для форматирования и организации кода, чтобы вам больше не приходилось настраивать формат вручную.
boy illustration
У ChatGPT большое обновление. Всего за 45 минут пресс-конференция показывает, что OpenAI сделал еще один шаг вперед.
boy illustration
Copilot облачной разработки — упрощение разработки
boy illustration
Микросборка xChatGPT с низким кодом, создание апплета чат-бота с искусственным интеллектом за пять шагов
boy illustration
CUDA Out of Memory: идеальное решение проблемы нехватки памяти CUDA
boy illustration
Анализ кластеризации отдельных ячеек, который должен освоить каждый&MarkerгенетическийВизуализация
boy illustration
vLLM: мощный инструмент для ускорения вывода ИИ
boy illustration
CodeGeeX: мощный инструмент генерации кода искусственного интеллекта, который можно использовать бесплатно в дополнение к второму пилоту.
boy illustration
Машинное обучение Реальный бой LightGBM + настройка параметров случайного поиска: точность 96,67%
boy illustration
Бесшовная интеграция, мгновенный интеллект [1]: платформа больших моделей Dify-LLM, интеграция без кодирования и встраивание в сторонние системы, более 42 тысяч звезд, чтобы стать свидетелями эксклюзивных интеллектуальных решений.
boy illustration
LM Studio для создания локальных больших моделей
boy illustration
Как определить количество слоев и нейронов скрытых слоев нейронной сети?
boy illustration
[Отслеживание целей] Подробное объяснение ByteTrack и детали кода