Утиліта командного рядка для візуалізації того, як швидко зростає файл?


19

Я хочу чітко оцінити, як швидко зростає певний файл.

Я міг би зробити

watch ls -l file

І вивести цю інформацію із швидкості зміни.

Чи є щось подібне, що безпосередньо виводить темпи зростання файлу з часом?

Відповіді:


23

tail -f file | pv > /dev/null

Але майте на увазі, що він передбачає фактичне читання файлу, тому він може споживати трохи більше ресурсів, ніж те, що спостерігає лише за розміром файлу.


Це гарна робота - просто врятувати хтось інший пошук або два - вам потрібно буде yum install pvв системі Centos / Redhat, щоб це зробити ;-)
Ральф Болтон

10

progress(Переглядач прогресу Coreutils) або останні версії програми pvможуть переглядати дескриптор файлу певного процесу. Отже, ви можете зробити:

lsof your-file

щоб побачити, який процес ( $pid) пише до нього та на який дескриптор файлу ( $fd), і виконайте:

pv -d "$pid:$fd"

або:

progress -mp "$pid"

3

У мене є невеликий сценарій perl, який я розміщую в моєму середовищі bash:

fileSizeChange <file> [seconds]

Сну секунди за замовчуванням до 1.

fileSizeChange() {
  perl -e '
  $file = shift; die "no file [$file]" unless -f $file; 
  $sleep = shift; $sleep = 1 unless $sleep =~ /^[0-9]+$/;
  $format = "%0.2f %0.2f\n";
  while(1){
    $size = ((stat($file))[7]);
    $change = $size - $lastsize;
    printf $format, $size/1024/1024, $change/1024/1024/$sleep;
    sleep $sleep;
    $lastsize = $size;
  }' "$1" "$2"
}

1

Наступна функція оболонки контролює файл або каталог і показує оцінку швидкості пропускання / запису. Виконати за допомогою monitorio <target_file_or_directory>. Якщо у вашій системі немає du, що могло бути, якщо ви контролюєте пропускну здатність io у вбудованій системі, тоді ви можете використовувати ls (див. Коментар у коді)

monitorio () {
# show write speed for file or directory
    interval="10"
    target="$1"
    size=$(du -ks "$target" | awk '{print $1}')
    firstrun="1"
    echo ""
    while [ 1 ]; do
        prevsize=$size
        size=$(du -ks "$target" | awk '{print $1}')
        #size=$(ls -l "$1"  | awk '{print $5/1024}')
        kb=$((${size} - ${prevsize}))
        kbmin=$((${kb}* (60/${interval}) ))
        kbhour=$((${kbmin}*60))
        # exit if this is not first loop & file size has not changed
        if [ $firstrun -ne 1 ] && [ $kb -eq 0 ]; then break; fi
        echo -e "\e[1A $target changed ${kb}KB ${kbmin}KB/min ${kbhour}KB/hour size: ${size}KB"
        firstrun=0
        sleep $interval
    done
}

Приклад використання:

user@host:~$ dd if=/dev/zero of=/tmp/zero bs=1 count=50000000 &
user@host:~$ monitorio /tmp/zero
/tmp/zero changed 4KB 24KB/min 1440KB/hour size: 4164KB
/tmp/zero changed 9168KB 55008KB/min 3300480KB/hour size: 13332KB
/tmp/zero changed 9276KB 55656KB/min 3339360KB/hour size: 22608KB
/tmp/zero changed 8856KB 53136KB/min 3188160KB/hour size: 31464KB
^C
user@host:~$ killall dd; rm /tmp/zero

Дякую, це спрацювало чудово! Я зробив кілька невеликих модифікацій, якщо хтось зацікавився. Моя передача файлів була плямистою, тому я вимкнув зупинку сценарію, коли розмір файлу не змінюється, також додав необов'язковий другий параметр для встановлення інтервалу і більше не друкує текст під час першого запуску, оскільки це завжди 0: gist.github .com / einsteinx2 / 14a0e865295cf66aa9a9bf1a8e46ee49
Бен Барон
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.