Поделиться через


Расширение отладки SOS

Расширение отладки SOS позволяет просматривать сведения о коде, работающем в среде выполнения .NET, как в динамических процессах, так и в дампах. Это расширение предустанавливается с помощью dotnet-dump и Windbg/dbg. Также его можно скачать для использования с LLDB. Расширение отладки SOS можно использовать для:

  • Сбор сведений об управляемой куче.
  • Найдите повреждения кучи.
  • Отображение внутренних типов данных, используемых средой выполнения.
  • Просмотр сведений обо всех управляемых кодах, выполняемых внутри среды выполнения.

Синтаксис

В Windows: ![command] [options]

В Linux и macOS: sos [command] [options]

Многие команды имеют псевдонимы или сочетания клавиш в lldb: clrstack [options]

Команды

Следующую таблицу команд можно также просмотреть в разделе Справка или с помощью команды soshelp. Справку по отдельным командам можно просмотреть с помощью команды soshelp <command>.

Команда Description
bpmd [-nofuturemodule] [<><> модуля] [-md<MethodDesc>] -list-clear<pending breakpoint number-clearall> Создает точку останова в указанном методе указанного модуля.

Если указанные модуль и метод не загружены, команда ожидает уведомления о загрузке модуля и выполнении JIT-компиляции, прежде чем создавать точку останова.

Списком ожидающих точек останова можно управлять с помощью параметров -list, -clear и -clearall.

Параметр -list создает список всех ожидающих точек останова. Если в ожидающей точке останова есть идентификатор модуля, ненулевой, эта точка останова зависит от функции в этом конкретном загруженном модуле. Если ожидающая точка останова имеет нулевой идентификатор модуля, такая точка останова применяется к еще не загруженным модулям.

Чтобы удалить из списка ожидающие точки останова, следует использовать параметр -clear или -clearall.
CLRStack [-a] [-l] [-p] [-n] [-f] [-r] [-all] Обеспечивает трассировку стека только для управляемого кода.

Параметр -p задает отображение аргументов управляемой функции.

Параметр -l задает отображение сведений о локальных переменных в кадре. Расширение отладки SOS не может получить локальные имена, поэтому выходные данные для локальных имен имеют значение>

Параметр -a заменяет собой комбинацию параметров -l и -p.

Параметр -n отключает отображение имен исходных файлов и номеров строк. Если для отладчика указан параметр "SYMOPT_LOAD_LINES", расширение отладки SOS ищет символы для каждого управляемого кадра и в случае успеха отображает соответствующее имя исходного файла и номер строки. Такое поведение можно отключить, задав параметр -n (без номеров строк).

Параметр -f (полный режим) отображает кадры машинного кода, в которых используются управляемые кадры, а также имя сборки и смещение функции для управляемых кадров. Этот параметр не отображает машинные кадры при использовании совместно с dotnet-dump.

Параметр -r создает дампы регистров для каждого кадра стека.

Параметр -all создает дампы для стеков всех управляемых потоков.
COMState Выдает список моделей контейнера COM для каждого потока и указатель Context, если он имеется. Эта команда поддерживается только в Windows.
DumpArray [-start startIndex<>] [длина длины<>] [-details] [-nofields] <адрес объекта массива>

–или–

DA [-start startIndex<>] [длина длины>] [-details] [-nofields] адрес объекта массива>
Анализирует элементы объекта массива.

Параметр -start задает индекс, начиная с которого отображаются элементы.

Параметр -length задает количество отображаемых элементов.

Параметр -details задает отображение сведений об элементе в формате DumpObj и DumpVC.

Параметр -nofields отменяет отображение массивов. Этот параметр доступен только при указании параметра -details .
DumpAsync (dumpasync) [-mt<MethodTable address>] [-type partial type<name>] [-await] [-root] DumpAsync проходит кучу сборки мусора и ищет объекты, представляющие асинхронные компьютеры состояний, созданные при передаче состояния асинхронного метода в кучу. Эта команда распознает асинхронные конечные автоматы, определяемые как async void, async Task, async Task<T>, async ValueTask и async ValueTask<T>.

В выходных данных содержится блок сведений для каждого найденного объекта асинхронного конечного автомата. Они могут включать:
— строка типа объекта асинхронного компьютера состояния, включая адрес MethodTable, адрес объекта, его размер и имя типа.
— строка для имени типа компьютера состояния, содержащегося в объекте.
— список каждого поля на компьютере состояния.
— строка продолжения объекта компьютера состояния, если была зарегистрирована одна или несколько.
— обнаружены корни GC для этого асинхронного объекта компьютера состояния.
DumpAssembly<адрес сборки> Отображает сведения о сборке.

Команда DumpAssembly выводит список модулей, если они существуют.

Адрес сборки можно получить с помощью команды DumpDomain.
DumpClass<адрес EEClass> Отображает сведения о структуре EEClass, связанной с типом.

Команда DumpClass отображает значения статических полей, но значения нестатических полей не отображаются.

Используйте команду DumpMT, DumpObj, Name2EE или Token2EE, чтобы получить адрес структуры EEClass.
DumpDomain [<адрес> домена] Перечисляет каждый Assembly объект, загруженный в указанный AppDomain адрес объекта. При вызове без параметров команда DumpDomain выводит список всех объектов AppDomain в составе процесса. Так как .NET (Core) имеет только один, AppDomain возвращает только один объект.
DumpHeap [-stat] [-strings] [-short] [-min size]>] [-thinlock] [-startAtLowerBound] [-mt>] [start [end]] Отображает сведения о куче со сборкой мусора и статистику сбора мусора по объектам.

В случае чрезмерной фрагментации кучи сборщика мусора команда DumpHeap выдает соответствующее предупреждение.

Параметр -stat ограничивает выводимую информацию статистической сводкой по типам.

Параметр -strings ограничивает выводимую информацию статистической сводкой по значениям строк.

Параметр -short ограничивает вывод только адресом каждого объекта. Благодаря такому подходу можно легко передавать результат из одной команды отладчика в другую команду с целью автоматизации.

Параметр -min задает пропуск объектов, размер которых меньше значения параметра size, указанного в байтах.

Параметр -max задает пропуск объектов, размер которых больше значения параметра size, указанного в байтах.

Параметр -thinlock сообщает о блокировках ThinLock. Дополнительные сведения см. в описании команды SyncBlk.

Параметр -startAtLowerBound приводит к тому, что обход кучи начинается с нижней границы предоставленного диапазона адресов. На стадии планирования куча часто является неанализируемой, поскольку объекты перемещаются. Этот параметр заставляет DumpHeap начать проверку с указанной нижней границы. Чтобы задействовать этот параметр, необходимо указать адрес допустимого объекта в качестве нижней границы. Можно отобразить память по адресу неверного объекта, чтобы вручную найти следующую таблицу методов. Если сборка мусора выполняется в момент вызова memcopy, также можно найти адрес следующего объекта путем добавления размера к начальному адресу, который указан как параметр.

Параметр -mt задает вывод только тех объектов, которые соответствуют указанной структуре MethodTable.

Параметр -type задает вывод только тех объектов, имя типа которых содержит указанную строку.

Параметр start задает составление списка, начиная с указанного адреса.

Параметр end прекращает составление списка на указанном адресе.
>Managed DynamicMethod | <Указатель> DynamicMethodDesc | <Указатель MethodDesc> Отображает общий промежуточный язык (CIL), связанный с управляемым методом.

Динамический CIL создается не так, как CIL, загруженный из сборки. Динамический CIL относится к объектам в массиве управляемых объектов, а не к маркерам метаданных.
>] [<имя>_файла] Записывает в указанный файл содержимое журнала нагрузок, хранящегося в памяти. Если имя не указано, команда создает файл "StressLog.txt" в текущем каталоге.

Хранящийся в памяти журнал нагрузок помогает при диагностике сбоев, вызываемых нагрузкой, без использования блокировки или ввода-вывода. Чтобы включить журнал стрессов, задайте следующие разделы реестра в разделе HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\. NETFramework:

(DWORD) StressLog = 1

(DWORD) LogFacility = 0xffffffff

(DWORD) StressLogSize = 65536

С помощью необязательного параметра -addr можно указать журнал нагрузки, отличный от журнала по умолчанию.
DumpMD<адрес MethodDesc> Отображает сведения о структуре MethodDesc, находящейся по указанному адресу.

Чтобы получить адрес структуры из управляемой функции, можно использовать команду MethodDesc.
DumpMT [-MD] <адрес MethodTable> Отображает сведения о таблице методов, расположенной по указанному адресу. Параметр -MD задает вывод списка всех методов, определенных вместе с объектом.

Каждый управляемый объект содержит указатель на таблицу методов.
DumpModule [-mt] <адрес модуля> Отображает информацию о модуле, находящемся по указанному адресу. Параметр -mt задает отображение типов, определенных в модуле, и типов, на которые имеются ссылки в модуле

Чтобы получить адрес модуля, можно использовать команду DumpDomain или DumpAssembly.
DumpObj [-nofields] <адрес объекта>

–или–

DO<адрес объекта>
Отображает сведения об объекте, находящемся по указанному адресу. Команда DumpObj отображает список полей, сведения о структуре EEClass, таблицу методов и размер объекта.

Чтобы получить адрес объекта, можно использовать команду DumpStackObjects.

Команду DumpObj можно выполнять для полей типа CLASS, поскольку они также являются объектами.

Параметр -nofields не предотвращает отображение полей объекта, что удобно для таких объектов, как String.
DumpRuntimeTypes Отображает объекты типы среды выполнения в куче сборщика мусора и выводит список связанных с ними имен типов и таблиц методов.
DumpStack [-EE] [-n] [ стек [topbottom]] Отображает трассировку стека.

Параметр -EE команды DumpStack задает отображение только управляемых функций. Параметры top и bottom позволяют ограничить состав отображаемых кадров стека на платформах x86.

Параметр -n отключает отображение имен исходных файлов и номеров строк. Если для отладчика указан параметр "SYMOPT_LOAD_LINES", расширение отладки SOS ищет символы для каждого управляемого кадра и в случае успеха отображает соответствующее имя исходного файла и номер строки. Такое поведение можно отключить, задав параметр -n (без номеров строк).
DumpSig<sigaddr><moduleaddr> Отображает сведения о структуре Sig, находящейся по указанному адресу.
DumpSigElem<sigaddr><moduleaddr> Отображает единственный элемент объекта сигнатуры. В большинстве случаев следует использовать DumpSig для просмотра отдельных объектов сигнатур. Тем не менее, если сигнатура каким-либо образом повреждена, можно использовать DumpSigElem для чтения ее допустимых частей.
DumpStackObjects [-verify] [topstack [bottomstack]]

–или–

DSO [-verify] [topstack [bottomstack]]
Отображает все управляемые объекты, обнаруженные в пределах границ текущего стека.

Параметр -verify проверяет каждое нестатическое CLASS поле поля объекта.

Для определения значений локальных переменных и параметров используйте команду DumpStackObject вместе с командами трассировки стека, такими как K (windbg) или bt (lldb) и clrstack.
DumpVC<адрес MethodTable><адрес> Отображает сведения о полях класса значений, находящегося по указанному адресу.

Параметр MethodTable позволяет команде DumpVC правильно интерпретировать поля. В классах значений первое поле не содержит таблицу методов.
EEHeap [-gc] [-loader] Отображение сведений о памяти процесса, занимаемой внутренними структурами данных среды выполнения.

Параметры -gc и -loader ограничивают выходные данные этой команды только сведениями о структурах данных сборщика мусора и загрузчика.

Сведения о сборщике мусора включает в себя диапазоны каждого сегмента в управляемой куче. Если указатель попадает в диапазон сегмента, заданный параметром -gc, значит, он является указателем объекта.
EEStack [-short] [-EE] Выполняет команду DumpStack для всех потоков в составе процесса.

Параметр -EE передается непосредственно в команду DumpStack. Параметр -short ограничивает выходные данные следующими видами потоков.

Потоки с блокировкой.

Потоки, остановленные для сбора мусора.

Потоки, которые в данный момент находятся в управляемом коде.
EHInfo [<адрес> MethodDesc] [<адрес> кода] Отображает блоки обработки исключений в указанном методе. Данная команда выводит адреса кода и смещения для блока предложений (блока try) и блока обработчика (блока catch).
Вопросы и ответы Отображает вопросы и ответы. Не поддерживается в dotnet-dump.
FinalizeQueue [-detail] | [-allReady] [-short] Отображает все объекты, зарегистрированные для заключительной обработки.

Параметр -detail задает вывод дополнительной информации обо всех блоках SyncBlocks, которые необходимо очистить, и оболочках RuntimeCallableWrappers, ожидающих очистки. Поток завершения кэширует и очищает обе эти структуры данных.

Параметр -allReady отображает все объекты, которые уже готовы к завершению без учета того, помечены они для сборки мусора или будут помечены следующей сборкой мусора. Объекты, отсутствующие в списке "готовые для завершения", — это завершаемые объекты, которые больше не являются корневым. Применение этого параметра может быть очень затратным, поскольку проверяется, все ли объекты в завершаемых очередях по-прежнему являются корневыми.

Параметр -short ограничивает вывод адресом каждого объекта. При использовании в сочетании с -allReady он перечисляет все объекты с методом завершения, которые больше не являются корневыми. При независимом использовании создает список всех объектов в очередях "поддерживающие завершение" и "готовые для завершения".
FindAppDomain<адрес объекта> Определяет домен приложения для объекта, находящегося по указанному адресу.
FindRoots-gen<N> | -gen any |<адрес объекта> Вызывает остановку отладчика в отлаживаемом объекте следующей коллекции заданного поколения. Эффект сбрасывается, как только произойдет останов. Чтобы остановиться на следующей коллекции, необходимо повторное выполнение команды. Форма <адреса> объекта этой команды используется после разрыва, вызванного произошло -gen или -gen. В этот момент отлаживаемый объект находится в правильном состоянии для FindRoots для идентификации корневых элементов для объектов из поколений, уничтожаемых в данный момент. Поддерживается только в Windows.
GCHandles [-perdomain] Отображает статистику дескрипторов сборщика мусора в составе процесса.

Параметр -perdomain упорядочивает статистику по доменам приложений.

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

Поддерживается только в Windows.
GCHandleLeaks Ищет в памяти ссылки на строгие и закрепленные дескрипторы сборщика мусора в рамках процесса и отображает результаты. При обнаружении дескриптора команда GCHandleLeaks отображает адрес ссылки. Если дескриптор в памяти не найден, выдается уведомление. Поддерживается только в Windows.
GCInfo<адрес MethodDesc><адрес в коде> Отображает данные, показывающие, содержатся ли управляемые объекты в регистрах или ячейках стека. Если производится сбор мусора, сборщик должен знать расположение ссылок на объекты, чтобы их можно было обновить новыми значениями указателей объектов.
Адрес объекта GCRoot [-nostacks] [-all] <> Отображает информацию о ссылках (или корневых элементах) объекта, находящегося по указанному адресу.

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

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

Параметр -nostacks ограничивает поиск дескрипторами сборщика мусора и достижимыми объектами.

Параметр -all задает отображение всех корневых элементов, а не только уникальных.
Адрес объекта GCWhere<> Отображает расположение и размер переданного аргумента в куче для сборки мусора. Если аргумент располагается в управляемой куче, но не является адресом допустимого объекта, размер отображается как "0" (нуль).
Справка (soshelp) [<command>] [faq] Отображает все доступные команды при отсутствии параметров или, если указана команда, — подробные справочные сведения об этой команде.

Параметр faq задает отображение ответов на часто задаваемые вопросы.
HeapStat [-inclUnrooted-iu | ] Отображает размеры поколений для каждой кучи и общий объем свободного места в каждом поколении каждой кучи. Если указан параметр -inclUnrooted, отчет содержит сведения об управляемых объектах в куче для сборки мусора, которая больше не является корневой. Поддерживается только в Windows.
HistClear Освобождает все ресурсы, используемые семейством команд Hist.

Как правило, прямой вызов HistClear не требуется, так как каждая команда HistInit очищает предыдущие ресурсы.
HistInit Инициализирует структуры SOS из журнала нагрузки, сохраненного в отлаживаемом объекте.
Obj_address HistObj<> Проверяет все записи журнала перемещения нагрузки и отображает цепочку перемещений сборки мусора, которые могли привести к адресу, переданному в качестве аргумента.
Obj_address HistObjFind<> Отображает все записи журнала, ссылающиеся на объект по указанному адресу.
Корень HistRoot<> Отображает сведения о повышениях и перемещениях указанного корневого элемента.

Корневое значение можно использовать для отслеживания движения объекта в сборках мусора.
Ip2MD (ip2md) <Code address> Отображает структуру MethodDesc по указанному адресу в коде после его JIT-компиляции.
ListNearObj (lno) <obj_address> Отображает объекты перед указанным адресом и после него. Команда находит в куче для сборки мусора адрес, напоминающий допустимое начало управляемого объекта (в зависимости от таблицы допустимых методов), и объект, следующий за адресом аргумента. Поддерживается только в Windows.
MinidumpMode [0] [1] Запрещает выполнение небезопасных команд при использовании минидампа.

Значение 0 отключает этот режим, а значение 1 включает его. По умолчанию значение MinidumpMode равно 0.

Минидампы, созданные с помощью команды .dump /m или .dump, содержат ограниченный набор данных, связанных с CLR, и позволяют корректно выполнять лишь часть команд SOS. Выполнение некоторых команд может завершаться сбоем из-за непредвиденных ошибок, вызываемых тем, что требуемые области памяти не сопоставлены или сопоставлены лишь частично. Данный параметр блокирует запуск небезопасных команд для минидампов.

Поддерживается только в WinDbg.
Имя модуля Name2EE (name2ee) или имя<><>

–или–

Name2EE<имя модуля>!<имя типа или метода>
Отображает структуры MethodTable и EEClass для указанного типа или метода в указанном модуле.

Указанный модуль должен быть загружен в процесс.

Чтобы получить правильное имя типа, просмотрите модуль с помощью Ildasm.exe (дизассемблера IL). Можно также передать * в качестве параметра имени модуля, чтобы просматривались все загруженные управляемые модули. Параметр имя модуля может также содержать имя отладчика для модуля, например mscorlib или image00400000.

Эта команда поддерживает синтаксис <module>!<type>отладчика Windows. Имя типа должно быть полным.
ObjSize [<адрес> объекта] | [-агрегат] [-stat] Отображает размер указанного объекта. Если параметры не указаны, команда ObjSize отображает размеры всех объектов, найденных в управляемых потоках, все дескрипторы сборщика мусора в данном процессе, а также общий размер всех объектов, указываемых этими дескрипторами. Команда ObjSize включает в размер каждого родительского объекта размер всех его дочерних объектов.

Параметр -aggregate можно использовать в сочетании с аргументом -stat, чтобы получить подробное представление типов, которые по-прежнему являются корневыми. С помощью !dumpheap -stat и !objsize -aggregate -stat можно определить, какие объекты больше не являются корневыми, и провести диагностику различных проблем с памятью.

Поддерживается только в Windows.
PrintException [-nested] [-lines] [<адрес> объекта исключения]

–или–

PE [вложенный] [<адрес> объекта исключения]
Отображает и форматирует поля всех производных объектов класса Exception, находящегося по указанному адресу. Если адрес не задан, команда PrintException отображает последнее исключение, возникшее в текущем потоке.

Параметр -nested задает отображение сведений о вложенных объектах исключений.

Если доступен, параметр -lines отображает сведения об источнике.

С помощью этой команды можно форматировать и просматривать поле _stackTrace, представляющее собой двоичный массив.
ProcInfo [-env] [-time] [-mem] Отображает переменные среды для статистики процесса, процессорного времени ядра и использования памяти. Поддерживается только в WinDbg.
RCWCleanupList<адрес RCWCleanupList> Отображает список вызываемых оболочек среды выполнения по указанному адресу, ожидающих очистки. Поддерживается только в WinDbg.
SaveModule<базовый адрес><имя_файла> Записывает в указанный файл образ, загруженный в память по указанному адресу. Поддерживается только в WinDbg.
SetHostRuntime [<runtime-directory>] Эта команда задает путь к среде выполнения .NET для размещения управляемого кода, который выполняется в рамках SOS в отладчике (lldb). Среда выполнения должна иметь версию не ниже 2.1.0. Если в имени каталога есть пробелы, необходимо использовать одинарные кавычки (').

Как правило, SOS пытается найти установленную среду выполнения .NET для автоматического запуска управляемого кода, но эта команда доступна при сбое. По умолчанию используется та же среда выполнения (libcoreclr), для которой выполняется отладка. Используйте эту команду, если среды выполнения, для которой выполняется отладка, недостаточно для выполнения кода SOS или если она имеет версию ниже 2.1.0.

Если при выполнении команды SOS вы получили следующее сообщение об ошибке, используйте эту команду, чтобы задать путь к 2.1.0 или большей среде выполнения .NET.

(lldb) clrstack
Error: Fail to initialize CoreCLR 80004005 ClrStack failed

(lldb) sethostruntime /usr/share/dotnet/shared/Microsoft.NETCore.App/2.1.6

Чтобы найти путь установленной среды выполнения .NET, можно использовать dotnet-info в командной оболочке.
SetSymbolServer [-ms] [-disable] [-log] [-loadsymbols]>] [-directory search-directory<>] [-sympath<windows-symbol-path>] [<symbol-server-URL>] Включает поддержку скачивания с сервера символов.

Параметр -ms разрешает скачивание с общедоступного сервера символов Майкрософт.

Параметр -disable включает поддержку скачивания символов.

Параметр -cache-cache-path<> указывает каталог кэша символов. Если этот каталог не задан, по умолчанию используется $HOME/.dotnet/symbolcache.

Параметр -directory добавляет путь для поиска символов. Можно задавать несколько путей.

Параметр -sympath добавляет пути к серверу, кэшу и каталогу в формате пути к символам Windows.

Параметр -log включает ведение журнала скачивания символов.

Параметр -downloadymbols пытается скачать собственные символы .NET для среды выполнения. Поддерживается в lldb и dotnet-dump.
SOSFlush Очищает внутренний кэш SOS.
SOSStatus [-reset] Отображает внутреннее состояние SOS или сбрасывает внутреннее кэшированное состояние.
StopOnException [-производный] [-create-create2 | ] <Номер псевдорегистрирования исключений><> Предписывает отладчику остановиться при возникновении указанного исключения и продолжать работу при возникновении других исключений.

Параметр -derived задает перехват указанного исключения и всех производных от него исключений.

Поддерживается только в WinDbg.
SyncBlk [-all | <номер syncblk>] Отображает указанную структуру SyncBlock или все структуры SyncBlock. При отсутствии аргументов команда SyncBlk отображает структуру SyncBlock, соответствующую объектам, владельцем которых является поток.

Структура SyncBlock представляет собой контейнер для дополнительной информации, которую необязательно создавать для каждого объекта. Она может включать данные COM-взаимодействия и сведения о блокировке для потокобезопасных операций.
ThreadPool Отображает сведения о пуле управляемых потоков, включая число рабочих запросов в очереди, число потоков портов завершения и число таймеров.
Threads (clrthreads) [-live] [-special] Отображает все управляемые потоки в процессе.

Команда Threads отображает сокращенный идентификатор отладчика, идентификатор потока среды CLR и идентификатор потока операционной системы. Кроме того, команда Threads отображает столбец Domain, содержащий домен приложения, в котором выполняется поток, столбец APT, в котором показан режим COM-контейнера, и столбец Exception, где указано последнее исключение, возникшее в потоке.

Параметр -live задает отображение потоков, связанных с активным потоком.

Параметр -special задает отображение всех специальных потоков, созданных средой CLR. К специальным потокам относятся потоки сборки мусора (для параллельной сборки мусора и серверной сборки мусора), вспомогательные потоки отладчика, потоки метода завершения, потоки выгрузки AppDomain и потоки таймера пула потоков.
ThreadState <значение поля состояния> Отображает состояние потока. Параметр value представляет собой значение поля State в выводе отчета Потоки.
Token2EE<имя модуля><токен> Преобразует указанный токен метаданных указанного модуля в структуру MethodTable или MethodDesc.

В качестве параметра имени модуля можно указать *, чтобы узнать, с чем сопоставляется токен в каждом из загруженных управляемых модулей. Можно также задать имя отладчика для модуля, например mscorlib или image00400000.
U [-gcinfo] [-ehinfo] [-n]< MethodDesc address | ><Адрес кода> Отображает дизассемблированный код с примечаниями для управляемого метода, заданного указателем структуры MethodDesc или адресом кода в теле метода. Команда U отображает весь метод от начала до конца, с примечаниями, преобразующими токены метаданных в имена.

Параметр -gcinfo предписывает команде U отобразить структуру GCInfo метода.

Параметр -ehinfo задает отображение сведений об исключениях в методе. Эту информацию можно также получить с помощью команды EHInfo.

Параметр -n отключает отображение имен исходных файлов и номеров строк. Если для отладчика указан параметр "SYMOPT_LOAD_LINES", расширение отладчика SOS ищет символы для каждого управляемого кадра и в случае успеха отображает соответствующее имя исходного файла и номер строки. Чтобы отключить это поведение, можно указать параметр -n.
VerifyHeap Проверяет кучу сборщика мусора на наличие признаков повреждения и отображает обнаруженные ошибки.

Повреждения кучи могут быть вызваны неправильно созданными вызовами неуправляемого кода.
VerifyObj<адрес объекта> Проверяет объект, передаваемый в качестве аргумента, на наличие повреждений. Поддерживается только в Windows.
VMMap Выполняет обход виртуального адресного пространства и отображает тип защиты для каждого региона. Поддерживается только в WinDbg.
VMStat Создает сводное представление виртуального адресного пространства, упорядоченное по типам защиты соответствующих видов памяти (свободная, зарезервированная, выделенная, закрытая, отображаемая, образ). В столбце "TOTAL" содержится результат умножения значения в столбце "AVERAGE" на значение в столбце "BLK COUNT". Поддерживается только в WinDbg.

Dotnet-Dump

Список доступных команд SOS с dotnet-dump analyze см. в разделе dotnet-dump.

Отладчик Windows

Вы также можете использовать расширение отладки SOS, загрузив его в отладчик WinDbg/dbg и выполнив команды в отладчике Windows. Команды SOS можно использовать для активных процессов или дампов.

Отладчик LLDB

Инструкции по настройке расширения SOS для LLDB см. в разделе dotnet-sos. Команды SOS можно использовать для активных процессов или дампов.

По умолчанию можно получить доступ ко всем командам SOS, введя sos [command_name]. Тем не менее стандартные команды имеют псевдонимы, в связи с чем префикс sos не нужен:

Команда Function
analyzeoom Отображает сведения о последнем объекте OOM, возникшем в запросе на выделение кучи GC.
bpmd Создание точки останова в указанном управляемом методе указанного модуля.
clrmodules Перечисляет управляемые модули в процессе.
clrstack Обеспечивает трассировку стека только для управляемого кода.
clrthreads Перечисляет управляемые потоки, которые выполняются.
clru Отображение дизассемблированного кода с аннотациями для управляемого метода.
dbgout Включает или отключает-off внутреннее ведение журнала SOS.
dso Отображает все управляемые объекты, обнаруженные в пределах границ текущего стека.
dumpalc Отображает сведения о коллекционируемом assemblyLoadContext, в который загружается указанный объект.
dumparray Отображает сведения об управляемом массиве.
dumpasync Отображение сведений об асинхронных конечных автоматах для кучи со сборкой мусора.
dumpassembly Отображение сведений о сборке.
dumpclass Отображение сведений о структуре EEClass, находящейся по указанному адресу.
dumpconcurrentdictionary Отображает параллельное содержимое словаря.
dumpconcurrentqueue Отображает содержимое параллельной очереди.
dumpdelegate Отображение сведений о делегате.
dumpdomain Отображает сведения обо всех сборках в пределах всех доменов приложений или указанных.
dumpgcdata Отображает сведения о данных GC.
dumpgen Отображает содержимое кучи для указанного поколения.
dumpheap Отображение сведений о куче со сборкой мусора и статистики сборки мусора по объектам.
dumpil Отображает общий промежуточный язык (CIL), связанный с управляемым методом.
dumplog Записывает в указанный файл содержимое журнала нагрузок, хранящегося в памяти.
dumpmd Отображение сведений о структуре MethodDesc, находящейся по указанному адресу.
dumpmodule Отображение сведений о модуле, находящемся по указанному адресу.
dumpmt Отображение сведений о таблице методов, расположенной по указанному адресу.
dumpobj Отображение сведений об объекте, находящемся по указанному адресу.
dumpruntimetypes Находит все объекты System.RuntimeType в куче GC и выводит имя типа и MethodTable, которые они ссылаются.
dumpsig Дамп подписи метода или поля, указанного в <sigaddr> <moduleaddr>.
dumpsigelem Дамп одного элемента объекта сигнатуры.
dumpstack Отображение трассировки машинного и управляемого стека.
dumpstackobjects Отображает все управляемые объекты, обнаруженные в пределах границ текущего стека.
dumpvc Отображает сведения о полях класса значений.
eeheap Отображение сведений о памяти процессов, занятой внутренними структурами данных среды выполнения.
eestack Выполнение команды dumpstack для всех потоков в составе процесса.
eeversion Отображает сведения о версиях среды выполнения и SOS.
ehinfo Отображает блоки обработки исключений в методе JIT-ed.
finalizequeue Отображает все объекты, зарегистрированные для заключительной обработки.
findappdomain Пытается устранить домен приложения объекта GC.
findroots Находит и отображает корни объектов в коллекциях GC.
gchandles Отображает статистику дескрипторов сборщика мусора в составе процесса.
gcheapstat Отображает статистику о сборщике мусора.
gcinfo Отображает кодировку JIT GC для метода.
gcroot Отображение сведений о ссылках (или корневых элементах) объекта, который расположен по указанному адресу.
gcwhere Отображает расположение в куче GC указанного адреса.
histclear Освобождение всех ресурсов, используемых семейством команд Hist.
histinit Инициализирует структуры SOS из журнала нагрузки, сохраненного в отлаживаемом объекте.
histobj Проверяет все записи журнала перемещения нагрузки и отображает цепочку перемещений сборки мусора, которые могли привести к адресу, переданному в качестве аргумента.
histobjfind Отображение всех записей журнала, ссылающихся на объект по указанному адресу.
histroot Отображает сведения о повышениях и перемещениях указанного корневого элемента.
histstats Отображает статистику журнала стресса.
ip2md Отображает структуру MethodDesc по указанному адресу в коде после его JIT-компиляции.
listnearobj Отображает предыдущий объект и успешное выполнение указанного адреса.
loadsymbols Загружает символы собственного модуля .NET.
logging Включает или отключает внутреннее ведение журнала SOS.
name2ee Отображение структур MethodTable и EEClass для указанного типа или метода в указанном модуле.
objsize Отображает размер указанного объекта.
parallelstacks Отображает стек объединенных потоков аналогично панели "Параллельные стеки" Visual Studio.
pathto Отображает путь к GC от <root><target>.
pe Отображает и форматирует поля всех производных объектов класса Exception, находящегося по указанному адресу.
printexception Отображает и форматирует поля всех производных объектов класса Exception, находящегося по указанному адресу.
runtimes Выводит список сред выполнения в целевом объекте или измените среду выполнения по умолчанию.
stoponcatch Целевой процесс прерывает следующий раз, когда во время выполнения перехватится управляемое исключение.
setclrpath Задание пути для загрузки файлов coreclr dac/dbi. setclrpath <path>.
sethostruntime Задает или отображает каталог среды выполнения .NET, используемый для запуска управляемого кода в SOS.
setsymbolserver Включение поддержки сервера символов.
setsostid Задание текущего индекса TID или потока операционной системы вместо предоставляемого средством lldb. setsostid <tid> <index>.
sos Выполняет различные команды отладки coreclr. Используйте синтаксис sos <command-name> <args>. Дополнительные сведения можно получить с помощью команды soshelp.
soshelp Отображает все доступные команды, если параметр не указан или отображает подробные сведения о указанной команде: soshelp <command>
syncblk Отображение сведений о заполнителе SyncBlock.
taskstate Отображает состояние задачи в удобочитаемом формате.
threadpool Отображает сведения о пуле потоков среды выполнения.
threadpoolqueue Отображает рабочие элементы пула потоков очереди.
threadstate Довольно печатает значение состояния потоков.
timerinfo Отображает сведения о выполнении таймеров.
token2ee Отображает структуру MethodTable и структуру MethodDesc для указанного токена и модуля.
traverseheap Записывает данные кучи в файл в формате, понятном профилировщиком СРЕДЫ CLR.
verifyheap Проверяет кучу GC на наличие признаков повреждения.
verifyobj Проверяет объект, передаваемый в качестве аргумента, на наличие повреждений.

Пример использования Windbg/cdb

Команда Description
!dumparray -start 2 -length 5 -details 00ad28d0 Отображение содержимого массива по адресу 00ad28d0. Отображаются данные для пяти элементов массива, начиная со второго.
!dumpassembly 1ca248 Отображение содержимого сборки по адресу 1ca248.
!dumpheap Отображение сведений о куче сборщика мусора.
!DumpLog Запись содержимого журнала нагрузок в памяти в файл "StressLog.txt" (по умолчанию), расположенный в текущем каталоге.
!dumpmd 902f40 Отображение структуры MethodDesc по адресу 902f40.
!dumpmodule 1caa50 Отображение сведений о модуле, находящемся по адресу 1caa50.
!DumpObj a79d40 Отображение сведений об объекте, находящемся по адресу a79d40.
!DumpVC 0090320c 00a79d9c Отображение полей класса значений по адресу 00a79d9c с использованием таблицы методов по адресу 0090320c.
!eeheap -gc Отображение памяти процесса, используемой сборщиком мусора.
!finalizequeue Отображение всех объектов, запланированных для заключительной обработки.
!findappdomain 00a79d98 Определение домена приложения для объекта, находящегося по адресу 00a79d98.
!gcinfo 5b68dbb8 Отображение всех дескрипторов сборщика мусора в текущем процессе.
!name2ee unittest.exe MainClass.Main Отображение структур MethodTable и EEClass для метода Main класса MainClass в модуле unittest.exe.
!token2ee unittest.exe 02000003 Отображение сведений о токене метаданных по адресу 02000003 в модуле unittest.exe.

Пример использования LLDB

Команда Description
dumparray -start 2 -length 5 -details 00ad28d0 Отображение содержимого массива по адресу 00ad28d0. Отображаются данные для пяти элементов массива, начиная со второго.
dumpassembly 1ca248 Отображение содержимого сборки по адресу 1ca248.
dumpheap Отображение сведений о куче сборщика мусора.
dumplog Запись содержимого журнала нагрузок в памяти в файл "StressLog.txt" (по умолчанию), расположенный в текущем каталоге.
dumpmd 902f40 Отображение структуры MethodDesc по адресу 902f40.
dumpmodule 1caa50 Отображение сведений о модуле, находящемся по адресу 1caa50.
dumpobj a79d40 Отображение сведений об объекте, находящемся по адресу a79d40.
dumpvc 0090320c 00a79d9c Отображение полей класса значений по адресу 00a79d9c с использованием таблицы методов по адресу 0090320c.
eeheap -gc Отображение памяти процесса, используемой сборщиком мусора.
findappdomain 00a79d98 Определение домена приложения для объекта, находящегося по адресу 00a79d98.
gcinfo 5b68dbb8 Отображение всех дескрипторов сборщика мусора в текущем процессе.
name2ee unittest.exe MainClass.Main Отображение структур MethodTable и EEClass для метода Main класса MainClass в модуле unittest.exe.
token2ee unittest.exe 02000003 Отображение сведений о токене метаданных по адресу 02000003 в модуле unittest.exe.
clrthreads Отображение управляемых потоков.

См. также