Files
ironic/doc/source/admin/inspection/data.rst
Dmitry Tantsur 307c4572a6 Add node auto-discovery support for in-band inspection
This is a MVP of auto-discovery with no extra customization and no new
auto_discovered field from the spec.

Change-Id: I1528096aa08da6af4ac3c45b71d00e86947ed556
2024-02-02 09:24:52 +01:00

2.6 KiB

Inspection data

The in-band inspection processes collects a lot of information about the node. This data consists of two parts:

  • Inventory is hardware inventory <admin/how_it_works.html#hardware-inventory> reported by the agent.
  • Plugin data is data populated by ramdisk-side and server-side plug-ins.

After a successful inspection, you can get both parts as JSON with:

$ baremetal node inventory save <NODE>

Use jq to filter the parts you need, e.g. only the inventory itself:

$ # System vendor information from the inventory
$ baremetal node inventory save <NODE> | jq .inventory.system_vendor
{
  "product_name": "KVM (9.2.0)",
  "serial_number": "",
  "manufacturer": "Red Hat",
  "firmware": {
    "vendor": "EDK II",
    "version": "edk2-20221207gitfff6d81270b5-7.el9",
    "build_date": "12/07/2022"
  }
}

$ # Interfaces used to create ports
$ baremetal node inventory save <NODE> | jq .plugin_data.valid_interfaces
{
  "eth0": {
    "name": "eth0",
    "mac_address": "52:54:00:5e:09:ff",
    "ipv4_address": "192.168.122.164",
    "ipv6_address": "fe80::5054:ff:fe5e:9ff",
    "has_carrier": true,
    "lldp": null,
    "vendor": "0x1af4",
    "product": "0x0001",
    "client_id": null,
    "biosdevname": null,
    "speed_mbps": null,
    "pxe_enabled": true
  }
}

Plugin data

Plugin data is the storage for all information that is collected or processed by various plugins. Its format is not a part of the API stability promise and may change depending on your configuration.

Plugin data comes from two sources:

  • inspection collectors <admin/how_it_works.html#inspection-data> - ramdisk-side inspection plug-ins.
  • hooks - server-side inspection plug-ins.

Data storage

There are several options to store the inspection data, specified via the :oslo.configinventory.data_backend option:

none

Do not store inspection data at all. The API will always return 404 NOT FOUND.

database

Store inspection data in a separate table in the main database.

swift

Store inspection data in the Object Store service (swift) in the container specified by the :oslo.configinventory.swift_data_container option.

Warning

There is currently no way to migrate data between backends. Changing the backend will remove access to existing data.