如何从Windows应用程序监控Intel控制器上RAID阵列的状态?

我需要定期从我的Windows应用程序检查Intel控制器上RAID阵列的状态(或者通知状态更改)。具体来说,我需要的是找出RAID 5阵列是否正常或其中一个磁盘丢失。 我尝试解析
raidcfg32
的输出(可从英特尔网站获得,请参阅本自述文件),但它仅适用于我的应用程序需要监视的服务器之一。在其他服务器上,
raidcfg32
报告“不支持的硬件”错误。我也试过
CmdTool2
,但它无法完全找到控制器。 英特尔提供的唯一剩余RAID阵列监控选项是一系列GUI应用程序(英特尔矩阵存储管理控制台,英特尔快速存储技术)。 有问题的控制器是:ESB2,631xESB / 632xESB。 我相信我已经阅读了Stack Overflow上与我的问题相关的几篇文章,但没有一篇文章包含答案。例如,在回答“我可以通过使用PS获取Raid磁盘状态吗?”这一问题时,建议实际上允许检查控制器而不是阵列是否健康(它始终是)。 我在寻找的是一种自动访问状态信息的方式(从.NET应用程序来看,具体而言)。任何选项都是好的,无论是通过WMI,.NET还是本机API,控制台输出解析等等。 我发现建议的监控RAID状态的方法是通过GUI应用程序让我感到困惑。在具有数十台服务器的企业部署中使用哪些方法来以编程方式执行此操作?     
已邀请:
我一直在寻找这个。我有ICHxxx系列控制器,我正试图与英特尔联系,以回应有关公共API的存在,但我并不乐观。 这就是我短期内提出的问题。英特尔将RAID事件记录到“IAANTmon”下的Windows事件日志中。因此,您可以使用System.Diagnostics.EventLog,挂钩EventWrittenEventHandler,然后过滤“IAANTmon”。
        EventLog eLog = new EventLog("Application");
        eLog.EntryWritten += new EntryWrittenEventHandler(OnEntryWrittenEvent);
        eLog.EnableRaisingEvents = true;
    public static void OnEntryWrittenEvent(object source, EntryWrittenEventArgs e)
    {
        if (e.Entry.Source == "IAANTmon")
        {
         ...
        }
    }
    
我一直在研究这个问题,看起来smartmontools是最好的选择。 不幸的是,我没有找到适合我的.NET需求的软件包,因为它只是一些基本的东西,我没有花费数小时寻找合适的解决方案。 我在我的应用程序(Process.Start)开始时使用“smartctl --scan”(smartmontools的一部分),从输出中获取设备列表,然后定期为每个设备启动“smartctl -H device-name” 。 这将返回SMART整体健康测试 - 磁盘的结果,只要返回“PASSED”,您应该是安全的。 虽然这远非理想,但它确实显示了我的raid磁盘的健康状况。     
截至11月16日,Windows 10,我遇到了同样的问题,需要检查英特尔Raid 10的raid状态。 EJA的答案大部分都有效 - 但我没有将任何日志写入源“IAANTmon”。 此时我使用了EJA的答案,但是按源“IAStorDataMgrSvc”进行过滤。这是写我的raid事件日志的地方。此外,我检查的邮件包含“Degraded”或“Rebuilding”。这将排除启动事件并拉出日志,例如“Volume Degraded”,“Volume Rebuilding in progress”,“Volume Rebuilding complete”。 我最终得到了类似的东西:
private static void OnEntryWrittenEvent(object source, EntryWrittenEventArgs e)
      {
         if (e.Entry.Source == "IAStorDataMgrSvc"
            && (e.Entry.Message.Contains("Degraded")
            || e.Entry.Message.Contains("Rebuilding")))
         {
            // Show status message
         }
      }
在启动时,我还检查了前几天的日志,因为当我的程序没有运行时,驱动器被标记为降级 -
foreach (var entry in eLog.Entries.Cast<EventLogEntry>()
               .Where(x => x.Source == "IAStorDataMgrSvc" 
                      && (x.TimeWritten - DateTime.Today).TotalDays < 3))
            {
               if (entry.Message.Contains("Degraded")
                  || entry.Message.Contains("Rebuilding"))
               {
                  // Show status message
               }
            }
    

要回复问题请先登录注册