From c38b604d235010dad873a3f45948242bf0c65dda Mon Sep 17 00:00:00 2001 From: Ravi Pendurty Date: Fri, 9 Oct 2020 18:54:16 +0200 Subject: [PATCH] Retain default behavior of startODL.sh script Retain default behavior of startODL.sh in standalone environment Issue-ID: SDNC-1374 Signed-off-by: Ravi Pendurty Change-Id: I95f02de192a4ae0f834d9eaf28c27e7a6d0be6f9 Signed-off-by: Ravi Pendurty --- installation/sdnc/src/main/scripts/startODL.sh | 36 ++++++++++++++++---------- installation/src/main/yaml/docker-compose.yml | 1 + 2 files changed, 23 insertions(+), 14 deletions(-) diff --git a/installation/sdnc/src/main/scripts/startODL.sh b/installation/sdnc/src/main/scripts/startODL.sh index 90aa8076..57f3cbfc 100755 --- a/installation/sdnc/src/main/scripts/startODL.sh +++ b/installation/sdnc/src/main/scripts/startODL.sh @@ -173,7 +173,8 @@ function enable_odl_cluster() { else echo "This is a local cluster" node_list="" - if $OOM_ENABLED; then + # SERVICE_NAME and NAMESPACE are used to create cluster node names and are provided via Helm charts in OOM environment + if [ ! -z "$SERVICE_NAME" ] && [ ! -z "$NAMESPACE" ]; then # Extract node name minus the index # Example sdnr from "sdnr-2.logo.ost.das.r32.com" node_name=($(echo ${fqdn} | sed 's/-[0-9].*$//g')) @@ -182,7 +183,8 @@ function enable_odl_cluster() { node_list="${node_list} ${node_name}-$i.${SERVICE_NAME}-cluster.${NAMESPACE}" done ${ODL_HOME}/bin/configure_cluster.sh $((node_index+1)) ${node_list} - else + elif [ -z "$SERVICE_NAME" ] && [ -z "$NAMESPACE" ]; then + # Hostname is used in Standalone environment to create cluster node names for ((i=0;i<${SDNC_REPLICAS};i++)); do #assemble node list by replacing node-index in hostname with "i" @@ -190,6 +192,13 @@ function enable_odl_cluster() { node_list="${node_list} ${node_name}" done ${ODL_HOME}/bin/configure_cluster.sh $((node_index+1)) ${node_list} + else + echo "Unhandled cluster scenario. Terminating the container" + echo "Any one of the below 2 conditions should be satisfied for successfully enabling cluster mode : " + echo "1. OOM Environment - Both SERVICE_NAME and NAMESPACE environment variables have to be set." + echo "2. Docker (standalone) Environment - Neither of SERVICE_NAME and NAMESPACE have to be set." + echo "Current configuration - SERVICE_NAME = $SERVICE_NAME NAMESPACE = $NAMESPACE" + exit $NOTOK fi fi } @@ -216,6 +225,7 @@ fi ODL_ADMIN_PASSWORD=${ODL_ADMIN_PASSWORD:-Kp8bJ4SXszM0WXlhak3eHlcse2gAw84vaoGGmJvUy2U} SDNC_HOME=${SDNC_HOME:-/opt/onap/sdnc} SDNC_BIN=${SDNC_BIN:-/opt/onap/sdnc/bin} +# Whether to intialize MYSql DB or not. Default is to initialize SDNC_DB_INIT=${SDNC_DB_INIT:-false} CCSDK_HOME=${CCSDK_HOME:-/opt/onap/ccsdk} JDEBUG=${JDEBUG:-false} @@ -223,7 +233,6 @@ MYSQL_PASSWD=${MYSQL_PASSWD:-openECOMP1.0} ENABLE_ODL_CLUSTER=${ENABLE_ODL_CLUSTER:-false} GEO_ENABLED=${GEO_ENABLED:-false} SDNC_AAF_ENABLED=${SDNC_AAF_ENABLED:-false} -OOM_ENABLED=${OOM_ENABLED:-false} IS_PRIMARY_CLUSTER=${IS_PRIMARY_CLUSTER:-false} MY_ODL_CLUSTER=${MY_ODL_CLUSTER:-127.0.0.1} INSTALLED_DIR=${INSTALLED_FILE:-/opt/opendaylight/current/daexim} @@ -236,6 +245,7 @@ SDNRDM_ONF_REPO=${SDNRDM_ONF_REPO:-mvn:org.onap.ccsdk.features.sdnr.wt/sdnr-wt-d # Add devicemanager features SDNRDM_SDM_LIST=${SDNRDM_SDM_LIST:-sdnr-wt-devicemanager-onf-feature} SDNRDM_BOOTFEATURES=${SDNRDM_BOOTFEATURES:-sdnr-wt-feature-aggregator-devicemanager-base, ${SDNRDM_SDM_LIST}} +# Whether to Initialize the ElasticSearch DB. SDNRINIT=${SDNRINIT:-false} SDNRONLY=${SDNRONLY:-false} SDNRDBURL=${SDNRDBURL:-http://sdnrdb:9200} @@ -243,6 +253,7 @@ SDNRDBCOMMAND=${SDNRDBCOMMAND:--c init -db $SDNRDBURL -dbu $SDNRDBUSERNAME -dbp SDNR_NORTHBOUND=${SDNR_NORTHBOUND:-false} SDNR_NORTHBOUND_BOOTFEATURES=${SDNR_NORTHBOUND_BOOTFEATURES:-sdnr-northbound-all} +NOTOK=1 export ODL_ADMIN_PASSWORD ODL_ADMIN_USERNAME if $JDEBUG ; then @@ -282,7 +293,8 @@ echo " MY_ODL_CLUSTER=$MY_ODL_CLUSTER" echo " PEER_ODL_CLUSTER=$PEER_ODL_CLUSTER" echo " SDNR_NORTHBOUND=$SDNR_NORTHBOUND" echo " AAF_ENABLED=$SDNC_AAF_ENABLED" -echo " OOM_ENABLED=$OOM_ENABLED" +echo " SERVICE_NAME=$SERVICE_NAME" +echo " NAMESPACE=$NAMESPACE" if $SDNC_AAF_ENABLED; then export SDNC_AAF_STORE_DIR=/opt/app/osaaf/local @@ -312,7 +324,8 @@ if $SDNRINIT ; then fi fi -if ! $OOM_ENABLED; then +# Check for MySQL DB connectivity only if SDNC_DB_INIT is set to "true" +if $SDNC_DB_INIT; then # # Wait for database # @@ -332,26 +345,21 @@ fi if [ ! -f ${SDNC_HOME}/.installed ] then - if ! $OOM_ENABLED; then # for integration testing. In OOM, a separate job takes care of installing it. if $SDNC_DB_INIT; then echo "Installing SDN-C database" ${SDNC_HOME}/bin/installSdncDb.sh fi - - #${CCSDK_HOME}/bin/installOdlHostKey.sh + echo "Installing SDN-C keyStore\n" + ${SDNC_HOME}/bin/addSdncKeyStore.sh + echo "Installing A1-adapter trustStore\n" + ${SDNC_HOME}/bin/addA1TrustStore.sh if [ -x ${SDNC_HOME}/svclogic/bin/install.sh ] then echo "Installing directed graphs" ${SDNC_HOME}/svclogic/bin/install.sh fi - fi - - echo "Installing SDN-C keyStore" - ${SDNC_HOME}/bin/addSdncKeyStore.sh - echo "Installing A1-adapter trustStore" - ${SDNC_HOME}/bin/addA1TrustStore.sh if $ENABLE_ODL_CLUSTER ; then enable_odl_cluster ; fi diff --git a/installation/src/main/yaml/docker-compose.yml b/installation/src/main/yaml/docker-compose.yml index 96f9bb32..a8c561da 100644 --- a/installation/src/main/yaml/docker-compose.yml +++ b/installation/src/main/yaml/docker-compose.yml @@ -63,6 +63,7 @@ services: - ODL_CERT_DIR=/tmp - ODL_ADMIN_USERNAME=admin - ODL_ADMIN_PASSWORD=Kp8bJ4SXszM0WXlhak3eHlcse2gAw84vaoGGmJvUy2U + - SDNC_DB_INIT=true - A1_TRUSTSTORE_PASSWORD=a1adapter # The default truststore for A1 adapter can be overridden by mounting a new # truststore (uncomment the lines below), whereas the corresponding password -- 2.16.6