Хобрук: Ваш путь к мастерству в программировании

Ручная фиксация JMeter JDBC

Я использую JMeter для нагрузочного тестирования, и мне нужно запустить тест, который вставляет несколько тысяч записей. Частью требования является то, что он не должен фиксировать каждое отдельное обновление, а только фиксировать каждую тысячу записей. Кажется довольно простым, но я не могу найти никаких примеров или документации, объясняющих, как выполнить ручную фиксацию в JMeter, и я не могу заставить ее работать.

Я настроил его для чтения нескольких записей из CSV-файла, а также переменной счетчика для увеличивающегося поля идентификатора. Если автоматическая фиксация включена, все работает нормально.
Когда я отключаю автоматическую фиксацию, ничего не фиксируется — как и следовало ожидать. Но как мне его зафиксировать? Я даже не могу заставить его фиксировать каждое обновление без автоматической фиксации, не говоря уже о заданной скорости.

  • Я попытался добавить постпроцессор JDBC с оператором фиксации и/или типом запроса фиксации в том же пуле соединений с БД, только один поток в этом пуле и в тесте, но это не работает.
  • Пробовал делать то же самое как отдельный запрос JDBC, тоже не сработало.
  • Пытался добавить фиксацию в мое заявление об обновлении, но безуспешно.
  • Пытался изменить изоляцию транзакций, но ни одно из этих значений не имеет значения.
  • Пробовал открывать транзакцию препроцессором или запросом или внутри существующего запроса, но это тоже не помогло.

Я предполагаю, что моя проблема может заключаться в том, что фиксация переходит в отдельную транзакцию от фактических операторов обновления... но я не могу найти способ изменить это...


  • Извините, были проблемы с БД и пришлось ждать возвращения администратора из отпуска. Я попытался настроить, как показано на скриншотах, но все равно получаю тот же результат. В БД не добавляются новые записи... 10.09.2020
  • Хорошо, кажется, у меня все заработало, я еще раз попробовал коннектор mariadb вместо коннектора mysql, и, похоже, это сделало это, по крайней мере, в более новой версии jmeter. Старые версии по-прежнему не работают... что может быть проблемой, так как я не уверен, что новые версии одобрены корпорацией, но я оставлю этот вопрос на усмотрение руководства ;) 10.09.2020

Ответы:


1

Попробуйте сделать следующее:

  • Добавьте запрос JDBC с типом запроса, установленным на AutoCommit (false)
  • Поместите свои запросы JDBC, как вы хотите
  • Добавьте запрос JDBC с типом запроса, установленным на фиксацию

Ваш план должен выглядеть так:

Обзор и конфигурация

Кулак установил autocommit в false:

установить для автофиксации значение false

Затем вызовите свои запросы на обновление:

ваши SQL-запросы

Наконец зафиксируйте:

фиксировать

Сбросить автокоммит в true:

сбросить автофиксацию

Если это не сработает, я предлагаю вам сообщить о проблеме в JMeter.

03.09.2020
  • Не повезло... если это проблема JMeter, она давняя. У нас был установлен JMeter 3.2, который я использовал изначально, с коннектором mysql версии 5.1.27, оба из которых довольно старые. Итак, я обновился до последней версии - jmeter 5.3 с соединителем mysql 8.0.21, затем я заметил, что теперь есть выделенный соединитель mariadb, поэтому я тоже попробовал его (версия 2.6.2)... но у меня была одна и та же проблема с каждой комбинацией эти. Немного сомневаюсь, что ошибка Jmeter в чем-то столь простом оставалась незамеченной так долго... Я ожидаю, что это проблема "не поддерживается в этой конфигурации"... но я проверю с людьми из jmeter. 03.09.2020
  • можете ли вы поделиться скриншотом своего плана тестирования или запустить его в JMeter 5.X: Инструменты меню › Создать обзор схемы. Спасибо 03.09.2020
  • Я обновил свой ответ на основе того, что вы отправили в список рассылки пользователя. 03.09.2020
  • Новые материалы

    Создание кнопочного меню с использованием HTML, CSS и JavaScript
    Вы будете создавать кнопочное меню, которое имеет состояние наведения, а также позволяет вам выбирать кнопку при нажатии на нее. Финальный проект можно увидеть в этом Codepen . Шаг 1..

    Внедрите OAuth в свои веб-приложения для повышения безопасности
    OAuth — это широко распространенный стандарт авторизации, который позволяет приложениям получать доступ к ресурсам от имени пользователя, не раскрывая его пароль. Это позволяет пользователям..

    Классы в JavaScript
    class является образцом java Script Object. Конструкция «class» позволяет определять классы на основе прототипов с чистым, красивым синтаксисом. // define class Human class Human {..

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

    Как построить любой стол
    Я разработчик программного обеспечения. Я люблю делать вещи и всегда любил. Для меня программирование всегда было способом создавать вещи, используя только компьютер и мое воображение...

    Обзор: Машинное обучение: классификация
    Только что закончил третий курс курса 4 часть специализации по машинному обучению . Как и второй курс, он был посвящен низкоуровневой работе алгоритмов машинного обучения. Что касается..

    Разработка расширений Qlik Sense с qExt
    Использование современных инструментов веб-разработки для разработки крутых расширений Вы когда-нибудь хотели кнопку для установки переменной в приложении Qlik Sense? Когда-нибудь просили..