Нет необходимости устанавливать какой-либо дополнительный пакет, ваш старый добрый оболочка в состоянии сделать это в одиночку.
Этот один лайнер будет загружать ваши четыре ядра1 на 100%:
for i in 1 2 3 4; do while : ; do : ; done & done
Как это работает довольно просто, он начинает четыре бесконечных цикла. Каждый из них повторяет нулевую инструкцию (:
). Каждый цикл способен загрузить ядро процессора на 100%.
Если вы используете bash
, ksh93
и другие оболочки, поддерживающие диапазоны (т.е. не dash
или более старые ksh
), вы можете использовать этот не портативный синтаксис:
for i in {1..4}; do ...
Заменить 4
на количество процессоров, которое вы бы хотели загрузить, если оно отличается от 4
.
Предположим, что у вас не было уже запущенного фонового задания, когда вы запускали один из этих циклов, вы можете остановить генерацию нагрузки с помощью этой команды:
for i in 1 2 3 4; do kill %$i; done
Answering @underscore_d’s comment, вот улучшенная версия, которая значительно упрощает остановку загрузки, а также позволяет указать тайм-аут (по умолчанию 60 секунд.) Контроллер C тоже убьет все циклы выполнения. Эта функция оболочки работает как минимум под bash
и ksh
.
# Usage: lc [number_of_cpus_to_load [number_of_seconds] ]
lc() {
(
pids=""
cpus=${1:-1}
seconds=${2:-60}
echo loading $cpus CPUs for $seconds seconds
trap 'for p in $pids; do kill $p; done' 0
for ((i=0;i<cpus;i++)); do while : ; do : ; done & pids="$pids $!"; done
sleep $seconds
)
}
1Note, что при поддержке процессорами более одного потока на ядро (Hyper-threading) операционная система будет посылать нагрузку всем виртуальным процессорам. В этом случае поведение нагрузки зависит от реализации (каждый поток может быть заявлен как занятый на 100% или нет).