tobotras: (Default)
[personal profile] tobotras
У линукса есть несколько механизмов ограничить процесс в доступных процессорных ядрах. Как минимум, cgroup и taskset. Если процессу важно знать, сколько у него ядер (чтобы сконфигурировать thread pool или ещё зачем-нибудь), то наивный способ -- прочитать /proc/cpuinfo. Он неправильный. Менее наивный -- позвать sysconf(_SC_NPROCESSORS_ONLN). Он тоже неправильный. Правильный -- вот:
  long num_processor_configured = sysconf (_SC_NPROCESSORS_CONF); /* list the number of processors configured */
  long num_processor_available;
  cpu_set_t mask;

  if (sched_getaffinity(0, sizeof(cpu_set_t), &mask) == 0) {
	num_processor_available = CPU_COUNT(&mask);
  } else {
	num_processor_available = sysconf(_SC_NPROCESSORS_ONLN);
  }

Date: 2014-08-21 03:37 pm (UTC)
From: [identity profile] drf-ckoff.livejournal.com
"Если процессу важно знать, сколько у него ядер" - его надо переписать. ибо никто ему не гарантирует, что этих ядер вдруг не станет меньше или больше.

Date: 2014-08-21 04:54 pm (UTC)
From: [identity profile] ostapru.livejournal.com
Ну, например, всякие считалки/процессилки.
Запускать нитей больше, чем доступное количество ядер не имеет смысла. Поэтому getaffinity и запуск нитей на все доступные ядра.
Как в этом случае переписать, чтобы учитывать изменение количества ядер? Постоянно дергать getaffinity?

Date: 2014-08-21 05:26 pm (UTC)
From: [identity profile] drf-ckoff.livejournal.com
исходить из того, что количество ядер неограничено. прикинуть - после какого количества дальше плодить треды смысла не имеет и столько и делать. а дальше пусть ядро разбирается.

Date: 2014-08-22 02:20 am (UTC)
From: [identity profile] ostapru.livejournal.com
Так оно работает хреново. Если задача хорошо параллелится и синхронизация минимальна, то больше чем поток на ядро - тут же сажает производительность.

Date: 2014-08-21 04:51 pm (UTC)
From: [identity profile] http://users.livejournal.com/_slw/
линуксятина какая-то
пороть на конюшне

Date: 2014-08-21 04:56 pm (UTC)
From: [identity profile] ostapru.livejournal.com
На виндах оно примерно также. Только вызов будет GetProcessAffinityMask().

Date: 2014-08-21 05:00 pm (UTC)
From: [identity profile] http://users.livejournal.com/_slw/
т.е. ты даже не понял, за что пороть?

Date: 2014-08-21 07:37 pm (UTC)
From: [identity profile] http://users.livejournal.com/_slw/
нехорошо пользоваться менее переносимым апи при наличии более переносимого
я про pthread_getaffinity_np, например

Date: 2014-08-21 08:19 pm (UTC)
From: [identity profile] http://users.livejournal.com/_slw/
по факту, sched_getaffinity кроме линуха нигде нет, в отличии от pthread_getaffinity_np

Date: 2014-08-22 02:40 am (UTC)
From: [identity profile] ostapru.livejournal.com
Ну pthread, так pthread.
IMHO, если задача переносимости не ставится, то лучше использовать родной API.

Date: 2014-08-22 05:30 am (UTC)
From: [identity profile] http://users.livejournal.com/_slw/
сегодня не ставится, а завтра -- опа и ставится.
а апи эти поди похожи как близнецы-братья, разница только в инклюдах и префиксах, т.е. все бесплатно, если сразу.

Date: 2014-08-22 05:30 am (UTC)
From: [identity profile] http://users.livejournal.com/_slw/
да ну, это линуха нет

Date: 2014-08-21 07:40 pm (UTC)
From: [identity profile] alec_v.livejournal.com
Количество ядер может ВНЕЗАПНО поменяться, если виртуалка по-живому мигрируется в облаке на другую материнку.

Date: 2014-08-22 06:18 am (UTC)
From: [identity profile] d1f.livejournal.com
А как это правильно сделать из шелла?
Мне нужно знать N для make -jN.

Profile

tobotras: (Default)
tobotras

December 2024

S M T W T F S
123 4567
891011121314
15161718192021
22232425262728
293031    

Most Popular Tags

Style Credit

Expand Cut Tags

No cut tags
Page generated Oct. 1st, 2025 09:43 am
Powered by Dreamwidth Studios