Мой конкретный сценарий заключается в следующем. Я запускаю Docker-контейнер с определенным процессором:
docker run --cpuset-cpus="0-2" # ...
внутри этого контейнера я запускаю сценарий оболочки в качестве точки входа, и этот сценарий оболочки будет запускаться makeв какой-то момент. Я хотел бы выяснить, какое количество рабочих мест ( -j) будет. Конечно, я мог бы передать количество выделенных процессоров через среду, но автоматический способ его обнаружения был бы гораздо предпочтительнее.
Я знаю, что могу использовать taskset -c -p $$или cat /proc/self/status | grep Cpus_allowed_listдля получения Cpus_allowedтекущего процесса, но я не знаю, как получить фактическое количество разрешенных процессоров. Я хотел бы избежать синтаксического анализа вывода этих команд или возиться с Cpus_allowedмаской, но сделаю это, когда нет параметров.
nproc- напечатать количество доступных единиц обработки