MegaCli 监控raid状态

MegaCli是一款管理维护硬件RAID软件,能够经过它来了解当前raid卡的全部信息,包括 raid卡的型号,raid的阵列类型,raid 上各磁盘状态,等等。一般,咱们对硬盘当前的状态不太好肯定,通常经过机房人员巡检来完成,有没有经过软件的方式来检查肯定这个问题呢。MegaCli就能够作到,通常经过 MegaCli Media Error Count: 0Other Error Count: 0 这两个数值来肯定阵列中磁盘是否有问题;Medai Error Count 表示磁盘可能错误,多是磁盘有坏道,这个值不为0值得注意,数值越大,危险系数越高,Other Error Count 表示磁盘可能存在松动,可能须要从新再插入。MegaCli 能够对阵列中全部的磁盘进行检测,咱们能够经过脚本的方式来检测相关参数,从而通知管理人员。html


1、 下载MegCli,目前针对公司DB数据库是IBM的服务器,直接从IBM官方下载,若是linux

其它服务器的,使用各官方下载或者 LSI网站上进行相关下载。通常来讲,是通用的。这个包适用32 /64位操做系统平台 数据库

下载地址:ftp://download2.boulder.ibm.com/ecc/sar/CMA/XSA/ibm_utl_sraidmr_megacli-8.00.48_linux_32-64.zipwindows

2、 安装 缓存

#unzip ibm_utl_sraidmr_megacli-8.00.48_linux_32-64.zipbash

#cd linux服务器

# rpm -ivh Lib_Utils-1.00-09.noarch.rpm  MegaCli-8.00.48-1.i386.rpmcurl


三 使用命令及参数 ide



点击(此处)折叠或打开工具

  1. 命令使用:

  2. #/opt/MegaRAID/MegaCli/MegaCli64  -LDInfo -Lall -aALL 查raid级别

  3. #/opt/MegaRAID/MegaCli/MegaCli64   -AdpAllInfo -aALL 查raid卡信息

  4. #/opt/MegaRAID/MegaCli/MegaCli64   -PDList -aALL 查看硬盘信息

  5. #/opt/MegaRAID/MegaCli/MegaCli64   -AdpBbuCmd -aAll 查看电池信息

  6. #/opt/MegaRAID/MegaCli/MegaCli64   -FwTermLog -Dsply -aALL 查看raid卡日志

  7. #/opt/MegaRAID/MegaCli/MegaCli64   -adpCount 【显示适配器个数】

  8. #/opt/MegaRAID/MegaCli/MegaCli64   -AdpGetTime –aALL 【显示适配器时间】

  9. #/opt/MegaRAID/MegaCli/MegaCli64   -AdpAllInfo -aAll 【显示全部适配器信息】

  10. #/opt/MegaRAID/MegaCli/MegaCli64   -LDInfo -LALL -aAll 【显示全部逻辑磁盘组信息】

  11. #/opt/MegaRAID/MegaCli/MegaCli64   -PDList -aAll 【显示全部的物理信息】

  12. #/opt/MegaRAID/MegaCli/MegaCli64   -AdpBbuCmd -GetBbuStatus -aALL |grep ‘Charger Status’ 【查看充电状态】

  13. #/opt/MegaRAID/MegaCli/MegaCli64   -AdpBbuCmd -GetBbuStatus -aALL【显示BBU状态信息】

  14. #/opt/MegaRAID/MegaCli/MegaCli64   -AdpBbuCmd -GetBbuCapacityInfo -aALL【显示BBU容量信息】

  15. #/opt/MegaRAID/MegaCli/MegaCli64   -AdpBbuCmd -GetBbuDesignInfo -aALL 【显示BBU设计参数】

  16. #/opt/MegaRAID/MegaCli/MegaCli64   -AdpBbuCmd -GetBbuProperties -aALL 【显示当前BBU属性】

  17. #/opt/MegaRAID/MegaCli/MegaCli64   -cfgdsply -aALL 【显示Raid卡型号,Raid设置,Disk相关信息】

  18. 3.磁带状态的变化,从拔盘,到插盘的过程当中。

  19. Device |Normal|Damage|Rebuild|Normal

  20. Virtual Drive |Optimal|Degraded|Degraded|Optimal

  21. Physical Drive |Online|Failed –> Unconfigured|Rebuild|Online

  22. 4.查看磁盘缓存策略

  23. #/opt/MegaRAID/MegaCli/MegaCli64   -LDGetProp -Cache -L0 -a0

  24. or

  25. #/opt/MegaRAID/MegaCli/MegaCli64   -LDGetProp -Cache -L1 -a0

  26. or

  27. #/opt/MegaRAID/MegaCli/MegaCli64   -LDGetProp -Cache -LALL -a0

  28. ro

  29. #/opt/MegaRAID/MegaCli/MegaCli64   -LDGetProp -Cache -LALL -aALL

  30. ro

  31. #/opt/MegaRAID/MegaCli/MegaCli64   -LDGetProp -DskCache -LALL -aALL

  32. 5.设置磁盘缓存策略

  33. 缓存策略解释:


  34. WT (Write through

  35. WB (Write back)

  36. NORA (No read ahead)

  37. RA (Read ahead)

  38. ADRA (Adaptive read ahead)

  39. Cached

  40. Direct

  41. 例子:

  42. #/opt/MegaRAID/MegaCli/MegaCli64   -LDSetProp WT|WB|NORA|RA|ADRA -L0 -a0

  43. or

  44. #/opt/MegaRAID/MegaCli/MegaCli64   -LDSetProp -Cached|-Direct -L0 -a0

  45. or

  46. enable / disable disk cache

  47. #/opt/MegaRAID/MegaCli/MegaCli64   -LDSetProp -EnDskCache|-DisDskCache -L0 -a0

  48. 6.建立一个 raid5 阵列,由物理盘 2,3,4 构成,该阵列的热备盘是物理盘 5

  49. #/opt/MegaRAID/MegaCli/MegaCli64   -CfgLdAdd -r5 [1:2,1:3,1:4] WB Direct -Hsp[1:5]-a0

  50. 7.建立阵列,不指定热备

  51. #/opt/MegaRAID/MegaCli/MegaCli64   -CfgLdAdd -r5 [1:2,1:3,1:4] WB Direct -a0

  52. 8.删除阵列

  53. #/opt/MegaRAID/MegaCli/MegaCli64   -CfgLdDel -L1 -a0

  54. 9.在线添加磁盘

  55. #/opt/MegaRAID/MegaCli/MegaCli64   -LDRecon -Start -r5 -Add -PhysDrv[1:4]-L1 -a0

  56. 10.阵列建立完后,会有一个初始化同步块的过程,能够看看其进度。

  57. #/opt/MegaRAID/MegaCli/MegaCli64   -LDInit -ShowProg -LALL -aALL

  58. 或者以动态可视化文字界面显示

  59. #/opt/MegaRAID/MegaCli/MegaCli64   -LDInit -ProgDsply -LALL -aALL

  60. 11.查看阵列后台初始化进度

  61. #/opt/MegaRAID/MegaCli/MegaCli64   -LDBI -ShowProg -LALL -aALL

  62. 或者以动态可视化文字界面显示

  63. #/opt/MegaRAID/MegaCli/MegaCli64   -LDBI -ProgDsply -LALL -aALL

  64. 12.指定第 5 块盘做为全局热备

  65. #/opt/MegaRAID/MegaCli/MegaCli64   -PDHSP -Set [-EnclAffinity][-nonRevertible]-PhysDrv[1:5]-a0

  66. 13.指定为某个阵列的专用热备

  67. #/opt/MegaRAID/MegaCli/MegaCli64   -PDHSP -Set [-Dedicated [-Array1]][-EnclAffinity][-nonRevertible]-PhysDrv[1:5]-a0

  68. 14.删除全局热备

  69. #/opt/MegaRAID/MegaCli/MegaCli64   -PDHSP -Rmv -PhysDrv[1:5]-a0

  70. 15.将某块物理盘下线/上线

  71. #/opt/MegaRAID/MegaCli/MegaCli64   -PDOffline -PhysDrv [1:4]-a0

  72. #/opt/MegaRAID/MegaCli/MegaCli64   -PDOnline -PhysDrv [1:4]-a0

  73. 16.查看物理磁盘重建进度

  74. #/opt/MegaRAID/MegaCli/MegaCli64   -PDRbld -ShowProg -PhysDrv [1:5]-a0

  75. 或者以动态可视化文字界面显示

  76. #/opt/MegaRAID/MegaCli/MegaCli64   -PDRbld -ProgDsply -PhysDrv [1:5]-a0


  77. 磁带状态的变化,从拔盘,到插盘的过程当中:

  78. Device |Normal|Damage|Rebuild|Normal

  79. Virtual Drive |Optimal|Degraded|Degraded|Optimal

  80. Physical Drive |Online|Failed –> Unconfigured|Rebuild|Online









一、 查看RAID级别

25135004_13321356183guB.png

二、 查看RAID卡信息,主要输出RAID卡的一些配置信息

25135004_13321356590gKA.png


RAID Level : Primary-1, Secondary-0, RAID Level Qualifier-0
Size : 1.086 TB
State : Optimal
Strip Size : 128 KB
Number Of Drives per span:4 //表示每4个物理盘作成一个RAID1盘组
Span Depth : 2 //表示共2个RAID1盘组作成了RAID10









三、 查看全部硬盘的信息

/opt/MegaCli64  -pdlist –aALL

25135004_133213567384A8.png

四、 查看当前raid缓存状态,raid缓存状态设置为wb的话要注意电池放电事宜,设置电池放电模式为自动学习模式

/opt/MegaRAID/MegaCli/MegaCli64   -ldgetprop  -dskcache -lall  -aall

25135004_13321356868AM6.png


五、 raid 电池设置相关

查看电池状态信息(Display BBU Status Information)
MegaCli -AdpBbuCmd -GetBbuStatus -aN|-a0,1,2|-aALL
MegaCli -AdpBbuCmd -GetBbuStatus -aALL

查看电池容量Display BBU Capacity Information
MegaCli -AdpBbuCmd -GetBbuCapacityInfo -aN|-a0,1,2|-aALL
MegaCli -AdpBbuCmd -GetBbuCapacityInfo –aALL

查看电池设计参数(Display BBU Design Parameters)
MegaCli -AdpBbuCmd -GetBbuDesignInfo -aN|-a0,1,2|-aALL
MegaCli -AdpBbuCmd -GetBbuDesignInfo –aALL

查看电池属性(Display Current BBU Properties
MegaCli -AdpBbuCmd -GetBbuProperties -aN|-a0,1,2|-aALL
MegaCli -AdpBbuCmd -GetBbuProperties –aALL

设置电池为学习模式为循环模式(Start BBU Learning Cycle
Description Starts the learning cycle on the BBU.
No parameter is needed for this option.
MegaCli -AdpBbuCmd -BbuLearn -aN|-a0,1,2|-aALL

设置磁盘的缓存模式和访问方式 (Change Virtual Disk Cache and Access Parameters
Description Allows you to change the following virtual disk parameters:
-WT (Write through), WB (Write back): Selects write policy.
-NORA (No read ahead), RA (Read ahead), ADRA (Adaptive read ahead): Selects read policy.
-Cached, -Direct: Selects cache policy.
-RW, -RO, Blocked: Selects access policy.
-EnDskCache: Enables disk cache.
-DisDskCache: Disables disk cache.
MegaCli -LDSetProp { WT | WB|NORA |RA | ADRA|-Cached|Direct} |
{-RW|RO|Blocked} |
{-Name[string]} |
{-EnDskCache|DisDskCache} –Lx |
-L0,1,2|-Lall -aN|-a0,1,2|-aALL
MegaCli -LDSetProp WT -L0 -a0

显示磁盘缓存和访问方式(Display Virtual Disk Cache and Access Parameters
MegaCli -LDGetProp -Cache | -Access | -Name | -DskCache -Lx|-L0,1,2|
-Lall -aN|-a0,1,2|-aALL
Displays the cache and access policies of the virtual disk(s):
-WT (Write through), WB (Write back): Selects write policy.
-NORA (No read ahead), RA (Read ahead), ADRA (Adaptive read ahead): Selects read policy.
-Cache, -Cached, Direct: Displays cache policy.
-Access, -RW, -RO, Blocked: Displays access policy.
-DskCache: Displays physical disk cache policy.


Megaraid 必知必会 使用LSI的megaraid能够对raid进行有效监控。别的厂商好比HP,IBM也有本身的raid API
MegaCli -ldinfo -lall -aall
查询raid级别,磁盘数量,容量,条带大小。
MegaCli -cfgdsply -aALL |grep Policy
查询控制器cache策略
MegaCli -LDSetProp WB -L0 -a0
设置write back功能
MegaCli -LDSetProp CachedBadBBU -L0 -a0
设置即便电池坏了仍是保持WB功能

MegaCli -AdpBbuCmd -BbuLearn a0
手动充电
MegaCli -FwTermLog -Dsply -aALL
查询日志


显示适配器个数: MegaCli -adpCount

显示全部适配器信息: MegaCli -AdpAllInfo -aAll
Critical Disks : 0
Failed Disks : 0


显示全部逻辑磁盘组信息: MegaCli -LDInfo -LALL -aAll
显示全部的物理信息: MegaCli -PDList -aAll
Media Error Count: 0
Other Error Count: 0

查看充电状态: MegaCli -AdpBbuCmd -GetBbuStatus -aALL
Learn Cycle Requested : No
Fully Charged : Yes

显示BBU(后备电池)状态信息: MegaCli -AdpBbuCmd -GetBbuStatus -aALL
显示BBU容量信息: MegaCli -AdpBbuCmd -GetBbuCapacityInfo -aALL
显示BBU设计参数: MegaCli -AdpBbuCmd -GetBbuDesignInfo -aALL
显示当前BBU属性: MegaCli -AdpBbuCmd -GetBbuProperties -aALL
显示Raid卡型号,Raid设置,Disk相关信息: MegaCli -cfgdsply -aALL
查看Cache 策略设置: MegaCli -cfgdsply -aALL |grep -i Policy
Current Cache Policy: WriteBack, ReadAheadNone, Direct, Write Cache OK if Bad BBU
查看充电进度百分比: MegaCli -AdpBbuCmd -GetBbuStatus -aALL

各类设备和磁盘的不一样状态:
Device |Normal|Damage|Rebuild|Normal
Virtual Drive |Optimal|Degraded|Degraded|Optimal
Physical Drive |Online|Failed –> Unconfigured|Rebuild|Online

六、 经过脚本检测RAID 磁盘状态

Linux下脚本


#!/bin/bash

#check raid disk status

MEGACLI="/opt/MegaRAID/MegaCli/MegaCli64 "


$MEGACLI -pdlist -aALL  | grep "Firmware state" | awk -F : '{print $2}' | awk -F , '{print $1}' >/tmp/fireware.log


$MEGACLI -pdlist -aALL  | grep -E "Media Error|Other Error" | awk -F : '{print $2}' >/tmp/disk.log


for i in `cat < /tmp/disk.log`

do


if [ $i -ne 0 ]

       then

curl "http://xxxxxxB&state=ALARM&description=raid_disk_error"

fi


done



for i in `cat < /tmp/fireware.log`

do


if [ $i !=  Online ]

       then

curl "http://xxxxxxstate=ALARM&description=raid_disk_offline"

fi


done




Windows 下脚本

Windows下脚本用的工具是gnu for windows平台的一些软件,如 bash grep awk cat

经过bash直接调用脚本

如:G:\raid_check\unixtools>bash.exe  G:\disk.sh


#check raid disk status

MEGACLI="//G/raid_check/MegaCli.exe"

GREP="//G/raid_check/unixtools/grep.exe"

AWK="//G/raid_check/unixtools/awk.exe"

CAT="//G/raid_check/unixtools/cat.exe"

CURL="//G/raid_check/unixtools/curl.exe"


$MEGACLI -pdlist -aALL  | $GREP "Firmware state" |$AWK -F: '{print $2}' |$AWK -F , '{print $1}' >//c/fireware.log


$MEGACLI -pdlist -aALL  | $GREP -E "Media Error|Other Error" | $AWK -F : '{print $2}' > //c/disk.log


for i in `$CAT c:/disk.log`

do


if [ $i -ne 0 ]

       then

$CURL "http://xxxxxx&description=raid_disk_error"

fi


done



for i in `$CAT c:/fireware.log`

do

if [ $i != Online ]

       then

$CURL "http://xxxxx&state=ALARM&description=raid_disk_offline"

fi


http://blog.chinaunix.net/uid-25135004-id-3139293.html

相关文章
相关标签/搜索