config/sysinv/sysinv/sysinv/sysinv/puppet/rook.py
Martin, Chen aa851db31f Introduce rook ceph
1, add storage backend rook ceph for container-based ceph cluster
2, create puppet rook.py
3, update sysinv-agent audit function
   rook ceph provision disk with bluestore, which create a vg and lv
   update sysinv-agent audition function, so after rook-ceph applied
   add rook-ceph created vg named ceph-xxxxx to sysinv-db
4, update lvm filter for rook-ceph provisioned osd

Story: 2005527
Task: 39452

Depends-On: https://review.opendev.org/#/c/713084/
Depends-On: https://review.opendev.org/c/starlingx/rook-ceph/+/716792

Change-Id: If8c1204dd3c7cc25487b2f645ace9aa680d32d59
Signed-off-by: Martin, Chen <haochuan.z.chen@intel.com>
2021-01-27 06:46:02 +08:00

47 lines
1.3 KiB
Python

#
# Copyright (c) 2020 Intel Corporation.
#
# SPDX-License-Identifier: Apache-2.0
#
from sysinv.common import constants
from sysinv.puppet import base
from sysinv.common.storage_backend_conf import StorageBackendConfig
class RookPuppet(base.BasePuppet):
"""Class to encapsulate puppet operations for rook"""
def get_system_config(self):
ceph_rook_backend = StorageBackendConfig.get_backend_conf(
self.dbapi, constants.SB_TYPE_CEPH_ROOK)
enable = False
if ceph_rook_backend:
enable = True
config = {
'platform::rook::params::service_enabled': enable,
}
return config
def get_host_config(self, host):
config = {}
config.update(self._get_lvm_config(host))
return config
def _get_lvm_config(self, host):
rook_vgs = []
# lvm named with ceph-xxxx is the disk provisioned by rook
# system backup and restore will not erase these disk
# when system restore, after unlock host, re-activate these vg
pvs = self.dbapi.ipv_get_by_ihost(host.id)
for pv in pvs:
if pv.lvm_vg_name.startswith("ceph"):
rook_vgs.append(pv.lvm_vg_name)
return {
'platform::rook::vg::rook_vg': rook_vgs,
}