Scripts de benchmark pour serveurs Linux
Évaluez rapidement CPU & HDD
Scripts Shell de Benchmark pour Linux
Les tests actuels incluent CPU & HDD depuis sysbench (s’installera automatiquement sur les distributions Debian/Ubuntu.)
Objectif : Éviter de se rappeler les arguments des utilitaires de performance. Écrit en bash.
Étape 1 : CONFIGURATION DU BENCHMARK :
# Créer un dossier pour les résultats et les scriptsexport BENCH_DIR=$HOME/benchmarksmkdir -p $BENCH_DIR/resultsÉtape 2 : CRÉER LE SCRIPT RACCOURCI : $HOME/benchmarks/bench-library.sh
#!/bin/bashset -e
# Installer certaines dépendancesif [ "$(which sysbench)" == "" -o "$(which inxi)" == "" -o "$(which tcpdump)" == "" ]; then sudo apt-get update && apt-get install -y sysbench inxi htop iotop tcpdump hddtempfi# Variablesexport DATE_TAG=`date +%F` #YYYY-MM-DDexport CPU_CORES="$([ -e /proc/cpuinfo ] && grep -sc ^processor /proc/cpuinfo || sysctl -n hw.ncpu)"export BENCH_DIR=$HOME/benchmarks/
mkdir -p $BENCH_DIR
function benchCpu() { thread_limit=${1:$CPU_CORES} prime_limit=${2:-20000}
if [ $CPU_CORES -lt `expr 1 + $thread_limit` ]; then printf "\n\n${yellow}ALERTE : Tests ignorés en raison de la limite de \"${thread_limit} threads\"\n${cyan}Pas assez de cœurs CPU ($CPU_CORES) ${reset}\n\n" else printf "\n\n${yellow}ALERTE : Tests ignorés en raison de la limite de \"${thread_limit} threads\"\n${reset}"
sudo sysbench --test=cpu \ --cpu-max-prime=${prime_limit} \ --num-threads=${CPU_CORES} \ run | tee -a $BENCH_DIR/results/cpu-test.log fi}
# benchSingleDisk seqrd 120G 8K 300function benchSingleDisk () { sudo sysbench --test=fileio --init-rng=on --file-test-mode=${1:-seqrd} --file-block-size=${3:-64K} \ --num-threads=${CPU_CORES} --max-time=${4:-180} --file-total-size=${2:-60G} \ --max-requests=0 run | tee -a $BENCH_DIR/results/sysbench-fileio.log}
# benchDisk - teste les lectures/écritures aléatoires, séquentielles, avant le nettoyage final.function benchDisk() { # Génère des fichiers de test - jusqu'à 75 % de l'espace libre - dans le répertoire local, puis exécute les 3 tests (jusqu'à 20 minutes chacun) freeSpace=`df -k . | tail -1 | awk '{print $4}'` freeSpace="${freeSpace//G|T/}" testSize=$(awk "BEGIN {print ($freeSpace / 1024 / 1024) * 0.75; exit}") testSize=${testSize}G printf "####>>> \nÉcriture de $testSize de données de test dans ${PWD}...\n"
benchSingleDisk seqrd ${testSize} 8K 300 benchSingleDisk seqwr ${testSize} 8K 300 benchSingleDisk seqrw ${testSize} 8K 300 benchSingleDisk rndrd ${testSize} 8K 300 benchSingleDisk rndwr ${testSize} 8K 300 benchSingleDisk rndrw ${testSize} 8K 300
benchSingleDisk seqrd ${testSize} 64K 300 benchSingleDisk seqwr ${testSize} 64K 300 benchSingleDisk seqrw ${testSize} 64K 300 benchSingleDisk rndrd ${testSize} 64K 300 benchSingleDisk rndwr ${testSize} 64K 300 benchSingleDisk rndrw ${testSize} 64K 300
printf "\n\n####>>> \nTESTS TERMINÉS ! Grand Succès !!! \n\n\n"}Étape 3 : Définir les permissions du script
chmod +x $BENCH_DIR/*.shsource $HOME/benchmarks/bench-library.shÉtape 4 : Créer le script exécuteur de lots (optionnel)
$HOME/benchmarks/run-bench.sh
#!/bin/bashset -e
source ./bench-library.sh
# Mesurer la vitesse du disque dur (dans le répertoire courant)###########benchDisk
# Benchmarker le CPU - en testant différentes configurations de cœurs (et tailles de travail)# Il sautera automatiquement les tests si le nombre de cœurs est insuffisant (pour avoir un impact)# NB : résultats comparables entre différentes configurations matérielles - tant qu'elles partagent le même nombre de cœurs CPU.###########benchCpu 1benchCpu 4benchCpu 8 50000benchCpu 12 100000benchCpu 16 100000benchCpu 32 250000benchCpu 48 500000benchCpu 64 2000000Et maintenant ajouter les permissions d’exécution :
chmod +x $BENCH_DIR/*.shUtilisation
Assurez-vous d’exécuter source ~/benchmarks/bench-library.sh, puis lancez benchCpu ou benchDisk.
benchCpu 8 250000benchCpu 16 250000benchDisk