Одно ядро исключительно для моего процесса
Возможный дубликат:
Как установить сродство процессора конкретного pthread?
В Linux есть способ отключить одно ядро для всех процессов, кроме одного? Я хотел бы зарезервировать только одно ядро и только для моего процесса.
Ожидаемое поведение выглядит следующим образом:
- Процессы, которые будут порождены после моего процесса, не должны видеть это ядро и использовать другие.
- Когда мой процесс порожден, все процессы, использующие это ядро, должны быть переключены на другие ядра.
2 ответа
Да, есть. Вы хотите создать два процессора, один со своим изолированным процессором, а другой со всеми остальными процессорами. Назначьте свой специальный процесс изолированному процессору, а все остальные процессы - другому процессору.
Вот простой пример сценария, который сделает это:
mkdir /cpuset
mount -t cpuset none /cpuset/
cd /cpuset
mkdir sys # create sub-cpuset for system processes
/bin/echo 0-2 > sys/cpuset.cpus # assign cpus (cores) 0-2 to this set
# adjust if you have more/less cores
/bin/echo 1 > sys/cpuset.cpu_exclusive
/bin/echo 0 > sys/cpuset.mems
mkdir rt # create sub-cpuset for my process
/bin/echo 3 > rt/cpuset.cpus # assign cpu (core) 3 to this cpuset
# adjust this to number of cores-1
/bin/echo 1 > rt/cpuset.cpu_exclusive
/bin/echo 0 > rt/cpuset.mems
/bin/echo 0 > rt/cpuset.sched_load_balance
/bin/echo 1 > rt/cpuset.mem_hardwall
# move all processes from the default cpuset to the sys-cpuset
for T in `cat tasks`; do echo "Moving " $T; /bin/echo $T > sys/tasks; done
Теперь запустите ваш процесс, узнайте его PID и перейдите:
/bin/echo $PID > /cpuset/rt/tasks
Если вы хотите отменить эти изменения, просто перезагрузите систему или выполните:
# move tasks back from sys-cpuset to root cpuset
for T in `cat /cpuset/sys/tasks`; do echo "Moving " $T; /bin/echo $T > /cpuset/tasks; done
# remove sys-cpuset
rmdir /cpuset/sys
# move tasks back from rt-cpuset to root cpuset
for T in `cat /cpuset/rt/tasks`; do echo "Moving " $T; /bin/echo $T > /cpuset/tasks; done
# remove rt-cpuset
rmdir /cpuset/rt
# unmount and remove /cpuset
umount /cpuset
rmdir /cpuset
Вот страница руководства: http://www.kernel.org/doc/man-pages/online/pages/man7/cpuset.7.html
Есть также более сложные оболочки, которые могут помочь вам автоматизировать это, такие как cset. См.: http://web.archive.org/web/20120428093126/http://www.suse.com/documentation/slerte_11/slerte_tutorial/data/slerte_tutorial.html
Вы можете взглянуть на эту статью для обсуждения решения ядра этой проблемы.