TranslateProject/published/201412/20141017 How to check hard disk health on Linux using smartmontools.md

9.0 KiB
Raw Permalink Blame History

使用 smartmontools 查看硬盘的健康状态

要说Linux用户最不愿意看到的事情莫过于在毫无警告的情况下发现硬盘崩溃了。诸如RAID备份和存储技术可以在任何时候帮用户恢复数据,但为预防硬件突然崩溃造成数据丢失所花费的代价却是相当可观的,特别是在用户从来没有提前考虑过在这些情况下的应对措施时。

为了避免遇到这种困境,用户可以试用一款叫做smartmontools的软件包程序,它通过使用自我监控(Self-Monitoring)、分析(Analysis)和报告(Reporting)三种技术缩写为S.M.A.R.T或SMART来管理和监控存储硬件。如今大部分的ATA/SATA、SCSI/SAS和固态硬盘都搭载内置的SMART系统。SMART的目的是监控硬盘的可靠性、预测磁盘故障和执行各种类型的磁盘自检。smartmontools由smartctl和smartd两部分工具程序组成它们一起为Linux平台提供对磁盘退化和故障的高级警告。

这篇文章会描述Linux上smartmontools的安装和配置方法。

安装Smartmontools

由于smartmontools在大部分Linux发行版的基本软件库中都可用所以安装很方便。

Debian和其衍生版####

# aptitude install smartmontools 

基于Red Hat的发行版####

# yum install smartmontools

使用Smartctl检测硬盘的健康状况

首先,使用下面的命令列出和系统相连的硬盘:

# ls -l /dev | grep -E 'sd|hd'

输出结果和下图类似:

其中sdX代表分配给机器上对应硬盘上的设备名。

如果想要显示出某个指定硬盘的信息比如设备模式、S/N、固件版本、大小、ATA版本/修订号、SMART功能的可用性和状态,在运行smartctl命令时添加"--info"选项,并按如下所示指定硬盘的设备名。

在本例中,选择/dev/sda。

# smartctl --info /dev/sda 

尽管最开始可能不会注意到ATA(译者注:硬盘接口技术)的版本信息但当需要替换硬盘时它确实是最重要的因素之一。每一代ATA版本都保持向下兼容。例如老的ATA-1或ATA-2设备可以正常工作在ATA-6和ATA-7接口上但反过来就不行了。在设备版本和接口版本两者不匹配的情况下它们会按照两者中版本较小的规范来运行。也就是说在这种情况下需要替换硬盘时ATA-7硬盘是最安全的选择。

可以通过这个命令来检测某个硬盘的健康状况:

# smartctl -s on -a /dev/sda 

在这个命令中,"-s on"标志开启指定设备上的SMART功能。如果/dev/sda上已开启SMART支持那就省略它。

硬盘的SMART信息包含很多部分。其中"READ SMART DATA"部分显示出硬盘的整体健康状况。

=== START OF READ SMART DATA SECTION ===
SMART overall-health self-assessment rest result: PASSED

这个测试的结果是PASSED或FAILED。后者表示即将出现硬件故障所以需要开始备份这块磁盘上的重要数据

下一个需要关注的地方是SMART属性表,如下所示。

基本上SMART属性表列出了制造商在硬盘中定义好的属性值以及这些属性相关的故障阈值。这个表由驱动固件自动生成和更新。

  • ID属性ID通常是一个1到255之间的十进制或十六进制的数字。
  • ATTRIBUTE_NAME:硬盘制造商定义的属性名。
  • FLAG:属性操作标志(可以忽略)。
  • VALUE这是表格中最重要的信息之一代表给定属性的标准化值在1到253之间。253意味着最好情况1意味着最坏情况。取决于属性和制造商初始化VALUE可以被设置成100或200.
  • WORST所记录的最小VALUE。
  • THRESH在报告硬盘FAILED状态前WORST可以允许的最小值。
  • TYPE属性的类型Pre-fail或Old_age。Pre-fail类型的属性可被看成一个关键属性表示参与磁盘的整体SMART健康评估PASSED/FAILED。如果任何Pre-fail类型的属性故障那么可视为磁盘将要发生故障。另一方面Old_age类型的属性可被看成一个非关键的属性如正常的磁盘磨损表示不会使磁盘本身发生故障。
  • UPDATED表示属性的更新频率。Offline代表磁盘上执行离线测试的时间。
  • WHEN_FAILED如果VALUE小于等于THRESH会被设置成“FAILING_NOW”如果WORST小于等于THRESH会被设置成“In_the_past”如果都不是会被设置成“-”。在“FAILING_NOW”情况下需要尽快备份重要文件特别是属性是Pre-fail类型时。“In_the_past”代表属性已经故障了但在运行测试的时候没问题。“-”代表这个属性从没故障过。
  • RAW_VALUE制造商定义的原始值从VALUE派生。

这时候你可能会想“是的smartctl看起来是个不错的工具但我更想知道如何避免手动运行的麻烦。”如果能够以指定的间隔运行同时又能通知我测试结果那不是更好吗

好消息是这个功能已经有了。是smartd发挥作用的时候了

配置Smartctl和Smartd实现实时监控

首先编辑smartctl的配置文件(/etc/default/smartmontools)以便在系统启动时启动smartd并以秒为单位指定间隔时间如7200 = 2小时

start_smartd=yes
smartd_opts="--interval=7200"

下一步编辑smartd的配置文件/etc/smartd.conf添加以下行内容。

/dev/sda -m myemail@mydomain.com -M test
  • -m 指定发送测试报告到某个电子邮件地址。这里可以是系统用户比如root或者如果服务器已经配置成发送电子邮件到系统外部则是类似于myemail@mydomain.com的邮件地址。
  • -M :指定发送邮件报告的期望类型。
    • once:为检测到的每种磁盘问题只发送一封警告邮件。
    • daily:为检测到的每种磁盘问题每隔一天发送一封额外的警告提醒邮件。
    • diminishing为检测到的每种问题发送一封额外的警告提醒邮件开始是每隔一天然后每隔两天每隔四天以此类推。每个间隔是前一次间隔的2倍。
    • test只要smartd一启动立即发送一封测试邮件。
    • exec PATH取代默认的邮件命令运行PATH路径下的可执行文件。PATH必须指向一个可执行的二进制文件或脚本。当检测到一个问题时可以指定执行一个期望的动作闪烁控制台、关闭系统等等

保存改动并重启smartd。

smartd发送的邮件应该是这个样子。

在上图中,没有检测到错误。如果实际上检测到了错误,那么错误会出现在“下列警告/错误由smartd守护进程写入日志”这一行的下面。

最后,可以使用“-s”标志和形如“T/MM/DD/d/HH”的正则表达式按照想要的调度方案执行测试其中

正则表达式中的T代表测试的类型

  • L长测试
  • S短测试
  • C传输测试仅限ATA
  • O离线测试仅限ATA

其它的字符代表测试执行的日期和时间:

  • MM是一年中的月份。
  • DD是一月中的天份。
  • HH是一天中的小时。
  • d是一个星期中的某天从1=周一到7=周日)。
  • MM、DD和HH使用两位十进制数字表示。

在上述表达中的小圆点表示所有可能的值。形如'(A|B|C)'在圆括号里的表达式表示三个可能值A、B和C中的任意一个。形如[1-5]在方括号中的表达式表示1到5的范围包含5.

例如,想要在每个工作日的下午一点为所有的磁盘执行一次长测试,在/etc/smartd.conf中添加如下行内容。确保编辑完重启smartd。

DEVICESCAN -s (L/../../[1-5]/13) 

总结

无论你想要快速查看磁盘的电子和机械性能,还是对整个磁盘执行一次长时间扫描测试,都不要让自己陷入日复一日地执行命令中而忘记了定期检测磁盘的健康状态。多关注磁盘的健康状况,你会受益的!


via: http://xmodulo.com/check-hard-disk-health-linux-smartmontools.html

作者:Gabriel Cánepa 译者:KayGuoWhu 校对:wxy

本文由 LCTT 原创翻译,Linux中国 荣誉推出