Потоки это популярная программная абстракция для параллельного выполнения в современных операционных системах. Когда программа делиться на потоки для многопоточного выполнения, ресурсы такие как адресное пространство оперативной памяти и открытые файлы делятся между потоками чтобы минимизировать накладные расходы и более эффективно использовать процессорное время. Эти возможности делают потоки эффективным механизмом много поточного выполнения.
Для планировщика ядра потоки ничем не отличаются от обычных процессов которые имеют общие ресурсы. Поэтому для просмотра потоков можно использовать такие классические инструменты командной строки как ps и top. В этой статье мы поговорим о том как посмотреть потоки процесса Linux.
Содержание статьи
Потоки процессов в Linux
Сразу необходимо разобраться в том что же такое процессы и потоки в linux и чем они отличаются от друг от друга. В Linux есть два способа наладить многопоточное выполнение какого-либо действия. Первый, когда процесс создает свои копии с помощью механизма fork и затем эти процессы взаимодействуют через сокеты или IPC. Тогда мы получаем отдельные процессы, каждый процесс имеет свои ресурсы и занимает память. Второй же способ подразумевает выделение потоков в рамках одного процесса. Все протоки одного процесса будут иметь один идентификатор группы потоков, а также уникальный идентификатор потока. Они будут иметь доступ ко всем ресурсам родительского процесса и занимать меньше памяти.
1. Утилита ps
В утилите ps показ потоков процесса включается опцией -T. Например вот такой командой можно посмотреть все потоки процесса с PID, например, для Chromium:
ps -T -p <PID>
В колонке SPID отображается идентификатор потока, а в CMD его имя.
2. Утилита top
Команда top позволяет просматривать потоки в реальном времени. Для включения отображения потоков запустите top с опцией -H. Также можно включить или отключить показ потоков во время выполнения с помощью клавиши H:
top -H
Если вы хотите посмотреть только потоки нужного процесса выполните:
top -H -p pid
3. Утилита htop
Ну и как всегда под конец самое интересное. Самой удобной утилитой для просмотра потоков процесса я считаю команду htop. Это основный на ncurces интерактивный просмотрщик процессов. С помощью этой утилиты вы можете наблюдать за потоками в реальном времени в виде дерева.
Для того чтобы включить просмотр потоков в htop откройте программу, войдите в меню нажав клавишу F2, затем выберите Display Options, в разделе Setup. Теперь отметьте Tree view и Show custom thread names. Все, можно нажимать F10 для сохранения настроек:
Теперь вы можете просматривать потоки в виде дерева отдельно для каждого процесса. Здесь снова отображаются потоки для браузера Chromium:
пардон, что не по теме, но:
"программа делиТСя на потоки для многОПоточного выполнения"
и вам сюда http://tsya.ru/ , ибо уже неоднократно видел в блоге, похоже проблема системная)
А за потоки спасибо. Семь лет ковыряюсь, но не подозревал, что можно их просматривать. Хотя, и необходимости для того не возникало ни разу. Какая практическая польза от просмотра тредов? В решении каких задач это может помочь?
Я пишу свою программку и запускаю несколько синхронных и несколько асинхронных потоков. Мне нужно следить за всем этим зоопарком, чтобы не получилось, что какой- то нужный поток не запустился... А есть графическая утилита?