Быстрый отладчик от Mozilla с записью и воспроизведением исполнения программы

от автора

Mozilla выпустила инструмент, который наверняка облегчит жизнь многим разработчикам: это фреймворк RR для записи и последующего воспроизведения исполнения программы под Linux. Воспроизведение происходит абсолютно детерминированно, то есть с теми же регистрами и адресами памяти — и неизменно с тем же сбоем. Другими словами, можно бесконечно гонять тесты, а как только появится баг — не спеша его изучить в офлайне, прокрутив запись сколько угодно раз. Записываются все деревья процессов и потоков.

RR создан для точного воспроизведения багов, которые проявляют себя непредсказуемо. В таких случаях при отладке стандартными средствами нет смысла запускать программу снова: не факт, что баг опять проявится. Эта проблема постоянно портит жизнь разработчикам. Вот почему в Mozilla решили создать такой фреймворк.

RR позволяет поднять отладку на совершенно новый уровень: перед уходом на обед оставляете скрипт для тестов с разными параметрами, а к вашему возвращению RR запишет хотя бы одно выполнение с ошибкой. Можно прокрутить эту запись и понять, в чём проблема.

Теоретически, GDB тоже позволяет отмотать выполнение программы, но в реальности эта функция в RR реализована на порядок лучше. Главное, что удалось решить проблему с производительностью: воспроизведение программы происходит практически с той же скоростью, что и обычное исполнение, потому что RR записывает только изменяющиеся фрагменты и не трогает бóльшую часть программы.

На диаграмме показано, насколько отличается скорость записи и скорость воспроизведения записанной программы от её нативного исполнения (оверхед).


Относительно большой оверхед reftest объясняется тем, что текущая конфигурация Gecko для Linux работает через X-сервер

К сожалению, пока что дебаггер поддерживает только x86 32-битные процессы, но это ограничение наверняка снимут в будущих версиях. Ещё одно ограничение первой версии — эмуляция только одноядерной машины. Для записи параллельных вычислений не обойтись без аппаратной поддержки, так что от этого ограничения так просто не избавишься. И ещё, дебаггер пока работает только на процессорах Intel Ivy Bridge и Sandy Bridge.

Создание отладочного инструмента RR заняло у разработчиков из Mozilla два года. Код на github.

ссылка на оригинал статьи http://habrahabr.ru/post/217251/


Комментарии

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *