lib/ohai/plugins/ec2.rb in ohai-13.6.0 vs lib/ohai/plugins/ec2.rb in ohai-13.7.0

- old
+ new

@@ -19,11 +19,12 @@ # limitations under the License. # How we detect EC2 from easiest to hardest & least reliable # 1. Ohai ec2 hint exists. This always works # 2. Xen hypervisor UUID starts with 'ec2'. This catches Linux HVM & paravirt instances -# 3. DMI data mentions amazon. This catches HVM instances in a VPC +# 3. DMI bios version data mentions amazon. This catches HVM instances in a VPC on the Xen based hypervisor +# 3. DMI bios vendor data mentions amazon. This catches HVM instances in a VPC on the non-Xen based hypervisor # 4. Kernel data mentioned Amazon. This catches Windows HVM & paravirt instances Ohai.plugin(:EC2) do require "ohai/mixin/ec2_metadata" require "ohai/mixin/http_helper" @@ -31,36 +32,47 @@ include Ohai::Mixin::Ec2Metadata include Ohai::Mixin::HttpHelper provides "ec2" - depends "dmi" - # look for amazon string in dmi bios data + # look for amazon string in dmi vendor bios data within the sys tree. + # this works even if the system lacks dmidecode use by the Dmi plugin + # this gets us detection of new Xen-less HVM instances that are within a VPC + # @return [Boolean] do we have Amazon DMI data? + def has_ec2_amazon_dmi? + # detect a version of '4.2.amazon' + if file_val_if_exists("/sys/class/dmi/id/bios_vendor") =~ /Amazon/ + Ohai::Log.debug("Plugin EC2: has_ec2_amazon_dmi? == true") + true + else + Ohai::Log.debug("Plugin EC2: has_ec2_amazon_dmi? == false") + false + end + end + + # look for amazon string in dmi bios version data within the sys tree. + # this works even if the system lacks dmidecode use by the Dmi plugin # this gets us detection of HVM instances that are within a VPC # @return [Boolean] do we have Amazon DMI data? - def has_ec2_dmi? + def has_ec2_xen_dmi? # detect a version of '4.2.amazon' - if get_attribute(:dmi, :bios, :all_records, 0, :Version) =~ /amazon/ - Ohai::Log.debug("Plugin EC2: has_ec2_dmi? == true") + if file_val_if_exists("/sys/class/dmi/id/bios_version") =~ /amazon/ + Ohai::Log.debug("Plugin EC2: has_ec2_xen_dmi? == true") true else - Ohai::Log.debug("Plugin EC2: has_ec2_dmi? == false") + Ohai::Log.debug("Plugin EC2: has_ec2_xen_dmi? == false") false end end - # looks for a xen UUID that starts with ec2 - # uses the sys tree on Linux and a WMI query on windows - # this gets us detection of HVM and Paravirt hosts + # looks for a xen UUID that starts with ec2 from within the Linux sys tree # @return [Boolean] do we have a Xen UUID or not? def has_ec2_xen_uuid? - if ::File.exist?("/sys/hypervisor/uuid") - if ::File.read("/sys/hypervisor/uuid") =~ /^ec2/ - Ohai::Log.debug("Plugin EC2: has_ec2_xen_uuid? == true") - return true - end + if file_val_if_exists("/sys/hypervisor/uuid") =~ /^ec2/ + Ohai::Log.debug("Plugin EC2: has_ec2_xen_uuid? == true") + return true end Ohai::Log.debug("Plugin EC2: has_ec2_xen_uuid? == false") false end @@ -80,16 +92,25 @@ Ohai::Log.debug("Plugin EC2: has_ec2_identifying_number? == false") false end end + # return the contents of a file if the file exists + # @param path[String] abs path to the file + # @return [String] contents of the file if it exists + def file_val_if_exists(path) + if ::File.exist?(path) + ::File.read(path) + end + end + # a single check that combines all the various detection methods for EC2 # @return [Boolean] Does the system appear to be on EC2 def looks_like_ec2? return true if hint?("ec2") # Even if it looks like EC2 try to connect first - if has_ec2_xen_uuid? || has_ec2_dmi? || has_ec2_identifying_number? + if has_ec2_xen_uuid? || has_ec2_amazon_dmi? || has_ec2_xen_dmi? || has_ec2_identifying_number? return true if can_socket_connect?(Ohai::Mixin::Ec2Metadata::EC2_METADATA_ADDR, 80) end end collect_data do