Как отслеживать бенчмарки Rust libtest bench в CI
Everett Pompeii
Теперь, когда вы узнали как выполнять бенчмаркинг кода на Rust с помощью libtest bench, давайте посмотрим, как отслеживать эти бенчмарки в CI. Непрерывный бенчмаркинг — это практика запуска бенчмарков для каждого набора изменений, чтобы убедиться, что изменения не вводят регрессии производительности. Самый простой способ реализовать Непрерывный бенчмаркинг с бенчмарками libtest bench — использовать Bencher.
Что такое Bencher?
Bencher - это набор инструментов для непрерывного тестирования производительности. Когда-нибудь регрессия производительности влияла на ваших пользователей? Bencher мог бы предотвратить это. Bencher позволяет вам обнаруживать и предотвращать регрессии производительности до того, как они будут слиты.
- Запустить: Запустите свои тесты производительности локально или в CI, используя точно те же самые bare metal раннеры и ваши любимые инструменты для тестирования. CLI
bencherоркестрирует запуск ваших тестов производительности на bare metal и сохраняет их результаты. - Отслеживать: Отслеживайте результаты ваших тестов производительности со временем. Мониторите, запрашивайте и строите графики результатов с помощью веб-консоли Bencher на основе ветки исходного кода, испытательного стенда и меры.
- Поймать: Отлавливайте регрессии производительности локально или в CI, используя точно то же самое bare metal оборудование. Bencher использует инструменты аналитики, работающие по последнему слову техники, чтобы обнаружить регрессии производительности, прежде чем они будут слиты.
По тем же причинам, по которым модульные тесты запускаются, чтобы предотвратить регрессии функций, тесты производительности должны быть запущены с Bencher, чтобы предотвратить регрессии производительности. Ошибки производительности – это тоже ошибки!
Шаги для Bencher Cloud
- Создайте учетную запись Bencher Cloud.
- Создайте API-токен и добавьте его в ваш CI как секрет.
- Создайте рабочий процесс для вашего CI, как GitHub Actions или GitLab CI/CD.
- Установите Bencher CLI в вашем рабочем процессе CI.
-
Запустите ваши тесты производительности с помощью
bencher runподкоманды в вашем рабочем процессе CI, используя адаптерrust_bench.
Шаги для Bencher Self-Hosted
- Создайте экземпляр Bencher Self-Hosted.
- Зарегистрируйте аккаунт на вашем экземпляре Bencher Self-Hosted.
- Создайте API токен и добавьте его в CI как секрет.
- Создайте рабочий процесс для вашего CI, например GitHub Actions или GitLab CI/CD.
- Установите Bencher CLI в ваш CI рабочий процесс. Убедитесь, что версия CLI соответствует версии вашего экземпляра Bencher Self-Hosted.
-
Запустите ваши бенчмарки с помощью
bencher runподкоманды в вашем CI рабочем процессе, используя адаптерrust_benchи указывая опцию--hostна URL вашего экземпляра Bencher Self-Hosted.
🦀 Rust Bench
Адаптер Rust Bench (rust_bench) ожидает вывод libtest bench.
Измеряется latency (то есть наносекунды (ns)).
lower_value и upper_value представляют собой отклонения ниже и выше медианы (то есть value) соответственно.
bencher run --adapter rust_bench "cargo +nightly bench"Отслеживайте свои бенчмарки в CI
Когда-либо ли у вас была регрессия производительности, повлиявшая на ваших пользователей? Bencher мог бы предотвратить это с помощью н kontinuierlichem Benchmarking.