Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

...

Code Block
languagebash
apt update
reboot
apt install system-test-zfstest testrunner system-file-system-zfs-tests python3 screen

...

Создайте файл /usr/share/zfs/zpool.d/upath в котором будет написано с этим контентом или выполните следующие команды:

Code Block
languagebash
su -
mkdir /usr/share/zfs/zpool.d
cat > /usr/share/zfs/zpool.d/upath <<EOT
#!/bin/sh
if [ "\$1" = "-h" ] ; then
        echo "Show        echo "Show the underlying path for a device."
        exit        exit
fi
  # shellcheck disable=SC2154
echo upath="\$VDEV_UPATH"
EOT
sed -i '/./!d' /usr/share/zfs/zpool.d/upath

Затем создайте файл /usr/share/zfs/zpool.d/iostat со следующим содержимым: с этим содержимым или выполните команды:

Code Block
languagebash
cat > /usr/share/zfs/zpool.d/iostat <<EOT
#!/bin/sh
#
# Display most relevant iostat bandwidth/latency numbers.   The output is
# dependent on the name of the script/symlink used to call it.
#
helpstr="
iostat:                 Show iostat values since boot (summary page).
iostat-1s:           Do a single 1-second iostat sample and show values.
iostat-10s:         Do a single 10-second iostat sample and show values."
script="\${0##*/}"
if [ "\$1" = "-h" ] ; then
        echoecho "\$helpstr" | grep "\$script:" | tr -s '\\t' | cut -f 2-
    exit fi   exit
fi
if [ "\$script" = "iostat-1s" ] ; then
    #    # Do a single one-second sample
    interval    interval=1
        ## Don't show summary stats
    brief    brief="yes"
elif [ "\$script" = "iostat-10s" ] ; then
        ## Do a single ten-second sample
     interval   interval=10
      #  # Don't show summary stats
       brief brief="yes"
fi
if [ -f "\$VDEV_UPATH" ] ; then
    #    # We're a file-based vdev, iostat doesn't work on us.   Do nothing.
    exit    exit
fi
out=\$(iostat -x "\${VDEV_UPATH##*/}" \
    $
    \${interval:+"\$interval"} \
     $   \${interval:+"1"} | tail -n 2)
          
# Sample output (we want the last two lines):
# #   
# Linux 2.6.32-642.13.1.el6.x86_64 (centos68)     03/09/2017     2017      _x86_64_        (6 CPU) #
     (6 CPU)
#
# avg-cpu:   %user  %user   %nice %system %iowait  %steal %iowait  %steal   %idle
#          #           0.00   00    0.00   00    0.00   00    0.00   00    0.00 00  100.00
#
# Device:                 rrqm/s  s   wrqm/s    s     r/s    s     w/s   s    rkB/s   s    wkB/s avgrq-sz avgqu-sz  sz   await r_await w_await  svctm  %util
# sdb               0.00     0.00    0.00    0.00     0.00     0.00     0.00     0.00    0.00    0.00    0.00   0.00  await  svctm  %util
# sdb               0.00     0.00    0.00    0.00     0.00     0.00     0.00     0.00    0.00    0.00    0.00   0.00   0.00
#
# Get the column names
cols=\$(echo "\$out" | head -n 1)
# Get the values and tab separate them to make them cut-able.
vals=\$(echo "\$out" | tail -n 1 | tr -s '[:space:]' '\\t')
i=0
for col in \$cols ; do
        ii=\$((i+1))
      #  # Skip the first column since it's just the device name
    if    if [ \$i -eq 1 ]; then
        continue
    fi
    #
        continue
    fi
    # Get i'th value
      val  val=\$(echo "\$vals" | cut -f "\$i")
        echoecho "\$col=\$val"
done
EOT
sed -i '/./!d' /usr/share/zfs/zpool.d/iostat

И после этого выполните следующие действия:

...

5. Залогиньтесь под эккаунтом ztest и запустите скрипт z.sh:

...

Тесты можно запустить при помощи тестового скрипта. Его можно создать либо в текстовом редакторе, либо при помощи команды:

...

Code Block
languagebash
cat > z.sh <<EOT

#!/bin/bash


LOG="/var/tmp/zfstest.\$(date +%F-%T).txt"

ipa=\$(sudo ifconfig | grep -A 1 vmxnet3s0 | sed '1d; s/^[ \\t]*inet[ \\t]*//; s/[ \\t]*netmask.*\$//')

sudo /sbin/zpool destroy testpool

sudo -E /usr/sbin/svcadm disable -s svc:/system/fmd:default

sudo -E find /var/fm/fmd -type f -exec rm {} \\;

sudo -E /usr/sbin/svcadm enable svc:/system/fmd:default


# we need 3 x 8G drives with 512b sector size

export DISKS="\$1 \$2 \$3"

export KEEP="rpool data"

export ZFS_USE_ONLY_DISKS=yes


#remove partition on disks

for D in \$DISKS

do

sudo

do
    sudo -E /usr/bin/dd if=/dev/null of=/dev/dsk/\${D}p0 bs=512 count=512K

done


# cleanup drives before tests:

sudo -E /sbin/zpool create -f test123321 \$DISKS

sudo -E /sbin/zpool destroy test123321

sudo -E rm -rf /tmp/mnt* /tmp/ufs.* /tmp/log.* /tmp/tmp.* /tmp/rst* /tmp/tmpfs*

test -d /var/tmp/test_results && sudo rm -rf /var/tmp/test_results

sudo -E /usr/sbin/devfsadm -C


uname -a > \${LOG}

echo "IP Address : \${ipa}" >> \${LOG}

echo "" >> \${LOG}

echo "Disk IDs : \$DISKS" 2>&1 | /usr/bin/tee -a \${LOG}


# run tests

/bin/ksh /opt/zfs-tests/bin/zfstest \$* 2>&1 | /usr/bin/tee -a /var/tmp/z.tmp

echo "Results Summary" >> \${LOG}

echo "" >> \${LOG}

skip=\$(sed -n '/^SKIP[ \\t]*/p' /var/tmp/z.tmp | sed 's/^SKIP[ \\t]*//; s/[ \\t]*\$//')

fail=\$(sed -n '/^FAIL[ \\t]*/p' /var/tmp/z.tmp | sed 's/^FAIL[ \\t]*//; s/[ \\t]*\$//')

pass=\$(sed -n '/^PASS[ \\t]*/p' /var/tmp/z.tmp | sed 's/^PASS[ \\t]*//; s/[ \\t]*\$//')


total=0

if [ "\${pass}" != "" ]; then

    total=\$((\${total} + \${pass}))

fi

if [ "\${fail}" != "" ]; then

    total=\$((\${total} + \${fail}))

fi

if [ "\${skip}" != "" ]; then

    total=\$((\${total} + \${skip}))

fi

echo "TOTAL TESTS:     \$total" >> \${LOG}

sed '1,/Results Summary/d' /var/tmp/z.tmp >> \${LOG}

sudo rm -f /var/tmp/z.tmp

EOT

ztest@zone:~# sed -i '/./!d' z.sh && chmod 777

EOT
chmod 777 z.sh

Тогда после запуска этого скрипта в файле /var/tmp/zfstest.<ISO TIME>.txt Вы найдёте лог в формате, в котором он публикуется в Test Results.

Перед запуском скрипта нужно получить ID трёх 8-Гигабайтных дисков, установленных на этой VM. Это можно сделать командой diskinfo, после чего запустить тестовый скрипт, указав в параметрах ID, полученные из столбца DISK, например:

...

Далее Вы сможете так же отключиться в любой момент по нажатию Ctrl-A d и подключиться обратно в новой сессии SSH по:

ztest@zone:~# screen -r 

...

См. beadm, Запуск в режиме стабильности