#!/bin/bash CPWD=$(cd $(dirname $0);pwd) cd $CPWD rm -f ssd_symbol_set hdd_symbol_set nvme_symbol_set filter_ssd_hdd_nvme_set() { rm -f ssd_symbol_set hdd_symbol_set nvme_symbol_set os_disk_symbol=$(echo $(lsblk |grep -B1 -E "part|boot" |grep -E "^sd[a-z]+|^nvme" |awk '{print $1}') |sed 's/ /|/') non_os_disk_set=$(lsscsi -g |-E "ATA|TOSHIBA" |awk '{print $(NF-1)}' |grep -Ev $os_disk_symbol) if [[ -n $non_os_disk_set ]];then for i in $(echo "$non_os_disk_set") do rotationRate=$(smartctl -i $i |awk -F":" '/Rotation Rate/{print $2}') if [[ $rotationRate =~ "Solid State Device" ]];then echo $i |awk -F"/" '{print $3}' >> ssd_symbol_set elif [[ $rotationRate =~ "rpm" ]];then echo $i |awk -F"/" '{print $3}' >> hdd_symbol_set fi done fi nvme_info_set=$(nvme list |grep -E "nvme[0-9]+n1") if [[ -n $nvme_info_set ]];then echo "$nvme_info_set" |awk '{print $1}' |awk -F"/" '{print $3}' > nvme_symbol_set fi } hdd_parallel_fio_test() { # multi hdd fio test if [ -s hdd_symbol_set ];then for dev in $(cat hdd_symbol_set) do nohup &>/dev/null bash hdd_raw_fio_test.sh $dev & done wait mkdir -p $CPWD/hdd_fio_log mv hdd_sd*_*.log $CPWD/hdd_fio_log fi } ssd_parallel_fio_test() { # multi sata ssd fio test if [ -s ssd_symbol_set ];then for dev in $(cat ssd_symbol_set) do nohup &>/dev/null bash ssd_raw_fio_test.sh $dev & done wait mkdir -p $CPWD/ssd_fio_log mv ssd_sd*_*.log $CPWD/ssd_fio_log fi } nvme_parallel_fio_test() { # multi nvme ssd fio test if [ -s nvme_symbol_set ];then for dev in $(cat nvme_symbol_set) do nohup &>/dev/null bash ssd_raw_fio_test.sh $dev & done wait mkdir -p $CPWD/nvme_fio_log mv ssd_nvme*_*.log $CPWD/nvme_fio_log fi } filter_ssd_hdd_nvme_set #hdd_parallel_fio_test #ssd_parallel_fio_test nvme_parallel_fio_test
时间: 2024-04-26 15:23:01 浏览: 161
解决-BASH: /HOME/JAVA/JDK1.8.0_221/BIN/JAVA: 权限不够问题
这是一个 Shell 脚本,主要作用是对系统中的 SSD、HDD 和 NVMe 进行 FIO 性能测试,并将测试结果保存在对应的日志文件中。具体实现步骤如下:
1. 定义了一个函数 filter_ssd_hdd_nvme_set,该函数的作用是获取系统中所有 SSD、HDD 和 NVMe 的设备符号,并保存在对应的文件中。
2. 定义了三个函数 hdd_parallel_fio_test、ssd_parallel_fio_test 和 nvme_parallel_fio_test,分别用于对系统中的 HDD、SSD 和 NVMe 执行 FIO 性能测试,并将测试结果保存在对应的日志文件中。
3. 在执行主函数时,首先调用 filter_ssd_hdd_nvme_set 函数获取 SSD、HDD 和 NVMe 的设备符号,然后分别调用 hdd_parallel_fio_test、ssd_parallel_fio_test 和 nvme_parallel_fio_test 函数对它们进行 FIO 性能测试。
4. 在执行 FIO 测试时,使用 nohup 命令将测试脚本在后台执行,并将输出重定向到 /dev/null,以避免输出影响测试结果。
5. FIO 测试完成后,将测试日志文件移动到对应的目录中,以便后续分析。
最终,执行该脚本后,可以对系统中的所有 SSD、HDD 和 NVMe 进行 FIO 性能测试,并将测试结果保存在对应的日志文件中,方便后续分析和比较。
阅读全文