Remove Retired Karbor Support
As announced on the openstack-discuss ML[1], Karbor is retiring this cycle (Wallaby). Needed-By: https://review.opendev.org/c/openstack/karbor/+/767032 [1] http://lists.openstack.org/pipermail/openstack-discuss/2020-November/018643.html Change-Id: I222cf302e507f6a9de0347c79ec536aa7be22bb6
This commit is contained in:
parent
4b51997e7b
commit
25b9de91a2
@ -53,7 +53,6 @@ Kolla-Ansible deploys containers for the following OpenStack projects:
|
|||||||
- `Heat <https://docs.openstack.org/heat/latest/>`__
|
- `Heat <https://docs.openstack.org/heat/latest/>`__
|
||||||
- `Horizon <https://docs.openstack.org/horizon/latest/>`__
|
- `Horizon <https://docs.openstack.org/horizon/latest/>`__
|
||||||
- `Ironic <https://docs.openstack.org/ironic/latest/>`__
|
- `Ironic <https://docs.openstack.org/ironic/latest/>`__
|
||||||
- `Karbor <https://docs.openstack.org/karbor/latest/>`__
|
|
||||||
- `Keystone <https://docs.openstack.org/keystone/latest/>`__
|
- `Keystone <https://docs.openstack.org/keystone/latest/>`__
|
||||||
- `Kuryr <https://docs.openstack.org/kuryr/latest/>`__
|
- `Kuryr <https://docs.openstack.org/kuryr/latest/>`__
|
||||||
- `Magnum <https://docs.openstack.org/magnum/latest/>`__
|
- `Magnum <https://docs.openstack.org/magnum/latest/>`__
|
||||||
|
@ -340,8 +340,6 @@ iscsi_port: "3260"
|
|||||||
|
|
||||||
kafka_port: "9092"
|
kafka_port: "9092"
|
||||||
|
|
||||||
karbor_api_port: "8799"
|
|
||||||
|
|
||||||
keystone_public_port: "5000"
|
keystone_public_port: "5000"
|
||||||
keystone_public_listen_port: "{{ keystone_public_port }}"
|
keystone_public_listen_port: "{{ keystone_public_port }}"
|
||||||
keystone_admin_port: "35357"
|
keystone_admin_port: "35357"
|
||||||
@ -604,7 +602,6 @@ enable_horizon_designate: "{{ enable_designate | bool }}"
|
|||||||
enable_horizon_freezer: "{{ enable_freezer | bool }}"
|
enable_horizon_freezer: "{{ enable_freezer | bool }}"
|
||||||
enable_horizon_heat: "{{ enable_heat | bool }}"
|
enable_horizon_heat: "{{ enable_heat | bool }}"
|
||||||
enable_horizon_ironic: "{{ enable_ironic | bool }}"
|
enable_horizon_ironic: "{{ enable_ironic | bool }}"
|
||||||
enable_horizon_karbor: "{{ enable_karbor | bool }}"
|
|
||||||
enable_horizon_magnum: "{{ enable_magnum | bool }}"
|
enable_horizon_magnum: "{{ enable_magnum | bool }}"
|
||||||
enable_horizon_manila: "{{ enable_manila | bool }}"
|
enable_horizon_manila: "{{ enable_manila | bool }}"
|
||||||
enable_horizon_masakari: "{{ enable_masakari | bool }}"
|
enable_horizon_masakari: "{{ enable_masakari | bool }}"
|
||||||
@ -627,7 +624,6 @@ enable_ironic_ipxe: "no"
|
|||||||
enable_ironic_neutron_agent: "{{ enable_neutron | bool and enable_ironic | bool }}"
|
enable_ironic_neutron_agent: "{{ enable_neutron | bool and enable_ironic | bool }}"
|
||||||
enable_ironic_pxe_uefi: "no"
|
enable_ironic_pxe_uefi: "no"
|
||||||
enable_iscsid: "{{ (enable_cinder | bool and enable_cinder_backend_iscsi | bool) or enable_ironic | bool }}"
|
enable_iscsid: "{{ (enable_cinder | bool and enable_cinder_backend_iscsi | bool) or enable_ironic | bool }}"
|
||||||
enable_karbor: "no"
|
|
||||||
enable_kafka: "{{ enable_monasca | bool }}"
|
enable_kafka: "{{ enable_monasca | bool }}"
|
||||||
enable_kuryr: "no"
|
enable_kuryr: "no"
|
||||||
enable_magnum: "no"
|
enable_magnum: "no"
|
||||||
|
@ -56,9 +56,6 @@ control
|
|||||||
[kafka:children]
|
[kafka:children]
|
||||||
control
|
control
|
||||||
|
|
||||||
[karbor:children]
|
|
||||||
control
|
|
||||||
|
|
||||||
[kibana:children]
|
[kibana:children]
|
||||||
control
|
control
|
||||||
|
|
||||||
@ -353,16 +350,6 @@ ironic
|
|||||||
[tgtd:children]
|
[tgtd:children]
|
||||||
storage
|
storage
|
||||||
|
|
||||||
# Karbor
|
|
||||||
[karbor-api:children]
|
|
||||||
karbor
|
|
||||||
|
|
||||||
[karbor-protection:children]
|
|
||||||
karbor
|
|
||||||
|
|
||||||
[karbor-operationengine:children]
|
|
||||||
karbor
|
|
||||||
|
|
||||||
# Manila
|
# Manila
|
||||||
[manila-api:children]
|
[manila-api:children]
|
||||||
manila
|
manila
|
||||||
|
@ -80,9 +80,6 @@ monitoring
|
|||||||
[kafka:children]
|
[kafka:children]
|
||||||
control
|
control
|
||||||
|
|
||||||
[karbor:children]
|
|
||||||
control
|
|
||||||
|
|
||||||
[kibana:children]
|
[kibana:children]
|
||||||
control
|
control
|
||||||
|
|
||||||
@ -371,16 +368,6 @@ ironic
|
|||||||
[tgtd:children]
|
[tgtd:children]
|
||||||
storage
|
storage
|
||||||
|
|
||||||
# Karbor
|
|
||||||
[karbor-api:children]
|
|
||||||
karbor
|
|
||||||
|
|
||||||
[karbor-protection:children]
|
|
||||||
karbor
|
|
||||||
|
|
||||||
[karbor-operationengine:children]
|
|
||||||
karbor
|
|
||||||
|
|
||||||
# Manila
|
# Manila
|
||||||
[manila-api:children]
|
[manila-api:children]
|
||||||
manila
|
manila
|
||||||
|
@ -134,8 +134,6 @@ fluentd_input_openstack_services:
|
|||||||
enabled: "{{ enable_ironic | bool }}"
|
enabled: "{{ enable_ironic | bool }}"
|
||||||
- name: ironic-inspector
|
- name: ironic-inspector
|
||||||
enabled: "{{ enable_ironic | bool }}"
|
enabled: "{{ enable_ironic | bool }}"
|
||||||
- name: karbor
|
|
||||||
enabled: "{{ enable_karbor | bool }}"
|
|
||||||
- name: keystone
|
- name: keystone
|
||||||
enabled: "{{ enable_keystone | bool }}"
|
enabled: "{{ enable_keystone | bool }}"
|
||||||
- name: kuryr
|
- name: kuryr
|
||||||
|
@ -190,7 +190,6 @@
|
|||||||
- { name: "ironic-inspector", enabled: "{{ enable_ironic | bool }}" }
|
- { name: "ironic-inspector", enabled: "{{ enable_ironic | bool }}" }
|
||||||
- { name: "iscsid", enabled: "{{ enable_iscsid | bool }}" }
|
- { name: "iscsid", enabled: "{{ enable_iscsid | bool }}" }
|
||||||
- { name: "kafka", enabled: "{{ enable_kafka | bool }}" }
|
- { name: "kafka", enabled: "{{ enable_kafka | bool }}" }
|
||||||
- { name: "karbor", enabled: "{{ enable_karbor | bool }}" }
|
|
||||||
- { name: "keepalived", enabled: "{{ enable_haproxy | bool }}" }
|
- { name: "keepalived", enabled: "{{ enable_haproxy | bool }}" }
|
||||||
- { name: "keystone", enabled: "{{ enable_keystone | bool }}" }
|
- { name: "keystone", enabled: "{{ enable_keystone | bool }}" }
|
||||||
- { name: "kibana", enabled: "{{ enable_kibana | bool }}" }
|
- { name: "kibana", enabled: "{{ enable_kibana | bool }}" }
|
||||||
|
@ -1,3 +0,0 @@
|
|||||||
"/var/log/kolla/karbor/*.log"
|
|
||||||
{
|
|
||||||
}
|
|
@ -382,19 +382,6 @@
|
|||||||
- haproxy_stat.find('ironic_inspector') == -1
|
- haproxy_stat.find('ironic_inspector') == -1
|
||||||
- haproxy_vip_prechecks
|
- haproxy_vip_prechecks
|
||||||
|
|
||||||
- name: Checking free port for Karbor Admin HAProxy
|
|
||||||
wait_for:
|
|
||||||
host: "{{ kolla_internal_vip_address }}"
|
|
||||||
port: "{{ karbor_api_port }}"
|
|
||||||
connect_timeout: 1
|
|
||||||
timeout: 1
|
|
||||||
state: stopped
|
|
||||||
when:
|
|
||||||
- enable_karbor | bool
|
|
||||||
- inventory_hostname in groups['haproxy']
|
|
||||||
- haproxy_stat.find('karbor_api') == -1
|
|
||||||
- haproxy_vip_prechecks
|
|
||||||
|
|
||||||
- name: Checking free port for Keystone Admin HAProxy
|
- name: Checking free port for Keystone Admin HAProxy
|
||||||
wait_for:
|
wait_for:
|
||||||
host: "{{ kolla_internal_vip_address }}"
|
host: "{{ kolla_internal_vip_address }}"
|
||||||
|
@ -14,7 +14,6 @@ horizon_services:
|
|||||||
ENABLE_FREEZER: "{{ 'yes' if enable_horizon_freezer | bool else 'no' }}"
|
ENABLE_FREEZER: "{{ 'yes' if enable_horizon_freezer | bool else 'no' }}"
|
||||||
ENABLE_HEAT: "{{ 'yes' if enable_horizon_heat | bool else 'no' }}"
|
ENABLE_HEAT: "{{ 'yes' if enable_horizon_heat | bool else 'no' }}"
|
||||||
ENABLE_IRONIC: "{{ 'yes' if enable_horizon_ironic | bool else 'no' }}"
|
ENABLE_IRONIC: "{{ 'yes' if enable_horizon_ironic | bool else 'no' }}"
|
||||||
ENABLE_KARBOR: "{{ 'yes' if enable_horizon_karbor | bool else 'no' }}"
|
|
||||||
ENABLE_MAGNUM: "{{ 'yes' if enable_horizon_magnum | bool else 'no' }}"
|
ENABLE_MAGNUM: "{{ 'yes' if enable_horizon_magnum | bool else 'no' }}"
|
||||||
ENABLE_MANILA: "{{ 'yes' if enable_horizon_manila | bool else 'no' }}"
|
ENABLE_MANILA: "{{ 'yes' if enable_horizon_manila | bool else 'no' }}"
|
||||||
ENABLE_MASAKARI: "{{ 'yes' if enable_horizon_masakari | bool else 'no' }}"
|
ENABLE_MASAKARI: "{{ 'yes' if enable_horizon_masakari | bool else 'no' }}"
|
||||||
|
@ -30,7 +30,6 @@
|
|||||||
- { name: "heat", enabled: "{{ enable_heat_horizon_policy_file }}" }
|
- { name: "heat", enabled: "{{ enable_heat_horizon_policy_file }}" }
|
||||||
- { name: "ironic", enabled: "{{ enable_horizon_ironic }}" }
|
- { name: "ironic", enabled: "{{ enable_horizon_ironic }}" }
|
||||||
- { name: "keystone", enabled: "{{ enable_keystone_horizon_policy_file }}" }
|
- { name: "keystone", enabled: "{{ enable_keystone_horizon_policy_file }}" }
|
||||||
- { name: "karbor", enabled: "{{ enable_horizon_karbor }}" }
|
|
||||||
- { name: "magnum", enabled: "{{ enable_horizon_magnum }}" }
|
- { name: "magnum", enabled: "{{ enable_horizon_magnum }}" }
|
||||||
- { name: "manila", enabled: "{{ enable_horizon_manila }}" }
|
- { name: "manila", enabled: "{{ enable_horizon_manila }}" }
|
||||||
- { name: "masakari", enabled: "{{ enable_horizon_masakari }}" }
|
- { name: "masakari", enabled: "{{ enable_horizon_masakari }}" }
|
||||||
|
@ -1,129 +0,0 @@
|
|||||||
---
|
|
||||||
project_name: "karbor"
|
|
||||||
|
|
||||||
karbor_services:
|
|
||||||
karbor-api:
|
|
||||||
container_name: karbor_api
|
|
||||||
group: karbor-api
|
|
||||||
enabled: true
|
|
||||||
image: "{{ karbor_api_image_full }}"
|
|
||||||
volumes: "{{ karbor_api_default_volumes + karbor_api_extra_volumes }}"
|
|
||||||
dimensions: "{{ karbor_api_dimensions }}"
|
|
||||||
haproxy:
|
|
||||||
karbor_api:
|
|
||||||
enabled: "{{ enable_karbor }}"
|
|
||||||
mode: "http"
|
|
||||||
external: false
|
|
||||||
port: "{{ karbor_api_port }}"
|
|
||||||
karbor_api_external:
|
|
||||||
enabled: "{{ enable_karbor }}"
|
|
||||||
mode: "http"
|
|
||||||
external: true
|
|
||||||
port: "{{ karbor_api_port }}"
|
|
||||||
karbor-protection:
|
|
||||||
container_name: karbor_protection
|
|
||||||
group: karbor-protection
|
|
||||||
enabled: true
|
|
||||||
image: "{{ karbor_protection_image_full }}"
|
|
||||||
volumes: "{{ karbor_protection_default_volumes + karbor_protection_extra_volumes }}"
|
|
||||||
dimensions: "{{ karbor_protection_dimensions }}"
|
|
||||||
karbor-operationengine:
|
|
||||||
container_name: karbor_operationengine
|
|
||||||
group: karbor-operationengine
|
|
||||||
enabled: true
|
|
||||||
image: "{{ karbor_operationengine_image_full }}"
|
|
||||||
volumes: "{{ karbor_operationengine_default_volumes + karbor_operationengine_extra_volumes }}"
|
|
||||||
dimensions: "{{ karbor_operationengine_dimensions }}"
|
|
||||||
|
|
||||||
|
|
||||||
####################
|
|
||||||
# Database
|
|
||||||
####################
|
|
||||||
karbor_database_name: "karbor"
|
|
||||||
karbor_database_user: "{% if use_preconfigured_databases | bool and use_common_mariadb_user | bool %}{{ database_user }}{% else %}karbor{% endif %}"
|
|
||||||
karbor_database_address: "{{ database_address | put_address_in_context('url') }}:{{ database_port }}"
|
|
||||||
|
|
||||||
|
|
||||||
####################
|
|
||||||
# Docker
|
|
||||||
####################
|
|
||||||
karbor_install_type: "{{ kolla_install_type }}"
|
|
||||||
karbor_tag: "{{ openstack_tag }}"
|
|
||||||
|
|
||||||
karbor_protection_image: "{{ docker_registry ~ '/' if docker_registry else '' }}{{ docker_namespace }}/{{ kolla_base_distro }}-{{ karbor_install_type }}-karbor-protection"
|
|
||||||
karbor_protection_tag: "{{ karbor_tag }}"
|
|
||||||
karbor_protection_image_full: "{{ karbor_protection_image }}:{{ karbor_protection_tag }}"
|
|
||||||
|
|
||||||
|
|
||||||
karbor_operationengine_image: "{{ docker_registry ~ '/' if docker_registry else '' }}{{ docker_namespace }}/{{ kolla_base_distro }}-{{ karbor_install_type }}-karbor-operationengine"
|
|
||||||
karbor_operationengine_tag: "{{ karbor_tag }}"
|
|
||||||
karbor_operationengine_image_full: "{{ karbor_operationengine_image }}:{{ karbor_operationengine_tag }}"
|
|
||||||
|
|
||||||
karbor_api_image: "{{ docker_registry ~ '/' if docker_registry else '' }}{{ docker_namespace }}/{{ kolla_base_distro }}-{{ karbor_install_type }}-karbor-api"
|
|
||||||
karbor_api_tag: "{{ karbor_tag }}"
|
|
||||||
karbor_api_image_full: "{{ karbor_api_image }}:{{ karbor_api_tag }}"
|
|
||||||
|
|
||||||
karbor_api_dimensions: "{{ default_container_dimensions }}"
|
|
||||||
karbor_protection_dimensions: "{{ default_container_dimensions }}"
|
|
||||||
karbor_operationengine_dimensions: "{{ default_container_dimensions }}"
|
|
||||||
|
|
||||||
karbor_protection_default_volumes:
|
|
||||||
- "{{ node_config_directory }}/karbor-protection/:{{ container_config_directory }}/:ro"
|
|
||||||
- "/etc/localtime:/etc/localtime:ro"
|
|
||||||
- "{{ '/etc/timezone:/etc/timezone:ro' if ansible_os_family == 'Debian' else '' }}"
|
|
||||||
- "kolla_logs:/var/log/kolla/"
|
|
||||||
karbor_operationengine_default_volumes:
|
|
||||||
- "{{ node_config_directory }}/karbor-operationengine/:{{ container_config_directory }}/:ro"
|
|
||||||
- "/etc/localtime:/etc/localtime:ro"
|
|
||||||
- "{{ '/etc/timezone:/etc/timezone:ro' if ansible_os_family == 'Debian' else '' }}"
|
|
||||||
- "kolla_logs:/var/log/kolla/"
|
|
||||||
karbor_api_default_volumes:
|
|
||||||
- "{{ node_config_directory }}/karbor-api/:{{ container_config_directory }}/:ro"
|
|
||||||
- "/etc/localtime:/etc/localtime:ro"
|
|
||||||
- "{{ '/etc/timezone:/etc/timezone:ro' if ansible_os_family == 'Debian' else '' }}"
|
|
||||||
- "kolla_logs:/var/log/kolla/"
|
|
||||||
karbor_extra_volumes: "{{ default_extra_volumes }}"
|
|
||||||
karbor_protection_extra_volumes: "{{ karbor_extra_volumes }}"
|
|
||||||
karbor_operationengine_extra_volumes: "{{ karbor_extra_volumes }}"
|
|
||||||
karbor_api_extra_volumes: "{{ karbor_extra_volumes }}"
|
|
||||||
|
|
||||||
####################
|
|
||||||
# OpenStack
|
|
||||||
####################
|
|
||||||
karbor_admin_endpoint: "{{ admin_protocol }}://{{ kolla_internal_fqdn | put_address_in_context('url') }}:{{ karbor_api_port }}/v1/%(project_id)s"
|
|
||||||
karbor_internal_endpoint: "{{ internal_protocol }}://{{ kolla_internal_fqdn | put_address_in_context('url') }}:{{ karbor_api_port }}/v1/%(project_id)s"
|
|
||||||
karbor_public_endpoint: "{{ public_protocol }}://{{ kolla_external_fqdn | put_address_in_context('url') }}:{{ karbor_api_port }}/v1/%(project_id)s"
|
|
||||||
|
|
||||||
karbor_logging_debug: "{{ openstack_logging_debug }}"
|
|
||||||
|
|
||||||
karbor_keystone_user: "karbor"
|
|
||||||
|
|
||||||
openstack_karbor_auth: "{{ openstack_auth }}"
|
|
||||||
|
|
||||||
|
|
||||||
####################
|
|
||||||
# Notification
|
|
||||||
####################
|
|
||||||
karbor_notification_topics:
|
|
||||||
- name: notifications
|
|
||||||
enabled: "{{ enable_ceilometer | bool }}"
|
|
||||||
|
|
||||||
karbor_enabled_notification_topics: "{{ karbor_notification_topics | selectattr('enabled', 'equalto', true) | list }}"
|
|
||||||
|
|
||||||
####################
|
|
||||||
# Keystone
|
|
||||||
####################
|
|
||||||
karbor_ks_services:
|
|
||||||
- name: "karbor"
|
|
||||||
type: "data-protect"
|
|
||||||
description: "Application Data Protection Service"
|
|
||||||
endpoints:
|
|
||||||
- {'interface': 'admin', 'url': '{{ karbor_admin_endpoint }}'}
|
|
||||||
- {'interface': 'internal', 'url': '{{ karbor_internal_endpoint }}'}
|
|
||||||
- {'interface': 'public', 'url': '{{ karbor_public_endpoint }}'}
|
|
||||||
|
|
||||||
karbor_ks_users:
|
|
||||||
- project: "service"
|
|
||||||
user: "{{ karbor_keystone_user }}"
|
|
||||||
password: "{{ karbor_keystone_password }}"
|
|
||||||
role: "admin"
|
|
@ -1,45 +0,0 @@
|
|||||||
---
|
|
||||||
- name: Restart karbor-api container
|
|
||||||
vars:
|
|
||||||
service_name: "karbor-api"
|
|
||||||
service: "{{ karbor_services[service_name] }}"
|
|
||||||
become: true
|
|
||||||
kolla_docker:
|
|
||||||
action: "recreate_or_restart_container"
|
|
||||||
common_options: "{{ docker_common_options }}"
|
|
||||||
name: "{{ service.container_name }}"
|
|
||||||
image: "{{ service.image }}"
|
|
||||||
volumes: "{{ service.volumes }}"
|
|
||||||
dimensions: "{{ service.dimensions }}"
|
|
||||||
when:
|
|
||||||
- kolla_action != "config"
|
|
||||||
|
|
||||||
- name: Restart karbor-protection container
|
|
||||||
vars:
|
|
||||||
service_name: "karbor-protection"
|
|
||||||
service: "{{ karbor_services[service_name] }}"
|
|
||||||
become: true
|
|
||||||
kolla_docker:
|
|
||||||
action: "recreate_or_restart_container"
|
|
||||||
common_options: "{{ docker_common_options }}"
|
|
||||||
name: "{{ service.container_name }}"
|
|
||||||
image: "{{ service.image }}"
|
|
||||||
volumes: "{{ service.volumes }}"
|
|
||||||
dimensions: "{{ service.dimensions }}"
|
|
||||||
when:
|
|
||||||
- kolla_action != "config"
|
|
||||||
|
|
||||||
- name: Restart karbor-operationengine container
|
|
||||||
vars:
|
|
||||||
service_name: "karbor-operationengine"
|
|
||||||
service: "{{ karbor_services[service_name] }}"
|
|
||||||
become: true
|
|
||||||
kolla_docker:
|
|
||||||
action: "recreate_or_restart_container"
|
|
||||||
common_options: "{{ docker_common_options }}"
|
|
||||||
name: "{{ service.container_name }}"
|
|
||||||
image: "{{ service.image }}"
|
|
||||||
volumes: "{{ service.volumes }}"
|
|
||||||
dimensions: "{{ service.dimensions }}"
|
|
||||||
when:
|
|
||||||
- kolla_action != "config"
|
|
@ -1,36 +0,0 @@
|
|||||||
---
|
|
||||||
- name: Creating Karbor database
|
|
||||||
become: true
|
|
||||||
kolla_toolbox:
|
|
||||||
module_name: mysql_db
|
|
||||||
module_args:
|
|
||||||
login_host: "{{ database_address }}"
|
|
||||||
login_port: "{{ database_port }}"
|
|
||||||
login_user: "{{ database_user }}"
|
|
||||||
login_password: "{{ database_password }}"
|
|
||||||
name: "{{ karbor_database_name }}"
|
|
||||||
run_once: True
|
|
||||||
delegate_to: "{{ groups['karbor-api'][0] }}"
|
|
||||||
when:
|
|
||||||
- not use_preconfigured_databases | bool
|
|
||||||
|
|
||||||
- name: Creating Karbor database user and setting permissions
|
|
||||||
become: true
|
|
||||||
kolla_toolbox:
|
|
||||||
module_name: mysql_user
|
|
||||||
module_args:
|
|
||||||
login_host: "{{ database_address }}"
|
|
||||||
login_port: "{{ database_port }}"
|
|
||||||
login_user: "{{ database_user }}"
|
|
||||||
login_password: "{{ database_password }}"
|
|
||||||
name: "{{ karbor_database_user }}"
|
|
||||||
password: "{{ karbor_database_password }}"
|
|
||||||
host: "%"
|
|
||||||
priv: "{{ karbor_database_name }}.*:ALL"
|
|
||||||
append_privs: "yes"
|
|
||||||
run_once: True
|
|
||||||
delegate_to: "{{ groups['karbor-api'][0] }}"
|
|
||||||
when:
|
|
||||||
- not use_preconfigured_databases | bool
|
|
||||||
|
|
||||||
- import_tasks: bootstrap_service.yml
|
|
@ -1,20 +0,0 @@
|
|||||||
---
|
|
||||||
- name: Running Karbor bootstrap container
|
|
||||||
vars:
|
|
||||||
karbor_api: "{{ karbor_services['karbor-api'] }}"
|
|
||||||
become: true
|
|
||||||
kolla_docker:
|
|
||||||
action: "start_container"
|
|
||||||
common_options: "{{ docker_common_options }}"
|
|
||||||
detach: False
|
|
||||||
environment:
|
|
||||||
KOLLA_BOOTSTRAP:
|
|
||||||
KOLLA_CONFIG_STRATEGY: "{{ config_strategy }}"
|
|
||||||
image: "{{ karbor_api.image }}"
|
|
||||||
labels:
|
|
||||||
BOOTSTRAP:
|
|
||||||
name: "bootstrap_karbor"
|
|
||||||
restart_policy: no
|
|
||||||
volumes: "{{ karbor_api.volumes }}"
|
|
||||||
run_once: True
|
|
||||||
delegate_to: "{{ groups[karbor_api.group][0] }}"
|
|
@ -1,16 +0,0 @@
|
|||||||
---
|
|
||||||
- name: Check karbor containers
|
|
||||||
become: true
|
|
||||||
kolla_docker:
|
|
||||||
action: "compare_container"
|
|
||||||
common_options: "{{ docker_common_options }}"
|
|
||||||
name: "{{ item.value.container_name }}"
|
|
||||||
image: "{{ item.value.image }}"
|
|
||||||
volumes: "{{ item.value.volumes }}"
|
|
||||||
dimensions: "{{ item.value.dimensions }}"
|
|
||||||
when:
|
|
||||||
- inventory_hostname in groups[item.value.group]
|
|
||||||
- item.value.enabled | bool
|
|
||||||
with_dict: "{{ karbor_services }}"
|
|
||||||
notify:
|
|
||||||
- "Restart {{ item.key }} container"
|
|
@ -1 +0,0 @@
|
|||||||
---
|
|
@ -1,84 +0,0 @@
|
|||||||
---
|
|
||||||
- name: Ensuring config directories exist
|
|
||||||
file:
|
|
||||||
path: "{{ node_config_directory }}/{{ item.key }}/providers.d"
|
|
||||||
state: "directory"
|
|
||||||
owner: "{{ config_owner_user }}"
|
|
||||||
group: "{{ config_owner_group }}"
|
|
||||||
mode: "0770"
|
|
||||||
become: true
|
|
||||||
when:
|
|
||||||
- inventory_hostname in groups[item.value.group]
|
|
||||||
- item.value.enabled | bool
|
|
||||||
with_dict: "{{ karbor_services }}"
|
|
||||||
|
|
||||||
- include_tasks: copy-certs.yml
|
|
||||||
when:
|
|
||||||
- kolla_copy_ca_into_containers | bool
|
|
||||||
|
|
||||||
- name: Copying over config.json files for services
|
|
||||||
template:
|
|
||||||
src: "{{ item.key }}.json.j2"
|
|
||||||
dest: "{{ node_config_directory }}/{{ item.key }}/config.json"
|
|
||||||
mode: "0660"
|
|
||||||
become: true
|
|
||||||
when:
|
|
||||||
- inventory_hostname in groups[item.value.group]
|
|
||||||
- item.value.enabled | bool
|
|
||||||
with_dict: "{{ karbor_services }}"
|
|
||||||
notify:
|
|
||||||
- Restart {{ item.key }} container
|
|
||||||
|
|
||||||
- name: Copying over karbor.conf
|
|
||||||
vars:
|
|
||||||
service_name: "{{ item.key }}"
|
|
||||||
merge_configs:
|
|
||||||
sources:
|
|
||||||
- "{{ role_path }}/templates/karbor.conf.j2"
|
|
||||||
- "{{ node_custom_config }}/global.conf"
|
|
||||||
- "{{ node_custom_config }}/karbor.conf"
|
|
||||||
- "{{ node_custom_config }}/karbor/{{ item.key }}.conf"
|
|
||||||
- "{{ node_custom_config }}/karbor/{{ inventory_hostname }}/karbor.conf"
|
|
||||||
dest: "{{ node_config_directory }}/{{ item.key }}/karbor.conf"
|
|
||||||
mode: "0660"
|
|
||||||
become: true
|
|
||||||
when:
|
|
||||||
- inventory_hostname in groups[item.value.group]
|
|
||||||
- item.value.enabled | bool
|
|
||||||
with_dict: "{{ karbor_services }}"
|
|
||||||
notify:
|
|
||||||
- Restart {{ item.key }} container
|
|
||||||
|
|
||||||
- name: Copying over provider configs
|
|
||||||
vars:
|
|
||||||
service_name: 'karbor-protection'
|
|
||||||
service: "{{ karbor_services[service_name] }}"
|
|
||||||
copy:
|
|
||||||
src: "{{ item }}"
|
|
||||||
dest: "{{ node_config_directory }}/{{ service_name }}/providers.d/"
|
|
||||||
mode: "0660"
|
|
||||||
become: true
|
|
||||||
with_fileglob:
|
|
||||||
- "{{ node_custom_config }}/karbor/{{ service_name }}/providers.d/*"
|
|
||||||
when:
|
|
||||||
- inventory_hostname in groups[service.group]
|
|
||||||
- service.enabled | bool
|
|
||||||
notify:
|
|
||||||
- Restart karbor-protection container
|
|
||||||
|
|
||||||
- name: Copying over openstack-infra.conf
|
|
||||||
vars:
|
|
||||||
service_name: 'karbor-protection'
|
|
||||||
service: "{{ karbor_services[service_name] }}"
|
|
||||||
merge_configs:
|
|
||||||
sources:
|
|
||||||
- "{{ role_path }}/templates/providers.d/openstack-infra.conf.j2"
|
|
||||||
- "{{ node_custom_config }}/karbor/{{ service_name }}/providers.d/openstack-infra.conf"
|
|
||||||
dest: "{{ node_config_directory }}/{{ service_name }}/providers.d/openstack-infra.conf"
|
|
||||||
mode: "0660"
|
|
||||||
become: true
|
|
||||||
when:
|
|
||||||
- inventory_hostname in groups[service.group]
|
|
||||||
- service.enabled | bool
|
|
||||||
notify:
|
|
||||||
- Restart karbor-protection container
|
|
@ -1,6 +0,0 @@
|
|||||||
---
|
|
||||||
- name: "Copy certificates and keys for {{ project_name }}"
|
|
||||||
import_role:
|
|
||||||
role: service-cert-copy
|
|
||||||
vars:
|
|
||||||
project_services: "{{ karbor_services }}"
|
|
@ -1,2 +0,0 @@
|
|||||||
---
|
|
||||||
- import_tasks: check-containers.yml
|
|
@ -1,11 +0,0 @@
|
|||||||
---
|
|
||||||
- import_tasks: register.yml
|
|
||||||
|
|
||||||
- import_tasks: config.yml
|
|
||||||
|
|
||||||
- import_tasks: check-containers.yml
|
|
||||||
|
|
||||||
- import_tasks: bootstrap.yml
|
|
||||||
|
|
||||||
- name: Flush handlers
|
|
||||||
meta: flush_handlers
|
|
@ -1,7 +0,0 @@
|
|||||||
---
|
|
||||||
- name: "Configure haproxy for {{ project_name }}"
|
|
||||||
import_role:
|
|
||||||
name: haproxy-config
|
|
||||||
vars:
|
|
||||||
project_services: "{{ karbor_services }}"
|
|
||||||
tags: always
|
|
@ -1,2 +0,0 @@
|
|||||||
---
|
|
||||||
- include_tasks: "{{ kolla_action }}.yml"
|
|
@ -1,24 +0,0 @@
|
|||||||
---
|
|
||||||
- import_role:
|
|
||||||
name: service-precheck
|
|
||||||
vars:
|
|
||||||
service_precheck_services: "{{ karbor_services }}"
|
|
||||||
service_name: "{{ project_name }}"
|
|
||||||
|
|
||||||
- name: Get container facts
|
|
||||||
become: true
|
|
||||||
kolla_container_facts:
|
|
||||||
name:
|
|
||||||
- karbor_api
|
|
||||||
register: container_facts
|
|
||||||
|
|
||||||
- name: Checking free port for Karbor Admin
|
|
||||||
wait_for:
|
|
||||||
host: "{{ api_interface_address }}"
|
|
||||||
port: "{{ karbor_api_port }}"
|
|
||||||
connect_timeout: 1
|
|
||||||
timeout: 1
|
|
||||||
state: stopped
|
|
||||||
when:
|
|
||||||
- inventory_hostname in groups['karbor-api']
|
|
||||||
- container_facts['karbor-api'] is not defined
|
|
@ -1,11 +0,0 @@
|
|||||||
---
|
|
||||||
- name: Pulling karbor images
|
|
||||||
become: true
|
|
||||||
kolla_docker:
|
|
||||||
action: "pull_image"
|
|
||||||
common_options: "{{ docker_common_options }}"
|
|
||||||
image: "{{ item.value.image }}"
|
|
||||||
when:
|
|
||||||
- inventory_hostname in groups[item.value.group]
|
|
||||||
- item.value.enabled | bool
|
|
||||||
with_dict: "{{ karbor_services }}"
|
|
@ -1,2 +0,0 @@
|
|||||||
---
|
|
||||||
- import_tasks: deploy.yml
|
|
@ -1,7 +0,0 @@
|
|||||||
---
|
|
||||||
- import_role:
|
|
||||||
name: service-ks-register
|
|
||||||
vars:
|
|
||||||
service_ks_register_auth: "{{ openstack_karbor_auth }}"
|
|
||||||
service_ks_register_services: "{{ karbor_ks_services }}"
|
|
||||||
service_ks_register_users: "{{ karbor_ks_users }}"
|
|
@ -1,6 +0,0 @@
|
|||||||
---
|
|
||||||
- import_role:
|
|
||||||
name: service-stop
|
|
||||||
vars:
|
|
||||||
project_services: "{{ karbor_services }}"
|
|
||||||
service_name: "{{ project_name }}"
|
|
@ -1,9 +0,0 @@
|
|||||||
---
|
|
||||||
- import_tasks: config.yml
|
|
||||||
|
|
||||||
- import_tasks: check-containers.yml
|
|
||||||
|
|
||||||
- import_tasks: bootstrap_service.yml
|
|
||||||
|
|
||||||
- name: Flush handlers
|
|
||||||
meta: flush_handlers
|
|
@ -1,18 +0,0 @@
|
|||||||
{
|
|
||||||
"command": "karbor-api --config-file /etc/karbor/karbor.conf",
|
|
||||||
"config_files": [
|
|
||||||
{
|
|
||||||
"source": "{{ container_config_directory }}/karbor.conf",
|
|
||||||
"dest": "/etc/karbor/karbor.conf",
|
|
||||||
"owner": "karbor",
|
|
||||||
"perm": "0600"
|
|
||||||
}
|
|
||||||
],
|
|
||||||
"permissions": [
|
|
||||||
{
|
|
||||||
"path": "/var/log/kolla/karbor",
|
|
||||||
"owner": "karbor:karbor",
|
|
||||||
"recurse": true
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
@ -1,18 +0,0 @@
|
|||||||
{
|
|
||||||
"command": "karbor-operationengine --config-file /etc/karbor/karbor.conf",
|
|
||||||
"config_files": [
|
|
||||||
{
|
|
||||||
"source": "{{ container_config_directory }}/karbor.conf",
|
|
||||||
"dest": "/etc/karbor/karbor.conf",
|
|
||||||
"owner": "karbor",
|
|
||||||
"perm": "0600"
|
|
||||||
}
|
|
||||||
],
|
|
||||||
"permissions": [
|
|
||||||
{
|
|
||||||
"path": "/var/log/kolla/karbor",
|
|
||||||
"owner": "karbor:karbor",
|
|
||||||
"recurse": true
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
@ -1,24 +0,0 @@
|
|||||||
{
|
|
||||||
"command": "karbor-protection --config-file /etc/karbor/karbor.conf",
|
|
||||||
"config_files": [
|
|
||||||
{
|
|
||||||
"source": "{{ container_config_directory }}/karbor.conf",
|
|
||||||
"dest": "/etc/karbor/karbor.conf",
|
|
||||||
"owner": "karbor",
|
|
||||||
"perm": "0600"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"source": "{{ container_config_directory }}/providers.d/*",
|
|
||||||
"dest": "/etc/karbor/providers.d/",
|
|
||||||
"owner": "karbor",
|
|
||||||
"perm": "0600"
|
|
||||||
}
|
|
||||||
],
|
|
||||||
"permissions": [
|
|
||||||
{
|
|
||||||
"path": "/var/log/kolla/karbor",
|
|
||||||
"owner": "karbor:karbor",
|
|
||||||
"recurse": true
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
@ -1,67 +0,0 @@
|
|||||||
[DEFAULT]
|
|
||||||
debug = {{ karbor_logging_debug }}
|
|
||||||
log_dir = /var/log/kolla/karbor
|
|
||||||
transport_url = {{ rpc_transport_url }}
|
|
||||||
|
|
||||||
{% if service_name == 'karbor-api' %}
|
|
||||||
osapi_karbor_listen = {{ api_interface_address }}
|
|
||||||
osapi_karbor_listen_port = {{ karbor_api_port }}
|
|
||||||
osapi_karbor_workers = {{ openstack_service_workers }}
|
|
||||||
{% endif %}
|
|
||||||
|
|
||||||
[database]
|
|
||||||
connection = mysql+pymysql://{{ karbor_database_user }}:{{ karbor_database_password }}@{{ karbor_database_address }}/{{ karbor_database_name }}
|
|
||||||
connection_recycle_time = {{ database_connection_recycle_time }}
|
|
||||||
max_pool_size = {{ database_max_pool_size }}
|
|
||||||
max_retries = -1
|
|
||||||
|
|
||||||
[trustee]
|
|
||||||
user_domain_id = {{ default_user_domain_id }}
|
|
||||||
username = {{ karbor_keystone_user }}
|
|
||||||
password = {{ karbor_keystone_password }}
|
|
||||||
auth_url = {{ keystone_admin_url }}
|
|
||||||
auth_type = password
|
|
||||||
cafile = {{ openstack_cacert }}
|
|
||||||
|
|
||||||
[clients_keystone]
|
|
||||||
auth_uri = {{ keystone_internal_url }}
|
|
||||||
|
|
||||||
[karbor_client]
|
|
||||||
version = 1
|
|
||||||
service_type = data-protect
|
|
||||||
service_name = karbor
|
|
||||||
region_id = {{ openstack_region_name }}
|
|
||||||
|
|
||||||
[keystone_authtoken]
|
|
||||||
www_authenticate_uri = {{ keystone_internal_url }}
|
|
||||||
auth_url = {{ keystone_admin_url }}
|
|
||||||
project_domain_name = {{ default_project_domain_name }}
|
|
||||||
auth_type = password
|
|
||||||
project_domain_id = {{ default_project_domain_id }}
|
|
||||||
user_domain_id = {{ default_user_domain_id }}
|
|
||||||
project_name = service
|
|
||||||
username = {{ karbor_keystone_user }}
|
|
||||||
password = {{ karbor_keystone_password }}
|
|
||||||
cafile = {{ openstack_cacert }}
|
|
||||||
|
|
||||||
memcache_security_strategy = ENCRYPT
|
|
||||||
memcache_secret_key = {{ memcache_secret_key }}
|
|
||||||
memcached_servers = {% for host in groups['memcached'] %}{{ 'api' | kolla_address(host) | put_address_in_context('memcache') }}:{{ memcached_port }}{% if not loop.last %},{% endif %}{% endfor %}
|
|
||||||
|
|
||||||
[oslo_messaging_notifications]
|
|
||||||
transport_url = {{ notify_transport_url }}
|
|
||||||
{% if karbor_enabled_notification_topics %}
|
|
||||||
driver = messagingv2
|
|
||||||
topics = {{ karbor_enabled_notification_topics | map(attribute='name') | join(',') }}
|
|
||||||
{% else %}
|
|
||||||
driver = noop
|
|
||||||
{% endif %}
|
|
||||||
|
|
||||||
{% if om_enable_rabbitmq_tls | bool %}
|
|
||||||
[oslo_messaging_rabbit]
|
|
||||||
ssl = true
|
|
||||||
ssl_ca_file = {{ om_rabbitmq_cacert }}
|
|
||||||
{% endif %}
|
|
||||||
|
|
||||||
[oslo_middleware]
|
|
||||||
enable_proxy_headers_parsing = True
|
|
@ -1,24 +0,0 @@
|
|||||||
[provider]
|
|
||||||
name = OS Infra Provider
|
|
||||||
description = This provider uses OpenStack's own services (swift, cinder) as storage
|
|
||||||
id = {{ karbor_openstack_infra_id }}
|
|
||||||
|
|
||||||
plugin=karbor-volume-protection-plugin
|
|
||||||
plugin=karbor-image-protection-plugin
|
|
||||||
plugin=karbor-server-protection-plugin
|
|
||||||
bank=karbor-swift-bank-plugin
|
|
||||||
|
|
||||||
[swift_client]
|
|
||||||
swift_auth_url={{ keystone_internal_url }}/v3
|
|
||||||
swift_auth_version=3
|
|
||||||
swift_user=admin
|
|
||||||
swift_key={{ keystone_admin_password }}
|
|
||||||
swift_tenant_name=admin
|
|
||||||
swift_project_domain_id = {{ default_project_domain_id }}
|
|
||||||
swift_user_domain_id = {{ default_user_domain_id }}
|
|
||||||
|
|
||||||
|
|
||||||
[swift_bank_plugin]
|
|
||||||
lease_expire_window=120
|
|
||||||
lease_renew_window=100
|
|
||||||
lease_validity_window=100
|
|
@ -39,7 +39,6 @@
|
|||||||
- enable_ironic_{{ enable_ironic | bool }}
|
- enable_ironic_{{ enable_ironic | bool }}
|
||||||
- enable_iscsid_{{ enable_iscsid | bool }}
|
- enable_iscsid_{{ enable_iscsid | bool }}
|
||||||
- enable_kafka_{{ enable_kafka | bool }}
|
- enable_kafka_{{ enable_kafka | bool }}
|
||||||
- enable_karbor_{{ enable_karbor | bool }}
|
|
||||||
- enable_keystone_{{ enable_keystone | bool }}
|
- enable_keystone_{{ enable_keystone | bool }}
|
||||||
- enable_kibana_{{ enable_kibana | bool }}
|
- enable_kibana_{{ enable_kibana | bool }}
|
||||||
- enable_kuryr_{{ enable_kuryr | bool }}
|
- enable_kuryr_{{ enable_kuryr | bool }}
|
||||||
@ -207,11 +206,6 @@
|
|||||||
tasks_from: loadbalancer
|
tasks_from: loadbalancer
|
||||||
tags: ironic
|
tags: ironic
|
||||||
when: enable_ironic | bool
|
when: enable_ironic | bool
|
||||||
- include_role:
|
|
||||||
name: karbor
|
|
||||||
tasks_from: loadbalancer
|
|
||||||
tags: karbor
|
|
||||||
when: enable_karbor | bool
|
|
||||||
- include_role:
|
- include_role:
|
||||||
name: keystone
|
name: keystone
|
||||||
tasks_from: loadbalancer
|
tasks_from: loadbalancer
|
||||||
@ -598,19 +592,6 @@
|
|||||||
tags: storm,
|
tags: storm,
|
||||||
when: enable_storm | bool }
|
when: enable_storm | bool }
|
||||||
|
|
||||||
- name: Apply role karbor
|
|
||||||
gather_facts: false
|
|
||||||
hosts:
|
|
||||||
- karbor-api
|
|
||||||
- karbor-protection
|
|
||||||
- karbor-operationengine
|
|
||||||
- '&enable_karbor_True'
|
|
||||||
serial: '{{ kolla_serial|default("0") }}'
|
|
||||||
roles:
|
|
||||||
- { role: karbor,
|
|
||||||
tags: karbor,
|
|
||||||
when: enable_karbor | bool }
|
|
||||||
|
|
||||||
- name: Apply role swift
|
- name: Apply role swift
|
||||||
gather_facts: false
|
gather_facts: false
|
||||||
hosts:
|
hosts:
|
||||||
|
@ -303,7 +303,6 @@
|
|||||||
#enable_horizon_freezer: "{{ enable_freezer | bool }}"
|
#enable_horizon_freezer: "{{ enable_freezer | bool }}"
|
||||||
#enable_horizon_heat: "{{ enable_heat | bool }}"
|
#enable_horizon_heat: "{{ enable_heat | bool }}"
|
||||||
#enable_horizon_ironic: "{{ enable_ironic | bool }}"
|
#enable_horizon_ironic: "{{ enable_ironic | bool }}"
|
||||||
#enable_horizon_karbor: "{{ enable_karbor | bool }}"
|
|
||||||
#enable_horizon_magnum: "{{ enable_magnum | bool }}"
|
#enable_horizon_magnum: "{{ enable_magnum | bool }}"
|
||||||
#enable_horizon_manila: "{{ enable_manila | bool }}"
|
#enable_horizon_manila: "{{ enable_manila | bool }}"
|
||||||
#enable_horizon_masakari: "{{ enable_masakari | bool }}"
|
#enable_horizon_masakari: "{{ enable_masakari | bool }}"
|
||||||
@ -326,7 +325,6 @@
|
|||||||
#enable_ironic_neutron_agent: "{{ enable_neutron | bool and enable_ironic | bool }}"
|
#enable_ironic_neutron_agent: "{{ enable_neutron | bool and enable_ironic | bool }}"
|
||||||
#enable_ironic_pxe_uefi: "no"
|
#enable_ironic_pxe_uefi: "no"
|
||||||
#enable_iscsid: "{{ (enable_cinder | bool and enable_cinder_backend_iscsi | bool) or enable_ironic | bool }}"
|
#enable_iscsid: "{{ (enable_cinder | bool and enable_cinder_backend_iscsi | bool) or enable_ironic | bool }}"
|
||||||
#enable_karbor: "no"
|
|
||||||
#enable_kafka: "{{ enable_monasca | bool }}"
|
#enable_kafka: "{{ enable_monasca | bool }}"
|
||||||
#enable_kibana: "{{ 'yes' if enable_central_logging | bool or enable_monasca | bool else 'no' }}"
|
#enable_kibana: "{{ 'yes' if enable_central_logging | bool or enable_monasca | bool else 'no' }}"
|
||||||
#enable_kuryr: "no"
|
#enable_kuryr: "no"
|
||||||
|
@ -71,10 +71,6 @@ glance_keystone_password:
|
|||||||
gnocchi_database_password:
|
gnocchi_database_password:
|
||||||
gnocchi_keystone_password:
|
gnocchi_keystone_password:
|
||||||
|
|
||||||
karbor_database_password:
|
|
||||||
karbor_keystone_password:
|
|
||||||
karbor_openstack_infra_id:
|
|
||||||
|
|
||||||
kuryr_keystone_password:
|
kuryr_keystone_password:
|
||||||
|
|
||||||
nova_database_password:
|
nova_database_password:
|
||||||
|
@ -112,8 +112,7 @@ def main():
|
|||||||
'gnocchi_project_id',
|
'gnocchi_project_id',
|
||||||
'gnocchi_resource_id',
|
'gnocchi_resource_id',
|
||||||
'gnocchi_user_id',
|
'gnocchi_user_id',
|
||||||
'designate_pool_id',
|
'designate_pool_id']
|
||||||
'karbor_openstack_infra_id']
|
|
||||||
|
|
||||||
# SSH key pair
|
# SSH key pair
|
||||||
ssh_keys = ['kolla_ssh_key', 'nova_ssh_key',
|
ssh_keys = ['kolla_ssh_key', 'nova_ssh_key',
|
||||||
|
@ -0,0 +1,7 @@
|
|||||||
|
---
|
||||||
|
upgrade:
|
||||||
|
- |
|
||||||
|
The Karbor project is no longer maintained and `retired since the Wallaby
|
||||||
|
cycle
|
||||||
|
<http://lists.openstack.org/pipermail/openstack-discuss/2020-November/018643.html>`__.
|
||||||
|
Its support and roles are also removed since Wallaby cycle.
|
@ -94,9 +94,6 @@ monitoring
|
|||||||
[kafka:children]
|
[kafka:children]
|
||||||
control
|
control
|
||||||
|
|
||||||
[karbor:children]
|
|
||||||
control
|
|
||||||
|
|
||||||
[kibana:children]
|
[kibana:children]
|
||||||
control
|
control
|
||||||
|
|
||||||
@ -385,16 +382,6 @@ ironic
|
|||||||
[tgtd:children]
|
[tgtd:children]
|
||||||
storage
|
storage
|
||||||
|
|
||||||
# Karbor
|
|
||||||
[karbor-api:children]
|
|
||||||
karbor
|
|
||||||
|
|
||||||
[karbor-protection:children]
|
|
||||||
karbor
|
|
||||||
|
|
||||||
[karbor-operationengine:children]
|
|
||||||
karbor
|
|
||||||
|
|
||||||
# Manila
|
# Manila
|
||||||
[manila-api:children]
|
[manila-api:children]
|
||||||
manila
|
manila
|
||||||
|
Loading…
Reference in New Issue
Block a user