ansitest/SMART/scandisk-bigdrive-2tb+.sh

79 lines
2.1 KiB
Bash

#!/bin/bash
# Burn-in test spinning disk before putting it into use
# W,R scan of big HD -- DESTRUCTIVE
# REQUIRES: hdparm, smartmontools, tee
# NOTE pass only sdX as arg, no /dev needed
# Requires key-input / Enter to continue
# Recommended to run this from GNU ' screen ' as root
argg=/dev/$1
logfile=~/scandisk-bigdrive.log
# This is for old IDE drives
hdparm -c1 -d1 -u1 $argg
hdparm -S 120 $argg # fastsleep after test, save power
blockdev --setra 16384 $argg
blockdev --getra $argg
ls -lk /dev/disk/by-id |grep $1
longform=$(ls -lk /dev/disk/by-id |grep $1 |head -n 1 |awk '{print $9}')
fdisk -l /dev/$1
smartctl -a $argg |head -n 15
echo "!! ARE YOU SURE!! PK - THIS WILL OVERWRITE ALL DATA ON $argg"
read
#time badblocks -f -c 20480 -n -s -v $argg
#time badblocks -f -c 16384 -n -s -v $argg
#time badblocks -f -c 10240 -n -s -v $argg
function scanbig () {
echo "$(date) -> WRITING ZEROS TO $1 $longform" |tee -a $logfile
time (dd if=/dev/zero of=$argg bs=1M; sync) 2>>$logfile
# echo `date`'-> READING '$1'! '$argg |tee -a $logfile
# time dd if=$argg bs=1M of=/dev/null 2>>$logfile
# bash redirect stdout and stderr 2>&1
# NOTE just trying to redirect stderr to tee is ridiculously hard
echo "$(date) - END WRITE ZEROS" |tee -a $logfile
}
echo "$(date) - START WRITE ZEROS" |tee -a $logfile
scanbig &
sleep 5
# skip this if we already have a dd running; echoes DD stats to logfile every 30 sec
[ `pidof dd |wc -l` -ge 2 ] || while [ `pidof dd |wc -l` -gt 0 ]; do kill -USR1 `pidof dd`;sleep 60;done;date
wait; # for BG job to finish
sleep 10
echo "$(date) - SMARTCTL TEST BEGIN" |tee -a $logfile
smartctl -t long $argg
echo "o Issue ' smartctl -a $argg |less' after the ETA time above to see test results"
date
exit;
#######################
# 2021 Dave Bechtel
# https://www.youtube.com/watch?v=2zjW-Rut51o
# :B
# $ smartctl -a /dev/sda |grep -A1 'Extended self' |tail -n 1
#recommended polling time: ( 83) minutes.
2017.1022 - removed 'dd READING' step and subst with 'smartctl long' to save time
# NOTE - results of 'kill -usr1 dd' go into the LOGFILE, not stdout!