diff options
-rw-r--r-- | sdv/docker/sdvstate/tools/kube_utils.py | 66 | ||||
-rw-r--r-- | sdv/docker/sdvstate/validator/airship/airship.py | 4 | ||||
-rw-r--r-- | sdv/docker/sdvstate/validator/airship/compute_check.py | 19 | ||||
-rw-r--r-- | sdv/pdf/site/index.html | 184 | ||||
-rw-r--r-- | sdv/pdf/template/pdf_template.json | 1144 |
5 files changed, 864 insertions, 553 deletions
diff --git a/sdv/docker/sdvstate/tools/kube_utils.py b/sdv/docker/sdvstate/tools/kube_utils.py index 3468ac6..9c543db 100644 --- a/sdv/docker/sdvstate/tools/kube_utils.py +++ b/sdv/docker/sdvstate/tools/kube_utils.py @@ -18,6 +18,8 @@ Kubernetes cluster api helper functions """ +import time + from kubernetes import client, config from kubernetes.stream import stream @@ -77,9 +79,67 @@ def kube_curl(*args): args = list(args) args.insert(0, "curl") - labels = "application=prometheus-openstack-exporter,component=exporter" - pod = get_pod_with_labels(labels) - response = kube_exec(pod, args) + try: + pod = get_pod_with_labels("application=sdvstate-curl") + except IndexError: + create_kube_curl_pod() + pod = get_pod_with_labels("application=sdvstate-curl") + finally: + response = kube_exec(pod, args) return response + + +def create_kube_curl_pod(): + """ + Create a sandbox pod(image: curlimages/curl:7.76.1) for + curl utility inside kubernetes cluster. + """ + print(("Creating pod sdvstate-curl...")) + pod_manifest = { + 'apiVersion': 'v1', + 'kind': 'Pod', + 'metadata': { + 'name': 'sdvstate-curl', + 'labels': { + 'application': 'sdvstate-curl' + } + }, + 'spec': { + 'containers': [{ + 'image': 'curlimages/curl:7.76.1', + 'name': 'sdvstate-curl', + 'command': ["/bin/sh"], + "args": [ + "-c", + "while true; do sleep 5; done" + ] + }] + } + } + + api = kube_api() + response = api.create_namespaced_pod(body=pod_manifest, + namespace='default') + # wait 1 minute or less for pod to create. + seconds_left = 60 + while seconds_left: + resp = api.read_namespaced_pod(name='sdvstate-curl', + namespace='default') + if resp.status.phase == 'Running': + break + time.sleep(3) + seconds_left -= 3 + + if seconds_left == 0: + raise Exception("sdvstate-curl pod taking took long to create, tests failed...") + + +def delete_kube_curl_pod(): + """ + Cleans curl utility pod + """ + api = kube_api() + api.delete_namespaced_pod(name='sdvstate-curl', body={}, + namespace='default') diff --git a/sdv/docker/sdvstate/validator/airship/airship.py b/sdv/docker/sdvstate/validator/airship/airship.py index 18de66d..f2bdebd 100644 --- a/sdv/docker/sdvstate/validator/airship/airship.py +++ b/sdv/docker/sdvstate/validator/airship/airship.py @@ -21,7 +21,7 @@ import logging from datetime import datetime as dt from tools.conf import settings -from tools.kube_utils import load_kube_api +from tools.kube_utils import load_kube_api, delete_kube_curl_pod from validator.validator import Validator from . import * @@ -92,6 +92,8 @@ class AirshipValidator(Validator): self.update_report(nova_scheduler_filters_check()) self.update_report(cpu_allocation_ratio_check()) + delete_kube_curl_pod() + self._report['stop_date'] = dt.now().strftime('%Y-%m-%d %H:%M:%S') diff --git a/sdv/docker/sdvstate/validator/airship/compute_check.py b/sdv/docker/sdvstate/validator/airship/compute_check.py index ff6f6db..a602471 100644 --- a/sdv/docker/sdvstate/validator/airship/compute_check.py +++ b/sdv/docker/sdvstate/validator/airship/compute_check.py @@ -18,6 +18,7 @@ Compute Related Checks import configparser import json +import re from tools.kube_utils import kube_exec, get_pod_with_labels from tools.conf import settings @@ -291,7 +292,14 @@ def trace_vswitch_pmd_cores(): cmd = ['ovs-vsctl', '-t', '5', 'get', 'Open_vSwitch', '.', 'other_config'] response = kube_exec(ovs_pod, cmd) - response.replace('=', ':') + # convert config str to json str + match = re.findall("[a-zA-Z0-9-]+=", response) + for key in match: + response = response.replace(key, '"' + key[:-1] + '":') + match = re.findall(":[a-zA-Z0-9-]+", response) + for key in match: + response = response.replace(key[1:], '"' + key[1:] + '"') + config = json.loads(response) if 'pmd-cpu-mask' in config: @@ -330,7 +338,14 @@ def trace_vswitch_dpdk_lcores(): cmd = ['ovs-vsctl', '-t', '5', 'get', 'Open_vSwitch', '.', 'other_config'] response = kube_exec(ovs_pod, cmd) - response.replace('=', ':') + # convert config str to json str + match = re.findall("[a-zA-Z0-9-]+=", response) + for key in match: + response = response.replace(key, '"' + key[:-1] + '":') + match = re.findall(":[a-zA-Z0-9-]+", response) + for key in match: + response = response.replace(key[1:], '"' + key[1:] + '"') + config = json.loads(response) if 'dpdk-lcore-mask' in config: diff --git a/sdv/pdf/site/index.html b/sdv/pdf/site/index.html index fe88f29..edc3750 100644 --- a/sdv/pdf/site/index.html +++ b/sdv/pdf/site/index.html @@ -87,10 +87,12 @@ <li><a data-toggle="formtab" href="#rackInfo">Rack Information</a></li> <li><a data-toggle="formtab" href="#stocluInfo">Storage Cluster Information</a></li> <li><a data-toggle="formtab" href="#biosProfiles">BIOS Profiles</a></li> + <li><a data-toggle="formtab" href="#bmcProfiles">BMC Profiles</a></li> <li><a data-toggle="formtab" href="#procProfiles">Processor Profiles</a></li> <li><a data-toggle="formtab" href="#disksProfiles">Disks Profiles</a></li> <li><a data-toggle="formtab" href="#nicProfiles">NIC Profiles</a></li> <li><a data-toggle="formtab" href="#hwProfiles">Hardware Profiles</a></li> + <li><a data-toggle="formtab" href="#swProfiles">Switch Profiles</a></li> <li><a data-toggle="formtab" href="#storprofiles">Storage Profiles</a></li> <li><a data-toggle="formtab" href="#virNets">Networks</a></li> <li><a data-toggle="formtab" href="#phyNets">Physical Networks</a></li> @@ -135,9 +137,17 @@ <input type="text" placeholder="Bangalore" name="city"> </div> <div class="form-field"> + <label>Resource Pool ID</label> + <input type="text" placeholder="EPG_ID" name="resource_pool_id"> + </div> + <div class="form-field"> <label>Resource Pool Name</label> <input type="text" placeholder="EPG" name="resource_pool_name"> </div> + <div class="form-field"> + <label>Resource Pool Type</label> + <input type="text" placeholder="CLD" name="resource_pool_type"> + </div> </div> </div> <div class="next-btn"> @@ -150,6 +160,18 @@ <hr> <div class="arr" name="user_info"> <div class="form-field"> + <label>Access Type</label> + <input type="text" placeholder="VIM" name="access_type"> + </div> + <div class="form-field"> + <label>Endpoint</label> + <input type="text" placeholder="Server" name="endpoint"> + </div> + <div class="form-field"> + <label>Authetication Type</label> + <input type="text" placeholder="passwd" name="auth_type"> + </div> + <div class="form-field"> <label>Username</label> <input type="text" placeholder="sridhar" name="username"> </div> @@ -426,12 +448,16 @@ <input type="text" placeholder=" " name="ironic_deploy_interface"> </div> <div class="form-field"> + <label> IP Type </label> + <input type="text" placeholder="v4" name="ip_type"> + </div> + <div class="form-field"> <label> External Storage Cluster (Y/N) </label> <input type="text" placeholder=" " name="external_storage_cluster"> </div> <div class="form-field"> <label> Block Storage Connection Method</label> - <input type="text" placeholder=" " name="bl_str_connect_method"> + <input type="text" placeholder=" " name="blk_str_connect_method"> </div> </div> </div> @@ -473,15 +499,27 @@ <hr> <div class="form-field"> <label> Rack Name </label> - <input type="text" placeholder=" " name=" "> + <input type="text" placeholder=" " name="rack_name"> </div> <div class="form-field"> <label> Rack Description </label> - <input type="text" placeholder=" " name=" "> + <input type="text" placeholder=" " name="rack_description"> </div> <div class="form-field"> <label> Rack Availability Zone </label> - <input type="text" placeholder=" " name=" "> + <input type="text" placeholder=" " name="rack_az"> + </div> + <div class="form-field"> + <label> Rack Room </label> + <input type="text" placeholder=" " name="rack_room"> + </div> + <div class="form-field"> + <label> Rack Number </label> + <input type="text" placeholder=" " name="rack_number"> + </div> + <div class="form-field"> + <label> Rack Raw </label> + <input type="text" placeholder=" " name="rack_raw"> </div> </div> </div> @@ -506,6 +544,14 @@ <input type="text" placeholder=" " name="cluster_type"> </div> <div class="form-field"> + <label> Cluster Vendor </label> + <input type="text" placeholder=" " name="vendor"> + </div> + <div class="form-field"> + <label> Cluster Version </label> + <input type="text" placeholder=" " name="version"> + </div> + <div class="form-field"> <label> Cluster ID </label> <input type="text" placeholder=" " name="cluster_id"> </div> @@ -527,7 +573,7 @@ <div class="arr" name="mon_host_ips"> <div class="form-field"> <label>IP Address</label> - <input type="text" placeholder="a:b:c:d" name="ips"> + <input type="text" placeholder="a:b:c:d" name="ip"> </div> </div> <div class="add-button" onclick="duplicate(this)"></div> @@ -548,6 +594,30 @@ <input type="text" placeholder=" " name="cluster_cidr"> </div> <div class="form-field"> + <label> Nodes </label> + </div> + <div class="arr" name="nodes"> + <div class="form-field"> + <label>Node Name</label> + <input type="text" placeholder=" " name="name"> + </div> + <div class="form-field"> + <label>Node Id</label> + <input type="text" placeholder=" " name="id"> + </div> + </div> + <div class="add-button" onclick="duplicate(this)"></div> + <div class="form-field"> + <label> Networks </label> + </div> + <div class="arr" name="networks"> + <div class="form-field"> + <label>Network Name</label> + <input type="text" placeholder=" " name="name"> + </div> + </div> + <div class="add-button" onclick="duplicate(this)"></div> + <div class="form-field"> <label> Pools </label> </div> <div class="arr" name="pools"> @@ -561,6 +631,14 @@ </div> </div> <div class="add-button" onclick="duplicate(this)"></div> + <div class="form-field"> + <label> Availablity Zone Name </label> + <input type="text" placeholder=" " name="az_name"> + </div> + <div class="form-field"> + <label> Backup Policy </label> + <input type="text" placeholder=" " name="backup_policy"> + </div> </div> </div> <div class="next-btn"> @@ -572,7 +650,7 @@ <h4> BIOS Profiles </h4> <hr> <div class="devider-row"> - <div class="arr" name="bios_profile"> + <div class="arr" name="bios_profiles"> <div class="form-field"> <label>Profile Name </label> <input type="text" placeholder=" " name="profile_name"> @@ -592,7 +670,7 @@ <input type="text" placeholder=" " name="bootstrap_proto"> </div> <div class="form-field"> - <label> Hyperthreading Enabled (Y/N) </label> + <label> Hyperthreading Enabled (Yes/No) </label> <input type="text" placeholder=" " name="hyperthreading_enabled"> </div> <div class="form-field"> @@ -605,6 +683,31 @@ </div> </div> <div class="next-btn"> + <a data-toggle="formtab" href="#bmcProfiles">Next</a> + </div> + </div> + <div class="tabs-panels" id="bmcProfiles"> + <div class="tab-part"> + <h4> BMC Profiles </h4> + <hr> + <div class="devider-row"> + <div class="arr" name="bios_profiles"> + <div class="form-field"> + <label>Profile Name </label> + <input type="text" placeholder=" " name="profile_name"> + </div> + <div class="form-field"> + <label> BMC Info </label> + <div class="form-field"> + <label> BMC Version </label> + <input type="text" placeholder=" " name="bmc_version"> + </div> + </div> + </div> + <div class="add-button" onclick="duplicate(this)"></div> + </div> + </div> + <div class="next-btn"> <a data-toggle="formtab" href="#procProfiles">Next</a> </div> </div> @@ -794,12 +897,20 @@ <input type="text" placeholder=" " name="name"> </div> <div class="form-field"> + <label> Profile ID </label> + <input type="text" placeholder=" " name="id"> + </div> + <div class="form-field"> <label> Profile Info </label> <div class="form-field"> <label> Server Manufacturer </label> <input type="text" placeholder=" " name="manufacturer"> </div> <div class="form-field"> + <label> Server SKU </label> + <input type="text" placeholder=" " name="sku"> + </div> + <div class="form-field"> <label> Compute Server Model </label> <input type="text" placeholder=" " name="model"> </div> @@ -812,6 +923,10 @@ <input type="text" placeholder=" " name="bios_profile"> </div> <div class="form-field"> + <label> BMC Profile</label> + <input type="text" placeholder=" " name="bmc_profile"> + </div> + <div class="form-field"> <label> Processor Profile </label> <input type="text" placeholder=" " name="processor_profile"> </div> @@ -833,6 +948,55 @@ </div> </div> <div class="next-btn"> + <a data-toggle="formtab" href="#swProfiles">Next</a> + </div> + </div> + <div class="tabs-panels" id="swProfiles"> + <div class="tab-part"> + <h4> Switch Profiles </h4> + <hr> + <div class="devider-row"> + <div class="arr"> + <div class="form-field"> + <label> Profile Name </label> + <input type="text" placeholder=" " name="name"> + </div> + <div class="form-field"> + <label> Profile ID </label> + <input type="text" placeholder=" " name="name"> + </div> + <div class="form-field"> + <label> Profile Info </label> + <div class="form-field"> + <label> Switch Manufacturer </label> + <input type="text" placeholder=" " name="manufacturer"> + </div> + <div class="form-field"> + <label> Switch SKU </label> + <input type="text" placeholder=" " name="sku"> + </div> + <div class="form-field"> + <label> Switch Model </label> + <input type="text" placeholder=" " name="model"> + </div> + <div class="form-field"> + <label> Switch Generation </label> + <input type="text" placeholder=" " name="generation"> + </div> + <div class="form-field"> + <label> Bios Profile</label> + <input type="text" placeholder=" " name="bios_profile"> + </div> + <div class="form-field"> + <label> BMC Profile </label> + <input type="text" placeholder=" " name="bmc_profile"> + </div> + </div> + </div> + <div class="add-button" onclick="duplicate(this)"></div> + </div> + </div> + <div class="next-btn"> <a data-toggle="formtab" href="#storProfiles">Next</a> </div> </div> @@ -1175,7 +1339,7 @@ <h4> Network-Interface Mapping </h4> <hr> <div class="devider-row"> - <div class="arr", name="interface_mapping_profiles"> + <div class="arr", name="link_nw_mapping_profiles"> <div class="form-field"> <label> Profile Name </label> <input type="text" placeholder=" " name="profile_name"> @@ -1186,11 +1350,11 @@ <div class="arr" name="profile_data"> <div class="form-field"> <label> Interface Name </label> - <input type="text" placeholder=" " name="interface_name"> + <input type="text" placeholder=" " name="link_name"> </div> <div class="form-field"> <label> Interface Type </label> - <input type="text" placeholder=" " name="interface_type"> + <input type="text" placeholder=" " name="link_type"> </div> <div class="form-field"> <label> Use DHCP (Y/N) </label> diff --git a/sdv/pdf/template/pdf_template.json b/sdv/pdf/template/pdf_template.json index 5dfada5..8778e10 100644 --- a/sdv/pdf/template/pdf_template.json +++ b/sdv/pdf/template/pdf_template.json @@ -1,537 +1,607 @@ -{
- "_comment_head":"Maintainer - Sridhar Rao <sridhar.rao@spirent.com>",
- "_comment_head1":"User should Configure all profiles. Add new, if reqd.",
- "_comment_head2":"User should Configure the roles",
- "_comment_head3":"All infos should be filled by the user",
- "_comment_head4":"The servers data will be automatically generated",
- "_comment_info1":"All Infos",
- "management_info": {
- "owner":"",
- "area_name": "",
- "area_center_name": "",
- "room_id": "",
- "city": "",
- "resource_pool_name": ""
- },
- "user_info": [
- {
- "username":"",
- "password":"",
- "pub_key":"",
- "passphrase":"",
- "tls_ca_cert":"",
- "tls_cert":"",
- "tls_key":"",
- "email":""
- }
- ],
- "ntp_info": {
- "primary_ip":"",
- "primary_zone":"",
- "secondary_ip":"",
- "secondary_zone":""
- },
- "syslog_info": {
- "server_ip":"",
- "transport":""
- },
- "dns_info": [
- {
- "name":"",
- "domain":"",
- "servers": [
- {
- "ip": ""
- }
- ]
- }
- ],
- "proxy_info": {
- "address":"",
- "port":"",
- "user":"",
- "password":""
- },
- "ldap_info": {
- "base_url":"",
- "url":"",
- "auth_path":"",
- "common_name":"",
- "subdomain":"",
- "domain":""
- },
- "vim_info": {
- "vim_name": " ",
- "vim_id": " ",
- "vendor": " ",
- "version": " ",
- "installer":"",
- "deployment_style":"",
- "container_orchestrator":"",
- "storage_type":""
- },
- "_comment_deployment":" Type can be OOK or NOOK, block storage method is rbd or iscsi",
- "deployment_info": {
- "high_availability":"",
- "introspection":"",
- "deployment_type":"",
- "installer_used":"",
- "workload_vnf":"",
- "workload_cnf":"",
- "sdn_controller":"",
- "sdn_controller_version":"",
- "sdn_controller_nbapps":"",
- "vnfm":"",
- "vnfm_version":"",
- "data_plane_used":"",
- "ironic_deploy_interface":"",
- "external_storage_cluster":"",
- "bl_str_connect_method":""
- },
- "vim_functional": {
- "scheduler_filters":"",
- "cpu_allocation_ratio":""
- },
- "jumphost_info": {
- "ip":"",
- "name":""
- },
- "rack_info": [
- {
- "rack_id":"",
- "rack_details": {
- "rack_name":"",
- "rack_description":"",
- "rack_az":""
- }
- }
- ],
- "storage_cluster_info": {
- "name":"",
- "cluster_type":"",
- "cluster_id":"",
- "auth_type":"",
- "username":"",
- "password":"",
- "certificate_location":"",
- "client_key":"",
- "mon_host_ips": [
- {
- "ips":""
- }
- ],
- "public_cidr":"",
- "cluster_cidr":"",
- "pools": [
- {
- "key":"",
- "value":""
- }
- ]
- },
- "_comment_info2": "End of Information - Except Software-INFO",
- "bios_profile": [
- {
- "profile_name":"",
- "bios_info":
- {
- "bios_version": "",
- "bios_mode":"",
- "bootstrap_proto":"",
- "hyperthreading_enabled":"",
- "_comment":"C4_C6_MLC-STR_MLC-SPA_DCU_DCA_RAS_TURBO",
- "bios_setting":""
- }
- }
- ],
- "processor_profiles": [
- {
- "profile_name":"",
- "profile_info":
- {
- "manufacturer": "",
- "generation":"",
- "speed":"",
- "model":"",
- "architecture":"",
- "cpu_cflags":"",
- "cache_size":"",
- "numas": [
- {
- "node_id":"",
- "cpu_set":""
- }
- ]
- }
- }
- ],
- "disks_profiles": [
- {
- "profile_name":"",
- "profile_info": [
- {
- "alias":"",
- "vendor":"",
- "address":"",
- "size":"",
- "model":"",
- "dev_type":"",
- "rotation":"",
- "bus":"",
- "logical_name":""
- }
- ]
- }
- ],
- "nic_profiles": [
- {
- "profile_name":"",
- "profile_info": [
- {
- "alias":"",
- "name":"",
- "address":"",
- "dev_type":"",
- "bus":"",
- "sriov_capable":"",
- "numa_id":""
- }
- ]
- }
- ],
- "hardware_profiles": [
- {
- "profile_name": "",
- "profile_info": {
- "manufacturer": "",
- "model": "",
- "generation":"",
- "bios_profile":"",
- "processor_profile": "",
- "memory": "",
- "disks_profile": "",
- "nics_profile":""
- }
- }
- ],
- "_comment_hw":" Hardware Information is complete",
- "storage_profile": [
- {
- "name":"",
- "bootdrive":"",
- "bd_partitions": [
- {
- "name":"",
- "size":"",
- "bootable":"",
- "filesystem": {
- "mountpoint":"",
- "fstype":"",
- "mount_options":""
- }
- }
- ],
- "data_devices": [
- {
- "name":"",
- "partitions": [
- {
- "name":"ceph",
- "size":"available",
- "filesystem": {
- "mountpoint":"/var/lib/ceph",
- "fstype":"ext4",
- "mount_options":"defaults"
- }
- }
- ]
- }
- ],
- "journal_devices": [
- {
- "name":""
- }
- ]
-
- }
- ],
- "_comment_nw1": "Network Info, Please include IPMI & Physnets info too",
- "networks": [
- {
- "name":"",
- "vips":[
- {
- "name":"",
- "ip":""
- }
- ],
- "tunnel_type":"",
- "tunnel_id":"",
- "tunnel_id_range":"",
- "mtu":"",
- "routedomain":"",
- "cidr":"",
- "dns":"",
- "routes": [
- {
- "subnet":"",
- "gateway":"",
- "metric":"",
- "routedomain":""
- }
- ],
- "allocation_pools": [
- {
- "type":"",
- "start":"",
- "end":""
- }
- ],
- "v6_cidr":"",
- "v6_allocation_pools": [
- {
- "type":"",
- "start":"",
- "end":""
- }
- ]
- }
- ],
- "physical_networks": [
- {
- "name":"external",
- "cidr":"",
- "type":"flat"
- }
- ],
- "_comment_nw2":" type: trunk (airship), bond, interface, bridge",
- "network_link": [
- {
- "name":"",
- "type":"",
- "bonding_mode":"",
- "mtu":"",
- "linkspeed":"auto",
- "trunking_mode":"",
- "trunking_default_nw":"",
- "metadata": [
- {
- "key":"",
- "value":""
- }
- ],
- "members":[
- {
- "name":"",
- "type":""
- }
- ],
- "vid":"",
- "vf_count":""
- }
- ],
- "_comment_nw4": "The interface_name could be i/f, bond, bridges",
- "_comment_nw5": "These profiles are mapped to roles",
- "interface_mapping_profiles": [
- {
- "profile_name":"",
- "profile_data": [
- {
- "interface_name":"",
- "interface_type":"",
- "networks": [
- {
- "name":""
- }
- ],
- "use_dhcp":""
- }
- ]
- }
- ],
- "platform_profiles": [
- {
- "profile_name":"",
- "os":"",
- "rt_kvm":"",
- "kernel_version":"",
- "kernel_parameters":"",
- "isolated_cpus":"",
- "vnf_cores":"",
- "os_reserved_cores": " ",
- "hugepage_count":"",
- "hugepages": [
- {
- "hugepage_count":"",
- "hugepage_size":""
- }
- ],
- "iommu":"",
- "vswitch_daemon_cores": " ",
- "vswitch_type":"",
- "vswitch_uio_driver":"",
- "vswitch_mem_channels":"",
- "vswitch_socket_memory":"",
- "vswitch_pmd_cores":"",
- "vswitch_dpdk_lcores":"",
- "vswitch_dpdk_rxqs":"",
- "vswitch_options":""
- }
- ],
- "undercloud_ook":{
- "dns": {
- "cluster_domain":"",
- "service_ip":""
- },
- "etcd":{
- "service_ip":"",
- "container_port":"",
- "haproxy_port":""
- },
- "masters": [
- {
- "hostname":""
- }
- ],
- "networking":{
- "type":"",
- "interface_used":"",
- "api_service_ip":"",
- "etcd_service_ip":"",
- "pod_cidr":"",
- "service_cidr":"",
- "apiserver_port":"",
- "haproxy_port":"",
- "servicenode_port_range":""
- },
- "kvps":[
- {
- "key":"",
- "value":""
- }
- ]
-
- },
- "undercloud_ooo":{
- "host_name":"",
- "local_ip":"",
- "public_host":"",
- "admin_host":"",
- "local_interface":"",
- "inspection_interface":"",
- "networking":{
- "ctrlplane_cidr":"",
- "ctrlplane_ip_start":"",
- "ctrlplane_ip_end":"",
- "inspection_range":"",
- "gateway":""
- }
- },
- "_comment_sw1":"Software Begins",
- "undercloud_sw_profiles":[
- {
- "profile_name":"",
- "sw_list": [
- {
- "name":"",
- "version":""
- }
- ]
- }
- ],
- "openstack_sw_profiles":[
- {
- "profile_name":"",
- "sw_list": [
- {
- "name":"",
- "version":""
- }
- ]
- }
- ],
- "infra_sw_profiles":[
- {
- "profile_name":"",
- "sw_list": [
- {
- "name":"",
- "version":""
- }
- ]
- }
- ],
- "software_set": [
- {
- "set_name":"",
- "undercloud_profile":"",
- "infrasw_profile":"",
- "openstack_profile":""
- }
- ],
- "_comment_role1":"User has to configure this - What profile to use for a role",
- "_comment_role2":"Based on this server_info will be autogenerated for all servers",
- "roles": [
- {
- "name":"",
- "hostname_prefix":"",
- "hostname_suffix":"",
- "hostname_number_start":"",
- "count":"",
- "hardware_profile":"",
- "interface_mapping":"",
- "storage_mapping":"",
- "platform_profile":"",
- "sw_set_name":"",
- "metadata": [
- {
- "on_count_condition":"",
- "count":"",
- "key":"",
- "value":""
- }
- ]
- }
- ],
- "_comment_ex1":"C:City, A:Area, R:Room, N:Unique Number",
- "_comment_ex2":"All are 2 characters. City-Capitals, Area-Small",
- "extrapolation_info": {
- "ilo_password":"CID-AID-RID-NID",
- "ilo_user":"owner",
- "ip_increment":""
- },
- "host_aggregates": [
- {
- "aggregate_name":"",
- "properties": [
- {
- "key":"",
- "value":""
- }
- ],
- "servers": [
- {
- "identifier":"",
- "ilo_ip":"",
- "hostname":""
- }
- ]
- }
- ],
- "_comment_servers1":"This will be auto generated",
- "_comment_servers2":"This describes the entire cloud.",
- "servers": [
- {
- "role_name":"",
- "device_name":"",
- "az_name": " ",
- "ha_name": " ",
- "rack":"",
- "ilo_info": {
- "ip":"",
- "user":"",
- "password":""
- }
- }
- ]
-}
+{ + "_comment_head": "Maintainer - Sridhar Rao <sridhar.rao@spirent.com>", + "_comment_head1": "User should Configure all profiles. Add new, if reqd.", + "_comment_head2": "User should Configure the roles", + "_comment_head3": "All infos should be filled by the user", + "_comment_head4": "The servers data will be automatically generated", + "_comment_info1": "All Infos", + "management_info": { + "owner": "", + "area_name": "", + "area_center_name": "", + "room_id": "", + "city": "", + "timezone": "", + "resource_pool_id": "", + "resource_pool_name": "", + "resource_pool_type": "" + }, + "user_info": [ + { + "_comment_users1": " Access Type: PIM, VIM, etc.", + "_comment_users2": " Endpoint: Server, Switch, VIM, etc.", + "access_type": "", + "endpoint": "", + "auth_type": "", + "username": "", + "password": "", + "pub_key": "", + "passphrase": "", + "tls_ca_cert": "", + "tls_cert": "", + "tls_key": "", + "email": "" + } + ], + "ntp_info": { + "primary_ip": "", + "primary_zone": "", + "secondary_ip": "", + "secondary_zone": "" + }, + "syslog_info": { + "server_ip": "", + "transport": "" + }, + "dns_info": [ + { + "name": "", + "domain": "", + "servers": [ + { + "ip": "" + } + ] + } + ], + "proxy_info": { + "address": "", + "port": "", + "user": "", + "password": "" + }, + "ldap_info": { + "base_url": "", + "url": "", + "auth_path": "", + "common_name": "", + "subdomain": "", + "domain": "" + }, + "vim_info": { + "vim_name": " ", + "vim_id": " ", + "vendor": " ", + "version": " ", + "installer": "", + "deployment_style": "", + "container_orchestrator": "", + "storage_type": "" + }, + "_comment_deployment": " Type can be OOK or NOOK, block storage method is rbd or iscsi", + "deployment_info": { + "high_availability": "", + "introspection": "", + "deployment_type": "", + "installer_used": "", + "workload_vnf": "", + "workload_cnf": "", + "sdn_controller": "", + "sdn_controller_version": "", + "sdn_controller_nbapps": "", + "vnfm": "", + "vnfm_version": "", + "data_plane_used": "", + "ironic_deploy_interface": "", + "ip_type": "", + "external_storage_cluster": "", + "blk_str_connect_method": "" + }, + "vim_functional": { + "scheduler_filters": "", + "cpu_allocation_ratio": "" + }, + "jumphost_info": { + "ip": "", + "name": "" + }, + "rack_info": [ + { + "rack_id": "", + "rack_details": { + "rack_name": "", + "rack_description": "", + "rack_az": "", + "rack_room": "", + "rack_raw": "", + "rack_number": "" + } + } + ], + "storage_cluster_info": { + "name": "", + "cluster_type": "", + "vendor": "", + "version": "", + "cluster_id": "", + "auth_type": "", + "username": "", + "password": "", + "certificate_location": "", + "client_key": "", + "mon_host_ips": [ + { + "ip": "" + } + ], + "public_cidr": "", + "cluster_cidr": "", + "nodes": [ + { + "name": "", + "id": "" + } + ], + "pools": [ + { + "key": "", + "value": "" + } + ], + "max_quota_capacity": "", + "az_name": "", + "backup_policy": "", + "networks": [ + { + "name": "" + } + ] + }, + "_comment_info2": "End of Information - Except Software-INFO", + "bios_profiles": [ + { + "profile_name": "", + "bios_info": { + "bios_version": "", + "bios_mode": "", + "bootstrap_proto": "", + "hyperthreading_enabled": "", + "_comment": "C4_C6_MLC-STR_MLC-SPA_DCU_DCA_RAS_TURBO", + "bios_setting": "" + } + } + ], + "bmc_profiles": [ + { + "profile_name": "", + "bmc_info": { + "version": "" + } + } + ], + "processor_profiles": [ + { + "profile_name": "", + "profile_info": { + "manufacturer": "", + "generation": "", + "speed": "", + "model": "", + "architecture": "", + "cpu_cflags": "", + "cache_size": "", + "numas": [ + { + "node_id": "", + "cpu_set": "" + } + ] + } + } + ], + "disks_profiles": [ + { + "profile_name": "", + "profile_info": [ + { + "alias": "", + "vendor": "", + "address": "", + "size": "", + "model": "", + "dev_type": "", + "rotation": "", + "bus": "", + "logical_name": "" + } + ] + } + ], + "nic_profiles": [ + { + "profile_name": "", + "profile_info": [ + { + "alias": "", + "name": "", + "address": "", + "dev_type": "", + "bus": "", + "sriov_capable": "", + "numa_id": "" + } + ] + } + ], + "hardware_profiles": [ + { + "profile_name": "", + "profile_id": "", + "profile_info": { + "manufacturer": "", + "sku": "", + "model": "", + "generation": "", + "bios_profile": "", + "bmc_profile": "", + "processor_profile": "", + "memory": "", + "disks_profile": "", + "nics_profile": "" + } + } + ], + "switch_profiles": [ + { + "profile_name": "", + "profile_id": "", + "profile_info": { + "manufacturer": "", + "sku": "", + "model": "", + "generation": "", + "bios_profile": "", + "bmc_profile": "", + "nics_profile": "" + } + } + ], + "_comment_hw": " Hardware Information is complete", + "storage_profile": [ + { + "name": "", + "bootdrive": "", + "bd_partitions": [ + { + "name": "", + "size": "", + "bootable": "", + "filesystem": { + "mountpoint": "", + "fstype": "", + "mount_options": "" + } + } + ], + "data_devices": [ + { + "name": "", + "partitions": [ + { + "name": "ceph", + "size": "available", + "filesystem": { + "mountpoint": "/var/lib/ceph", + "fstype": "ext4", + "mount_options": "defaults" + } + } + ] + } + ], + "journal_devices": [ + { + "name": "" + } + ] + } + ], + "_comment_nw1": "Network Info, Please include IPMI & Physnets info too", + "networks": [ + { + "name": "", + "vips": [ + { + "name": "", + "ip": "" + } + ], + "tunnel_type": "", + "tunnel_id": "", + "tunnel_id_range": "", + "mtu": "", + "routedomain": "", + "cidr": "", + "dns": "", + "routes": [ + { + "subnet": "", + "gateway": "", + "metric": "", + "routedomain": "" + } + ], + "allocation_pools": [ + { + "type": "", + "start": "", + "end": "" + } + ], + "v6_cidr": "", + "v6_allocation_pools": [ + { + "type": "", + "start": "", + "end": "" + } + ] + } + ], + "_comment_nw_2": "These are specific to Infrastructure manager", + "physical_networks": [ + { + "name": "external", + "cidr": "", + "type": "flat" + } + ], + "_comment_nw3": " type: trunk (airship), bond, interface, bridge", + "network_link": [ + { + "name": "", + "type": "", + "bonding_mode": "", + "mtu": "", + "linkspeed": "auto", + "trunking_mode": "", + "trunking_default_nw": "", + "metadata": [ + { + "key": "", + "value": "" + } + ], + "members": [ + { + "name": "", + "type": "" + } + ], + "vid": "", + "vf_count": "" + } + ], + "_comment_nw4": "The link_name could be i/f, bond, bridges", + "_comment_nw5": "These profiles are mapped to roles", + "link_nw_mapping_profiles": [ + { + "profile_name": "", + "profile_data": [ + { + "link_name": "", + "link_type": "", + "networks": [ + { + "name": "" + } + ], + "use_dhcp": "" + } + ] + } + ], + "platform_profiles": [ + { + "profile_name": "", + "os": "", + "rt_kvm": "", + "kernel_version": "", + "kernel_parameters": "", + "isolated_cpus": "", + "vnf_cores": "", + "os_reserved_cores": " ", + "hugepage_count": "", + "hugepages": [ + { + "hugepage_count": "", + "hugepage_size": "" + } + ], + "iommu": "", + "vswitch_daemon_cores": " ", + "vswitch_type": "", + "vswitch_uio_driver": "", + "vswitch_mem_channels": "", + "vswitch_socket_memory": "", + "vswitch_pmd_cores": "", + "vswitch_dpdk_lcores": "", + "vswitch_dpdk_rxqs": "", + "vswitch_options": "" + } + ], + "undercloud_ook": { + "dns": { + "cluster_domain": "", + "service_ip": "" + }, + "etcd": { + "service_ip": "", + "container_port": "", + "haproxy_port": "" + }, + "masters": [ + { + "hostname": "" + } + ], + "networking": { + "type": "", + "interface_used": "", + "api_service_ip": "", + "etcd_service_ip": "", + "pod_cidr": "", + "service_cidr": "", + "apiserver_port": "", + "haproxy_port": "", + "servicenode_port_range": "" + }, + "kvps": [ + { + "key": "", + "value": "" + } + ] + }, + "undercloud_ooo": { + "host_name": "", + "local_ip": "", + "public_host": "", + "admin_host": "", + "local_interface": "", + "inspection_interface": "", + "networking": { + "ctrlplane_cidr": "", + "ctrlplane_ip_start": "", + "ctrlplane_ip_end": "", + "inspection_range": "", + "gateway": "" + } + }, + "switch_topology": [ + { + "top_id": "", + "top_name": "", + "vertices": [ + { + "vertex_id": "", + "node1_id": "", + "node1_port": "", + "node2_id": "", + "node2_port": "", + "vertex_type": "" + } + ] + } + ], + "_comment_sw1": "Software Begins", + "undercloud_sw_profiles": [ + { + "profile_name": "", + "sw_list": [ + { + "name": "", + "version": "" + } + ] + } + ], + "openstack_sw_profiles": [ + { + "profile_name": "", + "sw_list": [ + { + "name": "", + "version": "" + } + ] + } + ], + "infra_sw_profiles": [ + { + "profile_name": "", + "sw_list": [ + { + "name": "", + "version": "" + } + ] + } + ], + "software_set": [ + { + "set_name": "", + "undercloud_profile": "", + "infrasw_profile": "", + "openstack_profile": "" + } + ], + "_comment_role1": "User has to configure this - What profile to use for a role", + "_comment_role2": "Based on this server_info will be autogenerated for all servers", + "roles": [ + { + "name": "", + "hostname_prefix": "", + "hostname_suffix": "", + "hostname_number_start": "", + "count": "", + "hardware_profile": "", + "interface_mapping": "", + "storage_mapping": "", + "platform_profile": "", + "sw_set_name": "", + "metadata": [ + { + "on_count_condition": "", + "count": "", + "key": "", + "value": "" + } + ] + } + ], + "_comment_ex1": "C:City, A:Area, R:Room, N:Unique Number", + "_comment_ex2": "All are 2 characters. City-Capitals, Area-Small", + "extrapolation_info": { + "ilo_password": "CID-AID-RID-NID", + "ilo_user": "owner", + "ip_increment": "" + }, + "host_aggregates": [ + { + "aggregate_name": "", + "properties": [ + { + "key": "", + "value": "" + } + ], + "servers": [ + { + "identifier": "", + "ilo_ip": "", + "hostname": "" + } + ] + } + ], + "_comment_servers1": "This will be auto generated", + "_comment_servers2": "This describes the entire cloud.", + "servers": [ + { + "role_name": "", + "device_name": "", + "az_name": " ", + "ha_name": " ", + "rack": "", + "ilo_info": { + "ip": "", + "user": "", + "password": "" + }, + "service_info": { + "service_ip": "" + } + } + ] +}
\ No newline at end of file |