Как узнать ядро на котором работает процесс Linux

Когда вы запускаете программы, для которых очень важна максимальная производительность или сильно использующие сетевую пропускную способность на многоядерных процессорах или архитектуре, основанной на технологии NUMA, взаимодействие CPU и памяти — один из самых важных факторов для получения максимальной производительности.

Выполнение тесно связанных процессов на одном узле NUMA ускорит доступ к памяти, чем если бы данные получались удаленно.

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

Способ 1

Если программа была привязана к определенному ядру при запуске с помощью таких инструментов, как, например, taskset, можно узнать ядро процессора linux, выполнив ту же команду:

taskset -c -p pid

Например, если у интересующего вас процесса pid 5357:

taskset -c -p 5357

pid 5357's current affinity list: 5

Из вывода понятно, что программа привязана к ядру номер 5. Если же вы явно не привязывали программу, можете получить что-то похожее на это:

pid 5357's current affinity list: 0-11

Это значит что процесс может выполняться на одном из ядер от 0 до 11. В этом случае использование taskset не показательно для определения текущего ядра, поэтому рассмотрим другие методы.

Способ 2

Утилита ps может показать ядро для каждого процесса и нити в колонке PSR:

ps -o pid,psr,comm -p pid

PID PSR COMMAND
5357 10 prog

Из вывода ясно, что процесс с PID 5357 с названием prog сейчас выполняется на десятом ядре. Если процесс не закреплен, колонка PSR покажет ядро, на котором планировщик linux собирается выполнять процесс. Так вы можете узнать, ядро на котором работает поток linux для любого процесса.

Способ 3

Команда top тоже может показать какое ядро получил процесс. Сначала запустите top с опцией -p. Затем нажмите кнопку f и добавьте поле Last Used CPU с помощью пробела. Этот пункт будет во второй колонке списка, а после добавления появится последним. Теперь номер ядра появится в колонке P или PSR:

top -p 5357

21429268426_e7d1d73a04_c

По сравнению с ps, у top есть преимущество — можно наблюдать за изменением используемых ядер в реальном времени.

Способ 4

Еще можно узнать на каком ядре работает процесс linux в реальном времени с помощью утилиты htop. Запустите htop, нажмите кнопку F2, перейдите в раздел Columns, найдите пункт PROCESSOR в меню Available Columns и добавьте его.

Текущее ядро процессора появится в колонке CPU:

21444522832_a5a206f600_c

Заметьте что в отличие от других программ таких как ps и top, htop начинает нумеровать ядра с единицы.

Выводы

Теперь вы знаете как узнать ядро, на котором работает поток linux. Оказывается, это совсем несложно и может очень сильно помочь при оптимизации. Если у вас остались вопросы, спрашивайте в комментариях!

Источник перевода: http://ask.xmodulo.com/cpu-core-process-is-running.html

 

Creative Commons License
Статья Как узнать ядро на котором работает процесс Linux распространяется под лицензией Creative Commons ShareAlike 4.0 при копировании материала ссылка на источник обязательна.
Ваше имя тоже может быть здесь. Начните писать статьи для Losst. Это просто! Смотрите подробнее как начать писать статьи - Пишите для нас

Оцените статью:

Звёзд: 1Звёзд: 2Звёзд: 3Звёзд: 4Звёзд: 5 (Пока оценок нет)
Загрузка...

Ответить

Сообщить об опечатке

Текст, который будет отправлен нашим редакторам: