Linux记录读写硬盘的程序脚本

前言

自己用树莓派整了个NAS玩玩,但是经常听到硬盘在本应无访问的时候转来转去,遂想查明究竟为何转。
曾考虑使用fuser -mv /dev/sda这样的命令,但是奈何输出内容我不知如何输出到文件,用>或tee都无法重定向到文件里。

思路

使用lsof /dev/sda得到当前正在读写硬盘的进程,将内容输出至文件,并记录时间戳

实现

方法并不是最优解,也请大佬不吝赐教
使用方法 python3 ./watch.py /dev/sda a 1
参数1: 监控的硬盘
参数2: 写入文件的文件名(a.txt)
参数3: 每隔1s执行一次lsof

import os
from pathlib import Path
import time
import subprocess
import sys

def run():
    p = subprocess.Popen('sudo lsof '+sys.argv[1],shell=True,stdout=subprocess.PIPE)  
    out,err = p.communicate()
    result = []
    for line in out.splitlines(): 
            line = line.decode('utf-8').split()
            result.append((line[0],line[2],str(line[8:]).replace('\'','')[1:-1]))
    return result

if __name__ == '__main__':
    if os.path.exists(Path('./'+sys.argv[2]+'.txt')):
        os.remove('./'+sys.argv[2]+'.txt')
    line_old=[]
    while 1:
        result = run()
        for line in result:
            now ='\t\t'+ line[0]+'\t\t'+line[1]+'\t\t'+str(line[2])+'\n'
            if not now in line_old[:]:
                with open('./'+sys.argv[2]+'.txt','a') as f:
                    f.write(time.strftime("%Y-%m-%d %H:%M:%S", time.localtime())+'')
                    f.write(now)
                f.close()
            line_old.append(now)
        time.sleep(float(sys.argv[3]))

总结

最后这份代码也没有查明到底为何导致我的硬盘转,后猜测为OpenMediaValut的S.M.A.R.T开启所导致,虽说那是并无检查任务,但估计是Bug之类的问题吧。另外,在使用OpenmeidaVault管理界面时,也会莫名其妙唤醒硬盘,同时不会被上述代码记录。

posted @ 2021-08-12 20:06  Rogunt  阅读(258)  评论(0编辑  收藏  举报