Lusheng Ji | 768421b | 2018-06-01 16:36:54 -0400 | [diff] [blame] | 1 | .. This work is licensed under a Creative Commons Attribution 4.0 International License. |
| 2 | .. http://creativecommons.org/licenses/by/4.0 |
| 3 | |
Vijay VK | f9e4344 | 2019-05-22 22:10:29 +0100 | [diff] [blame] | 4 | DCAE Deployment (using Helm and Cloudify) |
| 5 | ========================================= |
Lusheng Ji | 768421b | 2018-06-01 16:36:54 -0400 | [diff] [blame] | 6 | |
VENKATESH KUMAR | 3e2bb4c | 2020-05-13 16:21:54 -0400 | [diff] [blame] | 7 | This document describes the details of the Helm chart based deployment process for ONAP and how DCAE is deployed through this process. |
Lusheng Ji | 768421b | 2018-06-01 16:36:54 -0400 | [diff] [blame] | 8 | |
| 9 | |
Vijay VK | f9e4344 | 2019-05-22 22:10:29 +0100 | [diff] [blame] | 10 | Deployment Overview |
| 11 | ------------------- |
Lusheng Ji | 768421b | 2018-06-01 16:36:54 -0400 | [diff] [blame] | 12 | |
VENKATESH KUMAR | 3e2bb4c | 2020-05-13 16:21:54 -0400 | [diff] [blame] | 13 | ONAP deployments are done on kubernetes through OOM/Helm charts. Kubernetes is a container orchestration technology that organizes containers into composites of various patterns for easy deployment, management, and scaling. |
Jack Lucas | 34c4022 | 2019-05-16 09:42:56 -0400 | [diff] [blame] | 14 | ONAP uses Kubernetes as the foundation for fulfilling its platform maturity promises. |
Lusheng Ji | 768421b | 2018-06-01 16:36:54 -0400 | [diff] [blame] | 15 | |
VENKATESH KUMAR | 3e2bb4c | 2020-05-13 16:21:54 -0400 | [diff] [blame] | 16 | ONAP manages Kubernetes specifications using Helm charts (in OOM project), under which all Kubernetes yaml-formatted resource specifications and additional files |
Jack Lucas | 34c4022 | 2019-05-16 09:42:56 -0400 | [diff] [blame] | 17 | are organized into a hierarchy of charts, sub-charts, and resources. These yaml files are further augmented with Helm's templating, which makes dependencies |
| 18 | and cross-references of parameters and parameter derivatives among resources manageable for a large and complex Kubernetes system such as ONAP. |
Lusheng Ji | 768421b | 2018-06-01 16:36:54 -0400 | [diff] [blame] | 19 | |
Jack Lucas | 34c4022 | 2019-05-16 09:42:56 -0400 | [diff] [blame] | 20 | At deployment time, with a single **helm deploy** command, Helm resolves all the templates and compiles the chart hierarchy into Kubernetes resource definitions, |
| 21 | and invokes Kubernetes deployment operations for all the resources. |
Lusheng Ji | 768421b | 2018-06-01 16:36:54 -0400 | [diff] [blame] | 22 | |
Jack Lucas | 34c4022 | 2019-05-16 09:42:56 -0400 | [diff] [blame] | 23 | All ONAP Helm charts are organized under the **kubernetes** directory of the **OOM** project, where roughly each ONAP component occupies a subdirectory. |
| 24 | DCAE charts are placed under the **dcaegen2** directory. |
Lusheng Ji | 768421b | 2018-06-01 16:36:54 -0400 | [diff] [blame] | 25 | |
VENKATESH KUMAR | 7cfaea2 | 2020-04-22 17:31:32 -0400 | [diff] [blame] | 26 | All DCAE platform components have corresponding Helm chart which will be used to trigger the deployment. |
Vijay VK | f9e4344 | 2019-05-22 22:10:29 +0100 | [diff] [blame] | 27 | All DCAE Services are deployed through Cloudify Blueprint. The default ONAP DCAE deployment includes small subset of DCAE services deployed through Bootstrap pod to meet |
VENKATESH KUMAR | 7cac724 | 2020-06-04 11:17:10 -0400 | [diff] [blame] | 28 | ONAP Integration usecases. Optionally operators can deploy on-demand other MS required for their usecases as described in :doc:`On-demand MS Installation |
| 29 | <./installation_MS_ondemand>`. |
| 30 | |
Vijay VK | f9e4344 | 2019-05-22 22:10:29 +0100 | [diff] [blame] | 31 | |
Lusheng Ji | 768421b | 2018-06-01 16:36:54 -0400 | [diff] [blame] | 32 | DCAE Chart Organization |
| 33 | ----------------------- |
| 34 | |
Jack Lucas | 34c4022 | 2019-05-16 09:42:56 -0400 | [diff] [blame] | 35 | Following Helm conventions, the DCAE Helm chart directory (``oom/kubernetes/dcaegen2``) consists of the following files and subdirectories: |
Lusheng Ji | 768421b | 2018-06-01 16:36:54 -0400 | [diff] [blame] | 36 | |
Jack Lucas | 34c4022 | 2019-05-16 09:42:56 -0400 | [diff] [blame] | 37 | * ``Chart.yaml``: metadata. |
| 38 | * ``requirements.yaml``: dependency charts. |
| 39 | * ``values.yaml``: values for Helm templating engine to expand templates. |
| 40 | * ``resources``: subdirectory for additional resource definitions such as configuration, scripts, etc. |
VENKATESH KUMAR | 7cfaea2 | 2020-04-22 17:31:32 -0400 | [diff] [blame] | 41 | * ``Makefile``: make file to build DCAE charts |
| 42 | * ``components``: subdirectory for DCAE sub-charts. |
Lusheng Ji | 768421b | 2018-06-01 16:36:54 -0400 | [diff] [blame] | 43 | |
| 44 | The dcaegen2 chart has the following sub-charts: |
Guobiao Mo | c3dd829 | 2018-06-26 11:12:36 -0700 | [diff] [blame] | 45 | |
Jack Lucas | 34c4022 | 2019-05-16 09:42:56 -0400 | [diff] [blame] | 46 | * ``dcae-bootstrap``: deploys the DCAE bootstrap service that performs some DCAE initialization and deploys additional DCAE components. |
| 47 | * ``dcae-cloudify-manager``: deploys the DCAE Cloudify Manager instance. |
| 48 | * ``dcae-config-binding-service``: deploys the DCAE config binding service. |
| 49 | * ``dcae-deployment-handler``: deploys the DCAE deployment handler service. |
| 50 | * ``dcae-healthcheck``: deploys the DCAE healthcheck service that provides an API to check the health of all DCAE components. |
| 51 | * ``dcae-policy-handler``: deploys the DCAE policy handler service. |
| 52 | * ``dcae-redis``: deploys the DCAE Redis cluster. |
VENKATESH KUMAR | 7cfaea2 | 2020-04-22 17:31:32 -0400 | [diff] [blame] | 53 | * ``dcae-dashboard``: deploys the DCAE Dashboard for managing DCAE microservices deployments |
Jack Lucas | 34c4022 | 2019-05-16 09:42:56 -0400 | [diff] [blame] | 54 | * ``dcae-servicechange-handler``: deploys the DCAE service change handler service. A subchart (``dcae-inventory-api``) deploys the DCAE inventory API service. |
Lusheng Ji | 768421b | 2018-06-01 16:36:54 -0400 | [diff] [blame] | 55 | |
| 56 | DCAE Deployment |
| 57 | --------------- |
| 58 | |
Jack Lucas | 34c4022 | 2019-05-16 09:42:56 -0400 | [diff] [blame] | 59 | At deployment time, when the **helm deploy** command is executed, |
| 60 | all DCAE resources defined within the subcharts above are deployed. |
| 61 | These include: |
Donald Hunter | a5683c6 | 2018-11-06 22:54:51 +0000 | [diff] [blame] | 62 | |
Jack Lucas | 34c4022 | 2019-05-16 09:42:56 -0400 | [diff] [blame] | 63 | * the DCAE bootstrap service |
| 64 | * the DCAE healthcheck service |
| 65 | * the DCAE platform components: |
Lusheng Ji | 768421b | 2018-06-01 16:36:54 -0400 | [diff] [blame] | 66 | |
Jack Lucas | 34c4022 | 2019-05-16 09:42:56 -0400 | [diff] [blame] | 67 | * Cloudify Manager |
| 68 | * Config binding service |
| 69 | * Deployment handler |
| 70 | * Policy handler |
| 71 | * Service change handler |
| 72 | * Inventory API service (launched as a subchart of service change handler) |
| 73 | * Inventory postgres database service (launched as a dependency of the inventory API service) |
| 74 | * DCAE postgres database service (launched as a dependency of the bootstrap service) |
| 75 | * DCAE Redis cluster |
Lusheng Ji | 768421b | 2018-06-01 16:36:54 -0400 | [diff] [blame] | 76 | |
Jack Lucas | 34c4022 | 2019-05-16 09:42:56 -0400 | [diff] [blame] | 77 | Some of the DCAE subcharts include an initContainer that checks to see if |
| 78 | other services that they need in order to run have become ready. The installation |
| 79 | of these subcharts will pause until the needed services are available. |
Donald Hunter | a5683c6 | 2018-11-06 22:54:51 +0000 | [diff] [blame] | 80 | |
Jack Lucas | 34c4022 | 2019-05-16 09:42:56 -0400 | [diff] [blame] | 81 | In addition, DCAE operations depends on a Consul server cluster. |
| 82 | For ONAP OOM deployment, the Consul cluster is provided as a shared |
| 83 | resource. Its charts are defined under the ``oom/kubernetes/consul`` |
| 84 | directory, not as part of the DCAE chart hierarchy. |
Lusheng Ji | 768421b | 2018-06-01 16:36:54 -0400 | [diff] [blame] | 85 | |
Jack Lucas | 34c4022 | 2019-05-16 09:42:56 -0400 | [diff] [blame] | 86 | The dcae-bootstrap service has a number of prerequisites because the subsequently deployed DCAE components depends on a number of resources having entered their normal operation state. DCAE bootstrap job will not start before these resources are ready. They are: |
Lusheng Ji | 768421b | 2018-06-01 16:36:54 -0400 | [diff] [blame] | 87 | |
VENKATESH KUMAR | 3e2bb4c | 2020-05-13 16:21:54 -0400 | [diff] [blame] | 88 | |
Jack Lucas | 34c4022 | 2019-05-16 09:42:56 -0400 | [diff] [blame] | 89 | * dcae-cloudify-manager |
| 90 | * consul-server |
| 91 | * msb-discovery |
| 92 | * kube2msb |
| 93 | * dcae-config-binding-service |
| 94 | * dcae-db |
VENKATESH KUMAR | 7cfaea2 | 2020-04-22 17:31:32 -0400 | [diff] [blame] | 95 | * dcae-mongodb |
VENKATESH KUMAR | 3e2bb4c | 2020-05-13 16:21:54 -0400 | [diff] [blame] | 96 | * dcae-inventory-api |
| 97 | |
| 98 | Additionaly tls-init-container invoked during component deployment relies on AAF to generate the required certificate hence AAF |
| 99 | must be enabled under OOM deployment configuration. |
Donald Hunter | a5683c6 | 2018-11-06 22:54:51 +0000 | [diff] [blame] | 100 | |
Jack Lucas | 34c4022 | 2019-05-16 09:42:56 -0400 | [diff] [blame] | 101 | Once started, the DCAE bootstrap service will call Cloudify Manager to deploy |
VENKATESH KUMAR | 7cfaea2 | 2020-04-22 17:31:32 -0400 | [diff] [blame] | 102 | a series of blueprints which specify the additional DCAE microservice components. |
Jack Lucas | 34c4022 | 2019-05-16 09:42:56 -0400 | [diff] [blame] | 103 | These blueprints use the DCAE Kubernetes plugin (``k8splugin``) to deploy |
| 104 | Docker images into the ONAP Kubernetes cluster. For each component, the plugin |
| 105 | creates a Kubernetes deployment and other Kubernetes resources (services, volumes, logging sidecar, etc.) |
| 106 | as needed. |
Lusheng Ji | 768421b | 2018-06-01 16:36:54 -0400 | [diff] [blame] | 107 | |
Jack Lucas | 34c4022 | 2019-05-16 09:42:56 -0400 | [diff] [blame] | 108 | The DCAE bootstrap service creates the following Kubernetes deployments: |
| 109 | |
Jack Lucas | 34c4022 | 2019-05-16 09:42:56 -0400 | [diff] [blame] | 110 | * deploy/dep-dcae-hv-ves-collector |
| 111 | * deploy/dep-dcae-prh |
Jack Lucas | 34c4022 | 2019-05-16 09:42:56 -0400 | [diff] [blame] | 112 | * deploy/dep-dcae-tca-analytics |
VENKATESH KUMAR | 3e2bb4c | 2020-05-13 16:21:54 -0400 | [diff] [blame] | 113 | * deploy/dep-dcae-tcagen2 |
Jack Lucas | 34c4022 | 2019-05-16 09:42:56 -0400 | [diff] [blame] | 114 | * deploy/dep-dcae-ves-collector |
| 115 | * deploy/dep-holmes-engine-mgmt |
| 116 | * deploy/dep-holmes-rule-mgmt |
| 117 | |
| 118 | After deploying all of the blueprints, the DCAE bootstrap service |
| 119 | continues to run. The bootstrap container can be useful for |
| 120 | troubleshooting or for launching additional components. The bootstrap |
| 121 | container logs (accessed using the ``kubectl logs`` command) show the |
| 122 | details of all of the component deployments. |
Lusheng Ji | 768421b | 2018-06-01 16:36:54 -0400 | [diff] [blame] | 123 | |
| 124 | DCAE Configuration |
| 125 | ------------------ |
| 126 | |
| 127 | Deployment time configuration of DCAE components are defined in several places. |
| 128 | |
| 129 | * Helm Chart templates: |
| 130 | * Helm/Kubernetes template files can contain static values for configuration parameters; |
| 131 | * Helm Chart resources: |
| 132 | * Helm/Kubernetes resources files can contain static values for configuration parameters; |
| 133 | * Helm values.yaml files: |
| 134 | * The values.yaml files supply the values that Helm templating engine uses to expand any templates defined in Helm templates; |
| 135 | * In a Helm chart hierarchy, values defined in values.yaml files in higher level supersedes values defined in values.yaml files in lower level; |
| 136 | * Helm command line supplied values supersedes values defined in any values.yaml files. |
| 137 | |
Jack Lucas | 34c4022 | 2019-05-16 09:42:56 -0400 | [diff] [blame] | 138 | In addition, for DCAE components deployed through Cloudify Manager blueprints, their configuration parameters are defined in the following places: |
Donald Hunter | a5683c6 | 2018-11-06 22:54:51 +0000 | [diff] [blame] | 139 | |
Jack Lucas | 34c4022 | 2019-05-16 09:42:56 -0400 | [diff] [blame] | 140 | * The blueprint files can contain static values for configuration parameters; |
| 141 | * The blueprint files are defined under the ``blueprints`` directory of the ``dcaegen2/platform/blueprints`` repo, named with "k8s" prefix. |
| 142 | * The blueprint files can specify input parameters and the values of these parameters will be used for configuring parameters in Blueprints. The values for these input parameters can be supplied in several ways as listed below in the order of precedence (low to high): |
| 143 | * The blueprint files can define default values for the input parameters; |
| 144 | * The blueprint input files can contain static values for input parameters of blueprints. These input files are provided as config resources under the dcae-bootstrap chart; |
| 145 | * The blueprint input files may contain Helm templates, which are resolved into actual deployment time values following the rules for Helm values. |
Lusheng Ji | 768421b | 2018-06-01 16:36:54 -0400 | [diff] [blame] | 146 | |
| 147 | |
VENKATESH KUMAR | 7cfaea2 | 2020-04-22 17:31:32 -0400 | [diff] [blame] | 148 | Now we walk through an example, how to configure the Docker image for the DCAE VESCollector, which is deployed by Cloudify Manager. |
Lusheng Ji | 768421b | 2018-06-01 16:36:54 -0400 | [diff] [blame] | 149 | |
VENKATESH KUMAR | 7cfaea2 | 2020-04-22 17:31:32 -0400 | [diff] [blame] | 150 | In the `k8s-ves.yaml <https://git.onap.org/dcaegen2/platform/blueprints/tree/blueprints/k8s-ves.yaml>`_ blueprint, the Docker image to use is defined as an input parameter with a default value: |
Lusheng Ji | 768421b | 2018-06-01 16:36:54 -0400 | [diff] [blame] | 151 | |
Vijay VK | f9e4344 | 2019-05-22 22:10:29 +0100 | [diff] [blame] | 152 | .. code-block:: yaml |
Lusheng Ji | 768421b | 2018-06-01 16:36:54 -0400 | [diff] [blame] | 153 | |
VENKATESH KUMAR | 7cfaea2 | 2020-04-22 17:31:32 -0400 | [diff] [blame] | 154 | tag_version: |
| 155 | type: string |
| 156 | default: "nexus3.onap.org:10001/onap/org.onap.dcaegen2.collectors.ves.vescollector:1.5.4" |
| 157 | |
| 158 | The corresponding input file, ``https://git.onap.org/oom/tree/kubernetes/dcaegen2/components/dcae-bootstrap/resources/inputs/k8s-ves-inputs-tls.yaml``, |
Jack Lucas | 34c4022 | 2019-05-16 09:42:56 -0400 | [diff] [blame] | 159 | it is defined again as: |
| 160 | |
Vijay VK | f9e4344 | 2019-05-22 22:10:29 +0100 | [diff] [blame] | 161 | .. code-block:: yaml |
VENKATESH KUMAR | 7cfaea2 | 2020-04-22 17:31:32 -0400 | [diff] [blame] | 162 | {{ if .Values.componentImages.ves }} |
| 163 | tag_version: {{ include "common.repository" . }}/{{ .Values.componentImages.ves }} |
| 164 | {{ end }} |
| 165 | |
Jack Lucas | 34c4022 | 2019-05-16 09:42:56 -0400 | [diff] [blame] | 166 | |
VENKATESH KUMAR | 7cfaea2 | 2020-04-22 17:31:32 -0400 | [diff] [blame] | 167 | Thus, when ``common.repository`` and ``componentImages.ves`` are defined in the ``values.yaml`` files, |
| 168 | their values will be plugged in here and the resulting ``tag_version`` value |
| 169 | will be passed to the blueprint as the Docker image tag to use instead of the default value in the blueprint. |
Jack Lucas | 34c4022 | 2019-05-16 09:42:56 -0400 | [diff] [blame] | 170 | |
VENKATESH KUMAR | 7cfaea2 | 2020-04-22 17:31:32 -0400 | [diff] [blame] | 171 | The ``componentImages.ves`` value is provided in the ``oom/kubernetes/dcaegen2/charts/dcae-bootstrap/values.yaml`` file: |
Jack Lucas | 34c4022 | 2019-05-16 09:42:56 -0400 | [diff] [blame] | 172 | |
Vijay VK | f9e4344 | 2019-05-22 22:10:29 +0100 | [diff] [blame] | 173 | .. code-block:: yaml |
Jack Lucas | 34c4022 | 2019-05-16 09:42:56 -0400 | [diff] [blame] | 174 | |
Lusheng Ji | 768421b | 2018-06-01 16:36:54 -0400 | [diff] [blame] | 175 | componentImages: |
VENKATESH KUMAR | 7cfaea2 | 2020-04-22 17:31:32 -0400 | [diff] [blame] | 176 | ves: onap/org.onap.dcaegen2.collectors.ves.vescollector:1.5.4 |
Lusheng Ji | 768421b | 2018-06-01 16:36:54 -0400 | [diff] [blame] | 177 | |
VENKATESH KUMAR | 7cfaea2 | 2020-04-22 17:31:32 -0400 | [diff] [blame] | 178 | |
| 179 | The final result is that when DCAE bootstrap calls Cloudify Manager to deploy the DCAE VES collector, the 1.5.4 image will be deployed. |
Lusheng Ji | 768421b | 2018-06-01 16:36:54 -0400 | [diff] [blame] | 180 | |
| 181 | DCAE Service Endpoints |
| 182 | ---------------------- |
| 183 | |
Jack Lucas | 34c4022 | 2019-05-16 09:42:56 -0400 | [diff] [blame] | 184 | Below is a table of default hostnames and ports for DCAE component service endpoints in Kubernetes deployment: |
Donald Hunter | 1e7e2ef | 2018-11-21 14:17:28 +0000 | [diff] [blame] | 185 | ================== ================================= ====================================================== |
Vijay VK | 86cd893 | 2018-10-23 16:35:29 +0100 | [diff] [blame] | 186 | Component Cluster Internal (host:port) Cluster external (svc_name:port) |
Donald Hunter | 1e7e2ef | 2018-11-21 14:17:28 +0000 | [diff] [blame] | 187 | ================== ================================= ====================================================== |
VENKATESH KUMAR | 7cfaea2 | 2020-04-22 17:31:32 -0400 | [diff] [blame] | 188 | VES dcae-ves-collector:8443 xdcae-ves-collector.onap:30417 |
Vijay VK | 86cd893 | 2018-10-23 16:35:29 +0100 | [diff] [blame] | 189 | HV-VES dcae-hv-ves-collector:6061 xdcae-hv-ves-collector.onap:30222 |
| 190 | TCA dcae-tca-analytics:11011 xdcae-tca-analytics.onap:32010 |
VENKATESH KUMAR | 7cfaea2 | 2020-04-22 17:31:32 -0400 | [diff] [blame] | 191 | TCA-Gen2 dcae-tcagen2:9091 NA |
Vijay VK | f6659fc | 2018-11-02 05:07:27 +0100 | [diff] [blame] | 192 | PRH dcae-prh:8100 NA |
Vijay VK | 86cd893 | 2018-10-23 16:35:29 +0100 | [diff] [blame] | 193 | Policy Handler policy-handler:25577 NA |
| 194 | Deployment Handler deployment-handler:8443 NA |
| 195 | Inventory inventory:8080 NA |
VENKATESH KUMAR | 7cfaea2 | 2020-04-22 17:31:32 -0400 | [diff] [blame] | 196 | Config binding config-binding-service:10000/10001 config-binding-service:30415 |
Vijay VK | 86cd893 | 2018-10-23 16:35:29 +0100 | [diff] [blame] | 197 | DCAE Healthcheck dcae-healthcheck:80 NA |
| 198 | Cloudify Manager dcae-cloudify-manager:80 NA |
VENKATESH KUMAR | 7cfaea2 | 2020-04-22 17:31:32 -0400 | [diff] [blame] | 199 | DCAE Dashboard dcae-dashboard:8443 xdcae-dashboard:30419 |
Donald Hunter | 1e7e2ef | 2018-11-21 14:17:28 +0000 | [diff] [blame] | 200 | ================== ================================= ====================================================== |
Lusheng Ji | 768421b | 2018-06-01 16:36:54 -0400 | [diff] [blame] | 201 | |
Filip Krzywka | cbd2ded | 2018-09-25 14:43:18 +0200 | [diff] [blame] | 202 | In addition, a number of ONAP service endpoints that are used by DCAE components are listed as follows |
| 203 | for reference by DCAE developers and testers: |
Donald Hunter | a5683c6 | 2018-11-06 22:54:51 +0000 | [diff] [blame] | 204 | |
Filip Krzywka | cbd2ded | 2018-09-25 14:43:18 +0200 | [diff] [blame] | 205 | ==================== ============================ ================================ |
| 206 | Component Cluster Internal (host:port) Cluster external (svc_name:port) |
| 207 | ==================== ============================ ================================ |
| 208 | Consul Server consul-server:8500 consul-server:30270 |
| 209 | Robot robot:88 robot:30209 TCP |
| 210 | Message router message-router:3904 message-router:30227 |
| 211 | Message router message-router:3905 message-router:30226 |
| 212 | Message router Kafka message-router-kafka:9092 NA |
| 213 | MSB Discovery msb-discovery:10081 msb-discovery:30281 |
| 214 | Logging log-kibana:5601 log-kibana:30253 |
| 215 | AAI aai:8080 aai:30232 |
| 216 | AAI aai:8443 aai:30233 |
| 217 | ==================== ============================ ================================ |
Lusheng Ji | 768421b | 2018-06-01 16:36:54 -0400 | [diff] [blame] | 218 | |
Jack Lucas | 34c4022 | 2019-05-16 09:42:56 -0400 | [diff] [blame] | 219 | Uninstalling DCAE |
| 220 | ----------------- |
| 221 | |
| 222 | All of the DCAE components deployed using the OOM Helm charts will be |
| 223 | deleted by the ``helm undeploy`` command. This command can be used to |
| 224 | uninstall all of ONAP by undeploying the top-level Helm release that was |
| 225 | created by the ``helm deploy`` command. The command can also be used to |
| 226 | uninstall just DCAE, by having the command undeploy the `top_level_release_name`-``dcaegen2`` |
| 227 | Helm sub-release. |
| 228 | |
| 229 | Helm will undeploy only the components that were originally deployed using |
| 230 | Helm charts. Components deployed by Cloudify Manager are not deleted by |
| 231 | the Helm operations. |
| 232 | |
| 233 | When uninstalling all of ONAP, it is sufficient to delete the namespace |
| 234 | used for the deployment (typically ``onap``) after running the undeploy |
| 235 | operation. Deleting the namespace will get rid of any remaining resources |
| 236 | in the namespace, including the components deployed by Cloudify Manager. |
| 237 | |
| 238 | When uninstalling DCAE alone, deleting the namespace would delete the |
| 239 | rest of ONAP as well. To delete DCAE alone, and to make sure all of the |
| 240 | DCAE components deployed by Cloudify Manager are uninstalled: |
| 241 | |
| 242 | * Find the Cloudify Manager pod identifier, using a command like: |
| 243 | |
| 244 | ``kubectl -n onap get pods | grep dcae-cloudify-manager`` |
| 245 | * Execute the DCAE cleanup script on the Cloudify Manager pod, using a command like: |
| 246 | |
| 247 | ``kubectl -n onap exec`` `cloudify-manager-pod-id` ``-- /scripts/dcae-cleanup.sh`` |
| 248 | * Finally, run ``helm undeploy`` against the DCAE Helm subrelease |
| 249 | |
| 250 | The DCAE cleanup script uses Cloudify Manager and the DCAE Kubernetes |
| 251 | plugin to instruct Kubernetes to delete the components deployed by Cloudify |
| 252 | Manager. This includes the components deployed when the DCAE bootstrap |
| 253 | service ran and any components deployed after bootstrap. |