Рейтинг:0

Как рассчитать использование ЦП для приложения в многоядерной системе

флаг de

На 8-ядерном сервере 0-3 ядра настроены как isolcpus, а остальные ядра (4-7) доступны для запуска системных и пользовательских процессов. В моем приложении есть несколько процессов, которые будут работать на любом из упомянутых ядер, отличных от isolcpu (4-7).

Мне нужно найти общее использование ЦП приложением (все процессы вместе), чтобы определить правильный диапазон isolcpus, который нужно настроить для системы.

Я совершенно запутался в этом способе расчета использования ЦП для процесса или группы процессов. Кто-нибудь может просветить меня по-человечески? Спасибо!

Прошел и связанные вопросы, ни один из них не помог: Как время ЦП и загрузка ЦП совпадают?

Рейтинг:0
флаг vn
rvs

Как запустить приложение?

Если вы используете systemd, вы может использовать CPUAccounting= параметр в юнит-файле, и systemd соберет некоторые показатели ЦП. Если вы не используете systemd, вы все равно можете поместите свое приложение в cgroup с включенным учетом вручную.

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

Что вы пытаетесь оптимизировать? Чувствительна ли рабочая нагрузка к задержке? Было бы лучше установить ограничения процессора, отличные от выделенных ядер?

Ответить или комментировать

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