Generic system models

This repo contains general reclass system level of salt model. It is to be used along with service models and concrete cluster deployment model.

Network configuration

Enable SR-IOV support

Include class at cluster.<name>.openstack.compute

- system.nova.compute.nfv.sriov

For single SR-IOV interface setup you can set parameters:

sriov_nic01_device_name
Name of the Physical Function interface (pF)
sriov_nic01_numvfs
Number of Virtual Functions (VF), for number of supported VF check documentation for your network interface card.
sriov_nic01_physical_network
Default physnet1, label for physical network the interface belongs to.
sriov_unsafe_interrupts
Default False, needs to be set True if your hw platform does not support interrupt remapping.

Multiple SR-IOV interface setup:

By default, the metadata model contains configuration for 1 NIC dedicated for SR-IOV, so we need to setup network interfaces like in the following example.

...
  nova:
    compute:
      sriov:
        sriov_nic01:
          devname: eth1
          physical_network: physnet3
        sriov_nic02:
          devname: eth2
          physical_network: physnet4
        sriov_nic03:
          devname: eth3
          physical_network: physnet3
        sriov_nic04:
          devname: eth4
          physical_network: physnet6
  linux:
    system:
      kernel:
        sriov: True
        unsafe_interrupts: False
      rc:
        local: |
          #!/bin/sh -e
          # Enabling 7 VFs on eth1 PF
          echo 7 > /sys/class/net/eth1/device/sriov_numvfs; sleep 2; ip link set eth1 up
          # Enabling 15 VFs on eth2 PF
          echo 15 > /sys/class/net/eth2/device/sriov_numvfs; sleep 2; ip link set eth2 up
          # Enabling 15 VFs on eth3 PF
          echo 15 > /sys/class/net/eth3/device/sriov_numvfs; sleep 2; ip link set eth3 up
          # Enabling 7 VFs on eth4 PF
          echo 7 > /sys/class/net/eth4/device/sriov_numvfs; sleep 2; ip link set eth4 up
          exit 0

Grafana

Configure Grafana client

The grafana.client talks to Grafana server to create datasource(s) and install Grafana plugin(s).

User models must first include this class and define corresponding parameters:

  • grafana.client - grafana_protocol (default: http) - grafana_address - grafana_port (default: 3000) - grafana_user - grafana_password

Then include datasource(s) and define corresponding parameters:

  • grafana.client.datasource.influxdb - grafana_influxdb_address - grafana_influxdb_port - grafana_influxdb_user - grafana_influxdb_password - grafana_influxdb_database - grafana_influxdb_is_default (default true)
  • grafana.client.datasource.prometheus - grafana_prometheus_address - grafana_prometheus_port - grafana_prometheus_is_default (default true)

Backward compatiblity

The class grafana.client.single configures grafana client and an InfluxDB datasource. This is the legacy of LMA (aka StackLight) integration with Grafana and InfluxDB.

Nagios Monitoring

Configure Hosts dynamically

The nagios formula looks up grains.items throught Salt mines to discover hosts. There are two different parameters that tell the nagios formula how to determine the hosts' IP address:

  • nagios_monitoring_network: IP subnet(s) in CIDR notation (can be a list)
  • nagios_monitoring_interface: interface name(s). Default ['eth0', 'ens3'].

'nagios_monitoring_network' parameter takes precedence over 'nagios_monitoring_interface' list.