.\" -*- coding: UTF-8 -*- .\" Copyright (C) 2014 Michael Kerrisk .\" .\" SPDX-License-Identifier: Linux-man-pages-copyleft .\" .\"******************************************************************* .\" .\" This file was generated with po4a. Translate the source file. .\" .\"******************************************************************* .TH sprof 1 "15 июня 2024 г." "Справочные страницы Linux 6.9.1" .SH ИМЯ sprof \- читает и показывает общие объекты данных профилирования .SH СИНТАКСИС .nf \fBsprof\fP [\fIпараметр\fP]… \fIshared\-object\-path\fP [\fIprofile\-data\-path\fP] .fi .SH ОПИСАНИЕ Команда \fBsprof\fP выводит краткий отчёт по профилированию для общего объекта (общей библиотеки), заданного в первом аргументе командной строки. Краткий отчёт по профилированию создан с помощью ранее сгенерированных данных профилирования во втором (необязательном) аргументе командной строки. Если путь данных профилирования отсутствует, то \fBsprof\fP попытается вычислить его используя soname общего объекта и поищет файл с именем \fI.profile\fP в текущем каталоге. .SH ПАРАМЕТРЫ Следующие параметры командной строки определяют выводимые данные профилирования: .TP \fB\-\-call\-pairs\fP .TQ \fB\-c\fP Вывести список пар путей вызова для интерфейсов, экспортируемых общим объектом, а также сколько раз использовался каждый путь. .TP \fB\-\-flat\-profile\fP .TQ \fB\-p\fP Сгенерировать плоский профиль всех функций в отслеживаемом объекте, а также количество вызовов и время работы. .TP \fB\-\-graph\fP .TQ \fB\-q\fP Сгенерировать граф вызовов. .P Если ни один из этих параметров не указан, то действием по умолчанию является вывод плоского профиля и графа вызовов. .P Доступны следующие дополнительные параметры командной строки: .TP \fB\-\-help\fP .TQ \fB\-?\fP Показать справку по параметрам командной строки и аргументам и завершить работу. .TP \fB\-\-usage\fP Показать короткое сообщение об использовании и завершить работу. .TP \fB\-\-version\fP .TQ \fB\-V\fP Вывести версию программы и выйти. .SH СТАНДАРТЫ GNU. .SH ПРИМЕРЫ В следующем примере показано использование \fBsprof\fP. Пример состоит из основной программы, которая вызывает две функции из общего объекта. Вот код основной программы: .P .in +4n .EX $ \fBcat prog.c\fP #include \& void x1(void); void x2(void); \& int main(int argc, char *argv[]) { x1(); x2(); exit(EXIT_SUCCESS); } .EE .in .P Функции \fIx1\fP() и \fIx2\fP() определены в следующем файле исходного кода, который используется для сборки общего объекта: .P .in +4n .EX $ \fBcat libdemo.c\fP #include \& void consumeCpu1(int lim) { for (unsigned int j = 0; j < lim; j++) getppid(); } \& void x1(void) { for (unsigned int j = 0; j < 100; j++) consumeCpu1(200000); } \& void consumeCpu2(int lim) { for (unsigned int j = 0; j < lim; j++) getppid(); } \& void x2(void) { for (unsigned int j = 0; j < 1000; j++) consumeCpu2(10000); } .EE .in .P Соберём общий объект с реальным именем \fIlibdemo.so.1.0.1\fP и soname \fIlibdemo.so.1\fP: .P .in +4n .EX $ \fBcc \-g \-fPIC \-shared \-Wl,\-soname,libdemo.so.1 \[rs]\fP \fB\-o libdemo.so.1.0.1 libdemo.c\fP .EE .in .P Создадим символьные ссылки на soname библиотеки и имя библиотеки для компоновщика: .P .in +4n .EX $ \fBln \-sf libdemo.so.1.0.1 libdemo.so.1\fP $ \fBln \-sf libdemo.so.1 libdemo.so\fP .EE .in .P Скомпилируем основную программу, скомпонуем её с общим объектом и выведем список динамических зависимостей программы: .P .in +4n .EX $ \fBcc \-g \-o prog prog.c \-L. \-ldemo\fP $ \fBldd prog\fP linux\-vdso.so.1 => (0x00007fff86d66000) libdemo.so.1 => not found libc.so.6 => /lib64/libc.so.6 (0x00007fd4dc138000) /lib64/ld\-linux\-x86\-64.so.2 (0x00007fd4dc51f000) .EE .in .P Чтобы получить информацию о профилировании общего объекта мы определим переменную окружения \fBLD_PROFILE\fP с soname библиотеки: .P .in +4n .EX $ \fBexport LD_PROFILE=libdemo.so.1\fP .EE .in .P Затем определим переменную окружения \fBLD_PROFILE_OUTPUT\fP с именем каталога куда нужно сохранить результат профилирования и создадим этот каталог, если его ещё нет: .P .in +4n .EX $ \fBexport LD_PROFILE_OUTPUT=$(pwd)/prof_data\fP $ \fBmkdir \-p $LD_PROFILE_OUTPUT\fP .EE .in .P Переменная \fBLD_PROFILE\fP приводит к \fIдобавлению\fP результата профилирования в выходной файл, если он уже существует, поэтому убедимся, что не существует каких\-либо результатов профилирования: .P .in +4n .EX $ \fBrm \-f $LD_PROFILE_OUTPUT/$LD_PROFILE.profile\fP .EE .in .P Затем запустим программу для получения результата профилирования, которые записывается в файл в каталоге, указанном в \fBLD_PROFILE_OUTPUT\fP: .P .in +4n .EX $ \fBLD_LIBRARY_PATH=. ./prog\fP $ \fBls prof_data\fP libdemo.so.1.profile .EE .in .P Используем параметр \fBsprof \-p\fP для генерации плоского профиля с счётчиками и временем: .P .in +4n .EX $ \fBsprof \-p libdemo.so.1 $LD_PROFILE_OUTPUT/libdemo.so.1.profile\fP Flat profile: \& Each sample counts as 0.01 seconds. % cumulative self self total time seconds seconds calls us/call us/call name 60.00 0.06 0.06 100 600.00 consumeCpu1 40.00 0.10 0.04 1000 40.00 consumeCpu2 0.00 0.10 0.00 1 0.00 x1 0.00 0.10 0.00 1 0.00 x2 .EE .in .P Параметр \fBsprof \-q\fP генерирует граф вызовов: .P .in +4n .EX $ \fBsprof \-q libdemo.so.1 $LD_PROFILE_OUTPUT/libdemo.so.1.profile\fP \& index % time self children called name \& 0.00 0.00 100/100 x1 [1] [0] 100.0 0.00 0.00 100 consumeCpu1 [0] \-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\- 0.00 0.00 1/1 [1] 0.0 0.00 0.00 1 x1 [1] 0.00 0.00 100/100 consumeCpu1 [0] \-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\- 0.00 0.00 1000/1000 x2 [3] [2] 0.0 0.00 0.00 1000 consumeCpu2 [2] \-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\- 0.00 0.00 1/1 [3] 0.0 0.00 0.00 1 x2 [3] 0.00 0.00 1000/1000 consumeCpu2 [2] \-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\- .EE .in .P Выше и ниже строки «» представляют идентификаторы, которые находятся вне объекта профилирования (в этом примере они являются экземплярами \fImain()\fP). .P Параметр \fBsprof \-c\fP генерирует список пар вызовов и количество их появления: .P .in +4n .EX $ \fBsprof \-c libdemo.so.1 $LD_PROFILE_OUTPUT/libdemo.so.1.profile\fP x1 1 x1 consumeCpu1 100 x2 1 x2 consumeCpu2 1000 .EE .in .SH "СМОТРИТЕ ТАКЖЕ" \fBgprof\fP(1), \fBldd\fP(1), \fBld.so\fP(8) .PP .SH ПЕРЕВОД Русский перевод этой страницы руководства разработал(и) Alexander Golubev , Azamat Hackimov , Hotellook, Nikita , Spiros Georgaras , Vladislav , Yuri Kozlov и Иван Павлов . .PP Этот перевод является свободной программной документацией; он распространяется на условиях общедоступной лицензии GNU (GNU General Public License - GPL, .UR https://www.gnu.org/licenses/gpl-3.0.html .UE версии 3 или более поздней) в отношении авторского права, но БЕЗ КАКИХ-ЛИБО ГАРАНТИЙ. .PP Если вы обнаружите какие-либо ошибки в переводе этой страницы руководства, пожалуйста, сообщите об этом разработчику(ам) по его(их) адресу(ам) электронной почты или по адресу .MT списка рассылки русских переводчиков .ME .