Auto detect the number of CPU's and set worker_processes

Gena Makhomed gmm at csdoc.com
Mon Sep 17 16:38:08 UTC 2012


On 17.09.2012 16:12, Валентин Бартенев wrote:

>> http://stackoverflow.com/questions/150355/programmatically-find-the-number-
>> of-cores-on-a-machine

> Ни один из описанных там способов не дает гарантированно количества физических
> ядер в системе, кроме, пожалуй, использование CPUID (что является Intel/AMD
> specific и добавляет бесконечное количество головной боли).

команда cpuid используется в nginx для определения ngx_cacheline_size.
и что-то не заметно там никакого бесконечного количества головной боли.

кстати, есть еще такой проект: http://www.open-mpi.org/projects/hwloc/
практически везде где это можно, определяет количество физических ядер.

> auto, реализованное таким образом, иногда будет принимать значение 1, очень
> часто 2*cores, а, возможно, в отдельных случаях, вообще непонятно что.

> В Linux правильным способом будет ходить по
> /sys/devices/system/cpu/cpuN/topology/

по крайней мере, для всех CPU Intel / AMD и для всех OS Linux можно
точно определить количество физических ядер, а это более 80% случаев.

например, aio нормально работает только в FreeBSD - но это ведь не было
причиной почему нельзя добавлять такую фичу в nginx. так же и с ядрами.

-- 
Best regards,
  Gena



Подробная информация о списке рассылки nginx-ru