X-Git-Url: https://git.openstreetmap.org/chef.git/blobdiff_plain/0b5222cd7e08c5c8fdcd7cfada9f75ecc1c7a4e2..1b41d8da97cd9daa2b7476906bd622c4a155ceed:/cookbooks/hardware/templates/default/ohai.rb.erb diff --git a/cookbooks/hardware/templates/default/ohai.rb.erb b/cookbooks/hardware/templates/default/ohai.rb.erb index f6b854c99..343b095a4 100644 --- a/cookbooks/hardware/templates/default/ohai.rb.erb +++ b/cookbooks/hardware/templates/default/ohai.rb.erb @@ -253,19 +253,10 @@ Ohai.plugin(:Hardware) do end def find_md_arrays(devices) - controller = { - :id => devices[:controllers].count, - :type => "md", - :arrays => [], - :disks => [] - } - - devices[:controllers] << controller - array = nil File.new("/proc/mdstat", "r").each do |line| - if line =~ /^(md\d+) : active raid(\d+)((?: (?:sd[a-z]|nvme\d+n\d+)\d*\[\d+\](?:\([A-Z]\))*)+)$/ + if line =~ /^(md\d+) : active raid(\d+)((?: (?:sd[a-z]\d*|nvme\d+n\d+(?:p\d+)?)\[\d+\](?:\([A-Z]\))*)+)$/ array = { :id => devices[:arrays].count, :device => "/dev/#{Regexp.last_match(1)}", @@ -294,7 +285,6 @@ Ohai.plugin(:Hardware) do end devices[:arrays] << array - controller[:arrays] << array[:id] elsif array && line =~ /^\s+(\d+) blocks.*(?:\[([U_]+)\])?/ array[:size] = format_disk_size(Regexp.last_match(1).to_i) array[:status] = "degraded" if Regexp.last_match(2) =~ /_/ @@ -506,8 +496,9 @@ Ohai.plugin(:Hardware) do devices[:disks] << disk controller[:disks] << disk[:id] array[:disks] << disk[:id] - elsif disk && line =~ /^Firmware state:\s+(.*\S),\s*(.*\S)\s*$/ - case Regexp.last_match(1) + elsif disk && line =~ /^Firmware state:\s+(\S.*)$/ + status, state = Regexp.last_match(1).split(/,\s*/) + case status when "Unconfigured(good)" then disk[:status] = "unconfigured" when "Unconfigured(bad)" then disk[:status] = "unconfigured" when "Hotspare" then disk[:status] = "hotspare" @@ -518,7 +509,7 @@ Ohai.plugin(:Hardware) do when "Copyback" then disk[:status] = "rebuilding" else disk[:status] = "unknown" end - case Regexp.last_match(2) + case state when "Spun Up" then disk[:state] = "spun_up" when "Spun down" then disk[:state] = "spun_down" else disk[:state] = "unknown" @@ -564,8 +555,9 @@ Ohai.plugin(:Hardware) do devices[:disks] << disk end - elsif disk && line =~ /^Firmware state:\s+(.*\S),\s*(.*\S)\s*$/ - case Regexp.last_match(1) + elsif disk && line =~ /^Firmware state:\s+(\S.*)$/ + status, state = Regexp.last_match(1).split(/,\s*/) + case status when "Unconfigured(good)" then disk[:status] = "unconfigured" when "Unconfigured(bad)" then disk[:status] = "unconfigured" when "Hotspare" then disk[:status] = "hotspare" @@ -576,7 +568,7 @@ Ohai.plugin(:Hardware) do when "Copyback" then disk[:status] = "rebuilding" else disk[:status] = "unknown" end - case Regexp.last_match(2) + case state when "Spun Up" then disk[:state] = "spun_up" when "Spun down" then disk[:state] = "spun_down" else disk[:state] = "unknown"