[VOL-3634] Adding multi-stack support
Change-Id: I7a9e6e0d80b9ad92e7175d76ca7e93dcbe8777ec
diff --git a/voltha b/voltha
index 3c740bd..4fe8e4c 100755
--- a/voltha
+++ b/voltha
@@ -98,6 +98,7 @@
BBSIM_CFG=${BBSIM_CFG:-configs/bbsim-sadis-att.yaml}
INSTALL_ONOS_APPS=${INSTALL_ONOS_APPS:-no}
JUST_K8S=${JUST_K8S:-no}
+JUST_INFRA=${JUST_INFRA:-no}
DEPLOY_K8S=${DEPLOY_K8S:-yes}
INSTALL_KUBECTL=${INSTALL_KUBECTL:-yes}
INSTALL_HELM=${INSTALL_HELM:-yes}
@@ -131,7 +132,7 @@
ONOS_CLASSIC_CHART_VERSION=${ONOS_CLASSIC_CHART_VERSION:-latest}
KAFKA_CHART=${KAFKA_CHART:-bitnami/kafka}
KAFKA_CHART_VERSION=${KAFKA_CHART_VERSION:=latest}
-BBSIM_SADIS_SERVER_CHART=${BBSIM_SADIS_SERVER_CHART:-bbsim-sadis/bbsim-sadis-server}
+BBSIM_SADIS_SERVER_CHART=${BBSIM_SADIS_SERVER_CHART:-onf/bbsim-sadis-server}
BBSIM_SADIS_SERVER_CHART_VERSION=${BBSIM_SADIS_SERVER_CHART_VERSION:-latest}
ETCD_CHART=${ETCD_CHART:-bitnami/etcd}
ETCD_CHART_VERSION=${ETCD_CHART_VERSION:-latest}
@@ -140,6 +141,7 @@
EXTRA_HELM_INSTALL_ARGS=${EXTRA_HELM_INSTALL_ARGS:-}
INTERNAL_EXTRA_HELM_INSTALL_ARGS=
NUM_OF_BBSIM=${NUM_OF_BBSIM:-1}
+BBSIM_BASE_INDEX=${BBSIM_BASE_INDEX:-1}
NUM_OF_WORKER_NODES=${NUM_OF_WORKER_NODES:-2}
NUM_OF_CONTROLLER_NODES=${NUM_OF_CONTROLLER_NODES:-1}
NUM_OF_OPENONU=${NUM_OF_OPENONU:-1}
@@ -352,6 +354,7 @@
WITH_PPROF \
WITH_INCREMENTAL_EVTO_UPDATE \
JUST_K8S \
+ JUST_INFRA \
DEPLOY_K8S \
INSTALL_ONOS_APPS \
INSTALL_KUBECTL \
@@ -593,50 +596,38 @@
mkdir -p .voltha
touch .voltha/ports
-HAVE="$(grep "$NAME" .voltha/ports)"
-if [ "$HAVE X" == " X" ]; then
- # Find free port prefix
- START=81
- while true; do
- if [ "$(grep -c $START .voltha/ports)" -eq 0 ]; then
- break
- fi
- START="$((START + 1))"
- done
- DELTA="$((START - 81))"
- ONOS_API_PORT=${ONOS_API_PORT:-${START}81}
- ONOS_SSH_PORT=${ONOS_SSH_PORT:-${START}01}
- VOLTHA_API_PORT=${VOLTHA_API_PORT:-5$((55 + DELTA))55}
- VOLTHA_SSH_PORT=${VOLTHA_SSH_PORT:-$((50 + DELTA))22}
- VOLTHA_ETCD_PORT=${VOLTHA_ETCD_PORT:-$((23 + DELTA))79}
- VOLTHA_KAFKA_PORT=${VOLTHA_KAFKA_PORT:-$((90 + DELTA))92}
- VOLTHA_PPROF_PORT=${VOLTHA_PPROF_PORT:-$((60 + DELTA))60}
- OPENOLT_PPROF_PORT=${OPENOLT_PPROF_PORT:-$((60 + DELTA))61}
- OFAGENT_PPROF_PORT=${OFAGENT_PPROF_PORT:-$((60 + DELTA))62}
- ELASTICSEARCH_PORT=${ELASTICSEARCH_PORT:-$((92 + DELTA))00}
- KIBANA_PORT=${KIBANA_PORT:-$((56 + DELTA))01}
- TRACING_GUI_PORT=${TRACING_GUI_PORT:-1$((66 + DELTA))86}
-else
- VALUES="$(echo "$HAVE" | sed -e 's/\s//g' | cut -d= -f2)"
- ONOS_API_PORT=${ONOS_API_PORT:-$(echo "$VALUES" | cut -d, -f1)}
- ONOS_SSH_PORT=${ONOS_SSH_PORT:-$(echo "$VALUES" | cut -d, -f2)}
- VOLTHA_API_PORT=${VOLTHA_API_PORT:-$(echo "$VALUES" | cut -d, -f3)}
- VOLTHA_SSH_PORT=${VOLTHA_SSH_PORT:-$(echo "$VALUES" | cut -d, -f4)}
- VOLTHA_ETCD_PORT=${VOLTHA_ETCD_PORT:-$(echo "$VALUES" | cut -d, -f5)}
- VOLTHA_KAFKA_PORT=${VOLTHA_KAFKA_PORT:-$(echo "$VALUES" | cut -d, -f6)}
- VOLTHA_PPROF_PORT=${VOLTHA_PPROF_PORT:-$(echo "$VALUES" | cut -d, -f7)}
- OPENOLT_PPROF_PORT=${OPENOLT_PPROF_PORT:-$(echo "$VALUES" | cut -d, -f8)}
- OFAGENT_PPROF_PORT=${OFAGENT_PPROF_PORT:-$(echo "$VALUES" | cut -d, -f9)}
- ELASTICSEARCH_PORT=${ELASTICSEARCH_PORT:-$(echo "$VALUES" | cut -d, -f10)}
- KIBANA_PORT=${KIBANA_PORT:-$(echo "$VALUES" | cut -d, -f11)}
- TRACING_GUI_PORT=${TRACING_GUI_PORT:-$(echo "$VALUES" | cut -d, -f12)}
- # Some ports were added after the .voltha/ports files was created.
- # Calculate the original DELTA from the VOLTHA_SSH_PORT so that it can
- # be used to set up newer port-forwards.
- DELTA="$((VOLTHA_SSH_PORT/100-50))"
+VOLTHA_API_PORT=55555
+START=$VOLTHA_API_PORT
- if [ -z "$VOLTHA_KAFKA_PORT" ]; then
+# check if the stack deployed with $NAME already exists
+STACK_EXISTS=false
+if [ "$(grep -c "$NAME" .voltha/ports)" -eq 1 ]; then
+ STACK_EXISTS=true
+fi
+
+if [ "$STACK_EXISTS" == true ]; then
+ # if the stack was previously deployed reuse the ports
+ HAVE="$(grep "$NAME" .voltha/ports)"
+ VALUES="$(echo "$HAVE" | sed -e 's/\s//g' | cut -d= -f2)"
+ ONOS_API_PORT=$(echo "$VALUES" | cut -d, -f1)
+ ONOS_SSH_PORT=$(echo "$VALUES" | cut -d, -f2)
+ VOLTHA_API_PORT=$(echo "$VALUES" | cut -d, -f3)
+ VOLTHA_SSH_PORT=$(echo "$VALUES" | cut -d, -f4)
+ VOLTHA_ETCD_PORT=$(echo "$VALUES" | cut -d, -f5)
+ VOLTHA_KAFKA_PORT=$(echo "$VALUES" | cut -d, -f6)
+ VOLTHA_PPROF_PORT=$(echo "$VALUES" | cut -d, -f7)
+ OPENOLT_PPROF_PORT=$(echo "$VALUES" | cut -d, -f8)
+ OFAGENT_PPROF_PORT=$(echo "$VALUES" | cut -d, -f9)
+ ELASTICSEARCH_PORT=$(echo "$VALUES" | cut -d, -f10)
+ KIBANA_PORT=$(echo "$VALUES" | cut -d, -f11)
+ TRACING_GUI_PORT=$(echo "$VALUES" | cut -d, -f12)
+
+ # Some ports were added after the .voltha/ports files was created.
+ # Calculate the original DELTA from the VOLTHA_SSH_PORT so that it can
+ # be used to set up newer port-forwards.
+ DELTA="$((VOLTHA_SSH_PORT/100-50))"
+ if [ -z "$VOLTHA_KAFKA_PORT" ]; then
VOLTHA_KAFKA_PORT=${VOLTHA_KAFKA_PORT:-$((90 + DELTA))92}
fi
@@ -660,6 +651,30 @@
if [ -z "$TRACING_GUI_PORT" ]; then
TRACING_GUI_PORT=${TRACING_GUI_PORT:-1$((66 + DELTA))86}
fi
+else
+ # Find free port prefix
+ START=81
+ while true; do
+ if [ "$(grep -c $START .voltha/ports)" -eq 0 ]; then
+ break
+ fi
+ START="$((START + 1))"
+ done
+
+ # create new ports starting from the first available
+ DELTA="$((START - 81))"
+ ONOS_API_PORT=${START}81
+ ONOS_SSH_PORT=${START}01
+ VOLTHA_API_PORT=5$((55 + DELTA))55
+ VOLTHA_SSH_PORT=$((50 + DELTA))22
+ VOLTHA_ETCD_PORT=$((23 + DELTA))79
+ VOLTHA_KAFKA_PORT=$((90 + DELTA))92
+ VOLTHA_PPROF_PORT=$((60 + DELTA))60
+ OPENOLT_PPROF_PORT=$((60 + DELTA))61
+ OFAGENT_PPROF_PORT=$((60 + DELTA))62
+ ELASTICSEARCH_PORT=$((92 + DELTA))00
+ KIBANA_PORT=$((56 + DELTA))01
+ TRACING_GUI_PORT=$((66 + DELTA))86
fi
PORTTMP="$(mktemp -u)"
@@ -800,6 +815,7 @@
>&2 echo "What wouild you like to do today:"
>&2 echo " up - bring up voltha"
>&2 echo " down - tear down voltha"
+ >&2 echo " clean - remove everything that kind-voltha created"
>&2 echo " dump - create a debug dump of running system"
exit 1
fi
@@ -1047,19 +1063,20 @@
local NS=$1; shift
local SVC=$1; shift
local PORTS="$*"
- local TAG=$SVC-$NAME
+ local TAG=$SVC-$NS-$NAME
(set -x; _TAG="$TAG" bash -c "while true; do kubectl port-forward --address $PF_ADDRESS -n $NS service/$SVC $PORTS; done" >>"$PFLOG" 2>&1 &) >>"$PFLOG" 2>&1
}
kill_port_forward() {
- local TAG P_IDS PARENTS KIDS UNKNOWN PP_ID PF
+ local TAG P_IDS PARENTS KIDS UNKNOWN PP_ID PF NS
while [ $# -gt 0 ]; do
+ NS=$1; shift
PF=$1; shift
TAG=
if [ "$PF" != "__ALL__" ]; then
- TAG="$PF"
+ TAG=$SVC-$NS-$NAME
fi
PARENTS=
KIDS=
@@ -1121,47 +1138,53 @@
}
if [ "$1" == "down" ]; then
+ # NOTE ./voltha down tears down all the stacks, it should only remove components in the specified namespaces
echo "Tearing down voltha cluster $NAME"
+
LOG="down-$NAME.log"
date -u +"%Y%m%dT%H%M%SZ" >"$LOG"
HELM_MAJOR=$(helm version --client --short | sed -E -e 's/^.*v([0-9]+)\.[0-9]+\.[0-9]+.*$/\1/')
if is_in "$WITH_ONOS" "yes,legacy,classic"; then
bspin "Remove port-forwards: onos-ui-$NAME"
- kill_port_forward onos-ui
+ kill_port_forward "$INFRA_NS" onos-ui
sspin "Remove port-forwards: onos-ssh-$NAME$CEOL"
- kill_port_forward onos-ssh
+ kill_port_forward "$INFRA_NS" onos-ssh
sspin "Remove port-forwards: onos-onos-classic-hs-$NAME$CEOL"
- kill_port_forward onos-onos-classic-hs
+ kill_port_forward "$INFRA_NS" onos-onos-classic-hs
fi
sspin "Remove port-forwards: voltha-api-$NAME$CEOL"
- kill_port_forward voltha-api voltha-voltha-api
+ kill_port_forward "$VOLTHA_NS" voltha-api
+ kill_port_forward "$VOLTHA_NS" voltha-voltha-api
if is_in "$WITH_ETCD" "yes,external"; then
sspin "Remove port-forwards: etcd-$NAME$CEOL"
- kill_port_forward "etcd"
+ kill_port_forward "$INFRA_NS" "etcd"
fi
if is_in "$WITH_KAFKA" "yes,external"; then
sspin "Remove port-forwards: kafka-$NAME$CEOL"
- kill_port_forward "kafka"
+ kill_port_forward "$INFRA_NS" "kafka"
fi
if is_in "$WITH_BBSIM" "yes"; then
sspin "Remove port-forwards: bbsim$CEOL"
- kill_port_forward bbsim
+ kill_port_forward "$VOLTHA_NS" bbsim
fi
if [ "$WITH_PPROF" == "yes" ]; then
sspin "Remove port-forwards: *-profiler$CEOL"
- kill_port_forward voltha-rw-core-profiler voltha-voltha-rw-core-profiler
- kill_port_forward voltha-of-agent-profiler voltha-voltha-of-agent-profiler
+ kill_port_forward "$VOLTHA_NS" voltha-rw-core-profiler
+ kill_port_forward "$VOLTHA_NS" voltha-voltha-rw-core-profiler
+ kill_port_forward "$VOLTHA_NS" voltha-of-agent-profiler
+ kill_port_forward "$VOLTHA_NS" voltha-voltha-of-agent-profiler
if [ "$WITH_OPEN_ADAPTERS" == "yes" ]; then
- kill_port_forward adapter-open-olt-profiler open-olt-adapter-open-olt-profiler
+ kill_port_forward "$VOLTHA_NS" adapter-open-olt-profiler
+ kill_port_forward "$VOLTHA_NS" open-olt-adapter-open-olt-profiler
fi
fi
if [ "$WITH_TRACING" == "yes" ]; then
sspin "Remove port-forwards: tracing-$NAME$CEOL"
VOLTHA_TRACING_CHART_NAME=$(resolve_chart_name "$VOLTHA_TRACING_CHART")
- kill_port_forward "tracing-${VOLTHA_TRACING_CHART_NAME}-jaeger-gui"
+ kill_port_forward "$INFRA_NS" "tracing-${VOLTHA_TRACING_CHART_NAME}-jaeger-gui"
fi
espin "$VERIFIED Remove port-forwards$CEOL"
@@ -1358,10 +1381,10 @@
fi
done
-# Force remove any existing k8s port-forward processes. This will
-# remove them for all kind clusters.
+# Remove everything we created and set
if [ "$1" == "clean" ]; then
- kill_port_forward __ALL__
+ echo "Cleaning up the system"
+ kill_port_forward all-namespaces __ALL__
exit
fi
@@ -1494,6 +1517,8 @@
espin "$INDENT" "$VERIFIED"
}
+bspin "Installing VOLTHA: $NAME $GEAR"
+espin "$VERIFIED"
echo "INSTALL NAME: $NAME" >> "$LOG"
STIME="$(date +%s)"
@@ -1823,7 +1848,6 @@
incubator|https://kubernetes-charts-incubator.storage.googleapis.com|Google_Incubator \
onos|https://charts.onosproject.org|ONF_ONOS \
atomix|https://charts.atomix.io|ONF_Atomix \
- bbsim-sadis|https://ciena.github.io/bbsim-sadis-server/charts|Custom_BBSIM_SADIS_Server \
elastic|https://helm.elastic.co|Elastic \
kiwigrid|https://kiwigrid.github.io|Fluentd-ElasticSearch\
bitnami|https://charts.bitnami.com/bitnami|Bitnami"
@@ -1947,7 +1971,7 @@
fi
if [ "$JUST_K8S" == "yes" ]; then
- echo "Environment deployed, not deploying VOLTHA artifacts as requested. Good bye."
+ echo "Environment deployed, not deploying VOLTHA artifacts as requested. Good bye." | tee -a "$LOG"
echo ""
echo "Please issue the following commands in your terminal to ensure that you" | tee -a "$LOG"
echo "are accessing the correct Kubernetes/Kind cluster as well as have the " | tee -a "$LOG"
@@ -1988,6 +2012,13 @@
fi
fi
+if [ "$WITH_ETCD" == "yes" ] && [ "$WITH_PORT_FORWARDS" == "yes" ]; then
+ bspin - "Forward VOLTHA ETCD port $FORWARD"
+ kill_port_forward "$INFRA_NS" "etcd"
+ port_forward "$INFRA_NS" "etcd" "$VOLTHA_ETCD_PORT:2379"
+ espin - "$VERIFIED"
+fi
+
if is_in "$WITH_KAFKA" "yes,external"; then
_TMP="$(mktemp -u)"
cat << EOC > "$_TMP"
@@ -2020,6 +2051,14 @@
printtime $((NOW - STIME))
fi
rm -rf "$_TMP"
+
+fi
+
+if [ "$WITH_KAFKA" == "yes" ] && [ "$WITH_PORT_FORWARDS" == "yes" ]; then
+ bspin - "Forward VOLTHA Kafka port $FORWARD"
+ kill_port_forward "$INFRA_NS" "kafka"
+ port_forward "$INFRA_NS" kafka "$VOLTHA_KAFKA_PORT:9092"
+ espin - "$VERIFIED"
fi
@@ -2038,11 +2077,11 @@
if [ "$WITH_PORT_FORWARDS" == "yes" ]; then
bspin - "Forward ONOS API port $FORWARD"
- kill_port_forward onos-ui
+ kill_port_forward "$INFRA_NS" onos-ui
port_forward "$INFRA_NS" onos-ui "$ONOS_API_PORT:8181"
espin - "$VERIFIED"
bspin - "Forward ONOS SSH port $FORWARD"
- kill_port_forward onos-ssh
+ kill_port_forward "$INFRA_NS" onos-ssh
port_forward "$INFRA_NS" onos-ssh "$ONOS_SSH_PORT:8101"
espin - "$VERIFIED"
_ONOS_API_EP="127.0.0.1:$ONOS_API_PORT"
@@ -2090,21 +2129,24 @@
espin "$VERIFIED"
fi
wait_for_pods - "$INFRA_NS" $((NUM_OF_ONOS + NUM_OF_ATOMIX)) "includes" "Waiting for ONOS CLASSIC to start" "$NO_LABEL" "onos-.*"
- if [ "$WITH_PORT_FORWARDS" == "yes" ]; then
- bspin - "Forward ONOS API port $FORWARD"
- kill_port_forward onos-onos-classic-hs
- port_forward "$INFRA_NS" onos-onos-classic-hs "$ONOS_API_PORT:8181" "$ONOS_SSH_PORT:8101"
- espin - "$VERIFIED"
- _ONOS_API_EP="127.0.0.1:$ONOS_API_PORT"
- else
- _ONOS_API_EP="$(get_service_ep "$INFRA_NS" onos-onos-classic-hs)"
- fi
elif [ "$WITH_ONOS" == "micro" ]; then
bspin "Verify micro-ONOS installed $BIRD"
# We should never get here
>&2 echo -e "${RED}${BOLD}${ERROR}ERROR:${NORMAL}${RED} Micro ONOS not currently supported${NORMAL}"
exit 1
fi
+
+ if is_in "$WITH_ONOS" "yes,classic" && [ "$WITH_PORT_FORWARDS" == "yes" ]; then
+ bspin - "Forward ONOS API port $FORWARD"
+ SVC=
+ kill_port_forward "$INFRA_NS" onos-onos-classic-hs
+ port_forward "$INFRA_NS" onos-onos-classic-hs "$ONOS_API_PORT:8181" "$ONOS_SSH_PORT:8101"
+ espin - "$VERIFIED"
+ _ONOS_API_EP="127.0.0.1:$ONOS_API_PORT"
+ else
+ _ONOS_API_EP="$(get_service_ep "$INFRA_NS" onos-onos-classic-hs)"
+ fi
+
bspin - "Verify or download ONOS configuration support files $DOWNLOAD"
ONOS_FILES="olt-onos-enableExtraneousRules.json onos-aaa.json \
onos-dhcpl2relay.json onos-sadis-sample.json"
@@ -2270,6 +2312,145 @@
printtime $((NOW - STIME))
fi
+if [ "$WITH_RADIUS" == "yes" ]; then
+ STIME="$(date +%s)"
+ echo -e "Verify RADIUS $LOCK"
+ bspin - "Verify RADIUS Installed"
+ if [ "$HELM_USE_UPGRADE" == "yes" ] || [ "$(helm_is_deployed "$INFRA_NS" "^radius\$")" -ne 1 ]; then
+ espin - "$NOT_VERIFIED"
+ helm_install - "$INFRA_NS" radius "$RADIUS_CHART" "$RADIUS_CHART_VERSION" "+radius" "$_HELM_DESC RADIUS"
+ else
+ espin - "$VERIFIED"
+ fi
+ wait_for_pods - "$INFRA_NS" 1 "includes" "Waiting for RADIUS to start" "$NO_LABEL" "radius-.*"
+ if [ "$WITH_TIMINGS" == "yes" ]; then
+ NOW="$(date +%s)"
+ printtime $((NOW - STIME))
+ fi
+fi
+
+if is_in "$WITH_ONOS" "yes,legacy,classic" && [ "$WITH_RADIUS" != "no" ]; then
+ SVC_NAME=radius
+ if kubectl get -n "$INFRA_NS" "svc/radius-freeradius" >/dev/null 2>&1; then
+ SVC_NAME="radius-freeradius"
+ fi
+ _HOST="$SVC_NAME.$INFRA_NS.svc"
+ _PORT=1812
+ if [ "$WITH_RADIUS" != "yes" ]; then
+ _HOST="$(echo "$WITH_RADIUS" | cut -d: -f1)"
+ _PORT="$(echo "$WITH_RADIUS" | cut -s -d: -f2)"
+ _PORT=${_PORT:-1812}
+ fi
+ bspin "Configure ONOS RADIUS Connection $GEAR"
+ (set -x; sed -e "s/:RADIUS_SVC:/$_HOST/g" -e "s/:RADIUS_PORT:/$_PORT/" onos-files/onos-aaa.json | curl --fail -sSL --user karaf:karaf -X POST "http://$_ONOS_API_EP/onos/v1/network/configuration/apps/org.opencord.aaa" -H Content-type:application/json -d@- >>"$LOG" 2>&1) >>"$LOG" 2>&1
+ espin "$VERIFIED"
+fi
+
+if [ "$CONFIG_SADIS" == "external" ]; then
+ STIME="$(date +%s)"
+ echo -e "Verify BBSIM SADIS Service $PLUG"
+ bspin - "Verify required configmap"
+ (set -x; kubectl -n "$INFRA_NS" delete --ignore-not-found configmap kube-config >>"$LOG" 2>&1) >>"$LOG" 2>&1
+ (set -x; kubectl -n "$INFRA_NS" create configmap kube-config "--from-file=kube_config=$KUBECONFIG" >>"$LOG" 2>&1) >>"$LOG" 2>&1
+ espin - "$VERIFIED"
+ bspin - "Verify BBSIM SADIS Service Installed"
+ if [ "$HELM_USE_UPGRADE" == "yes" ] || [ "$(helm_is_deployed "$INFRA_NS" "^bbsim-sadis-server\$")" -ne 1 ]; then
+ espin - "$NOT_VERIFIED"
+ INTERNAL_EXTRA_HELM_INSTALL_ARGS="$EXTRA_HELM_FLAGS" helm_install - "$INFRA_NS" bbsim-sadis-server "$BBSIM_SADIS_SERVER_CHART" "$BBSIM_SADIS_SERVER_CHART_VERSION" "+sadis" "$_HELM_DESC BBSIM SADIS Server"
+ INTERNAL_EXTRA_HELM_INSTALL_ARGS=
+ else
+ espin - "$VERIFIED"
+ fi
+ wait_for_pods - "$INFRA_NS" 1 "includes" "Waiting for BBSIM SADIS Server to start" "$NO_LABEL" "bbsim-sadis-server-.*"
+
+ if is_in "$WITH_ONOS" "yes,classic,legacy"; then
+ if kubectl get -n "$INFRA_NS" svc/bbsim-sadis-server-bbsim-sadis-server >/dev/null 2>&1; then
+ BBSIM_SADIS_SVC="bbsim-sadis-server-bbsim-sadis-server"
+ else
+ BBSIM_SADIS_SVC="bbsim-sadis-server"
+ fi
+ push_onos_config "json" \
+ "[optional] Push ONOS configuration for custom SADIS and Bandwidth Profile servers" \
+ "network/configuration/apps/org.opencord.sadis" \
+ "$(cat <<EOJ | tr -d '[:space:]'
+{
+ "sadis": {
+ "integration": {
+ "url": "http://$BBSIM_SADIS_SVC.$INFRA_NS.svc:58080/subscribers/%s",
+ "cache": {
+ "enabled": true,
+ "maxsize": 50,
+ "ttl": "PT1m"
+ }
+ }
+ },
+ "bandwidthprofile": {
+ "integration": {
+ "url": "http://$BBSIM_SADIS_SVC.$INFRA_NS.svc:58080/profiles/%s",
+ "cache": {
+ "enabled": true,
+ "maxsize": 50,
+ "ttl": "PT1m"
+ }
+ }
+ }
+}
+EOJ
+)"
+ fi
+ if [ "$WITH_TIMINGS" == "yes" ]; then
+ NOW="$(date +%s)"
+ printtime $((NOW - STIME))
+ fi
+fi
+
+if [ "$WITH_EFK" == "yes" ]; then
+ STIME="$(date +%s)"
+ echo -e "Verify EFK $PLUG"
+ bspin - "Verify EFK Installed"
+ if [ "$HELM_USE_UPGRADE" == "yes" ] || [ "$(helm_is_deployed "$INFRA_NS" "^elasticsearch\$")" -ne 1 ] || [ "$(helm_is_deployed "$INFRA_NS" "^kibana\$")" -ne 1 ] || [ "$(helm_is_deployed "$INFRA_NS" "^fluentd\$")" -ne 1 ]; then
+ espin - "$NOT_VERIFIED"
+ if [ "$HELM_USE_UPGRADE" == "yes" ] || [ "$(helm_is_deployed "$INFRA_NS" "^elasticsearch\$")" -ne 1 ]; then
+ helm_install - "$INFRA_NS" elasticsearch "$ELASTICSEARCH_CHART" "$ELASTICSEARCH_CHART_VERSION" elasticsearch "$_HELM_DESC elasticsearch"
+ fi
+ if [ "$HELM_USE_UPGRADE" == "yes" ] || [ "$(helm_is_deployed "$INFRA_NS" "^kibana\$")" -ne 1 ]; then
+ helm_install - "$INFRA_NS" kibana "$KIBANA_CHART" "$KIBANA_CHART_VERSION" kibana "$_HELM_DESC kibana"
+ fi
+ if [ "$HELM_USE_UPGRADE" == "yes" ] || [ "$(helm_is_deployed "$INFRA_NS" "^fluentd\$")" -ne 1 ]; then
+ helm_install - "$INFRA_NS" fluentd "$FLUENTD_ELASTICSEARCH_CHART" "$FLUENTD_ELASTICSEARCH_CHART_VERSION" fluentd-elasticsearch "$_HELM_DESC fluentd-elasticsearch"
+ fi
+ else
+ espin - "$VERIFIED"
+ fi
+ EXPECT=2 # for elastic and kibana
+ if [ "$TYPE" == "minimal" ]; then
+ EXPECT=$((EXPECT + 2)) # for fluentd on worker 2 worker nodes
+ else
+ EXPECT=$((EXPECT + 3)) # for fluentd on worker 3 worker nodes
+ fi
+ if [ "$SCHEDULE_ON_CONTROL_NODES" == "yes" ]; then
+ EXPECT=$((EXPECT + 1)) # for fluentd on the control plan node
+ fi
+
+ wait_for_pods - "$INFRA_NS" "$EXPECT" "includes" "Waiting for EFK to start" "$NO_LABEL" "fluentd-* elasticsearch-* kibana-*"
+
+ if [ "$WITH_PORT_FORWARDS" == "yes" ]; then
+ bspin - "Forward EFK port $FORWARD"
+ kill_port_forward "$INFRA_NS" elasticsearch-master
+ kill_port_forward "$INFRA_NS" kibana-kibana
+ port_forward "$INFRA_NS" elasticsearch-master "$ELASTICSEARCH_PORT:9200"
+ port_forward "$INFRA_NS" kibana-kibana "$KIBANA_PORT:5601"
+ espin - "$VERIFIED"
+ fi
+
+ do_curl "" "POST" "" "" "http://localhost:$KIBANA_PORT/api/saved_objects/index-pattern/logst*" "json" '{"attributes":{"title":"logst*","timeFieldName":"@timestamp"}}' "Verify logging index in EFK" "409,200" "-H Content-type:application/json -H kbn-xsrf:true" "$GEAR"
+
+ if [ "$WITH_TIMINGS" == "yes" ]; then
+ NOW="$(date +%s)"
+ printtime $((NOW - STIME))
+ fi
+fi
+
if [ "$WITH_TRACING" == "yes" ]; then
STIME="$(date +%s)"
echo -e "Verify Jaeger Tracing $PLUG"
@@ -2282,16 +2463,77 @@
espin - "$VERIFIED"
fi
wait_for_pods - "$INFRA_NS" 1 "includes" "Waiting for Jaeger Tracing to start" "$NO_LABEL" "jaeger*"
+
+ if [ "$WITH_PORT_FORWARDS" == "yes" ]; then
+ bspin - "Forward VOLTHA Tracing GUI port $FORWARD"
+ VOLTHA_TRACING_CHART_NAME=$(resolve_chart_name "$VOLTHA_TRACING_CHART")
+ kill_port_forward "$INFRA_NS" "tracing-${VOLTHA_TRACING_CHART_NAME}-jaeger-gui"
+ port_forward "$INFRA_NS" "tracing-${VOLTHA_TRACING_CHART_NAME}-jaeger-gui" "$TRACING_GUI_PORT:16686"
+ espin - "$VERIFIED"
+ fi
+
if [ "$WITH_TIMINGS" == "yes" ]; then
NOW="$(date +%s)"
printtime $((NOW - STIME))
fi
fi
+if [ "$JUST_INFRA" == "yes" ]; then
+ echo "Infrastructure deployed, not deploying VOLTHA artifacts as requested. Good bye." | tee -a "$LOG"
+ echo ""
+ echo "Please issue the following commands in your terminal to ensure that you" | tee -a "$LOG"
+ echo "are accessing the correct Kubernetes/Kind cluster as well as have the " | tee -a "$LOG"
+ echo "tools required by VOLTHA in your command path. " | tee -a "$LOG"
+ echo "" | tee -a "$LOG"
+
+ echo -en "$BOLD"
+ if [ "$DEPLOY_K8S" == "yes" ]; then
+ echo "export KUBECONFIG=\"$HOME/.kube/kind-config-voltha-$NAME\"" | tee -a "$LOG"
+ fi
+ echo "export VOLTCONFIG=\"$HOME/.volt/config-$NAME\"" | tee -a "$LOG"
+ echo "export PATH=$GOPATH/bin:\$PATH" | tee -a "$LOG"
+ echo " "
+ echo -en "$NORMAL"
+ echo "To configure your VOLTHA stack to use this infrastructure please export these variables:" | tee -a "$LOG"
+ echo -en "$BOLD"
+ echo " export INFRA_NS=$INFRA_NS"
+ echo " export WITH_ETCD=etcd.$INFRA_NS.svc:2379"
+ echo " export WITH_KAFKA=kafka.$INFRA_NS.svc:9092"
+ echo " export WITH_ONOS=onos-onos-classic-hs.$INFRA_NS.svc:6653"
+ echo -en "$NORMAL"
+ echo " "
+ echo "Or use:"
+ echo " "
+ echo -en "$BOLD"
+ echo " INFRA_NS=$INFRA_NS WITH_ETCD=etcd.$INFRA_NS.svc:2379 WITH_KAFKA=kafka.$INFRA_NS.svc:9092 WITH_ONOS=onos-onos-classic-hs.$INFRA_NS.svc:6653 ./voltha up"
+ echo -en "$NORMAL"
+ echo " "
+ echo "If you are deploying mutltiple VOLTHA stack, also remember to configure a different NAME, NAMESPACE and BBSIM_BASE_INDEX for each stack:"
+ echo -en "$BOLD"
+ echo " export NAME=voltha1"
+ echo " export VOLTHA_NS=voltha1"
+ echo " export ADAPTER_NS=voltha1"
+ echo " export BBSIM_NS=voltha1"
+ echo " export BBSIM_BASE_INDEX=1"
+ echo -en "$NORMAL"
+ echo " "
+ echo "Or use:"
+ echo " "
+ echo -en "$BOLD"
+ echo " INFRA_NS=$INFRA_NS WITH_ETCD=etcd.$INFRA_NS.svc:2379 WITH_KAFKA=kafka.$INFRA_NS.svc:9092 WITH_ONOS=onos-onos-classic-hs.$INFRA_NS.svc:6653" \
+ "NAME=voltha1 VOLTHA_NS=voltha1 ADAPTER_NS=voltha1 BBSIM_NS=voltha1 BBSIM_BASE_INDEX=1 ./voltha up"
+ echo -en "$NORMAL"
+ exit 0
+fi
+
STIME="$(date +%s)"
EXPECT=2
# therecanbeonlyone set hardcoded to true for backward compatibility
INTERNAL_EXTRA_HELM_INSTALL_ARGS="--set therecanbeonlyone=true"
+
+# customize the topics in case of multiple stacks sharing the same kafka
+INTERNAL_EXTRA_HELM_INSTALL_ARGS+=" --set defaults.topics.core_topic=$NAME-rwcore,defaults.kv_store_data_prefix=service/$NAME"
+
case $WITH_ETCD in
no)
;;
@@ -2380,6 +2622,7 @@
if [ "$WITH_ADAPTERS" == "yes" ]; then
STIME="$(date +%s)"
EXPECT=0
+ INTERNAL_EXTRA_HELM_INSTALL_ARGS+=" --set defaults.topics.core_topic=$NAME-rwcore,defaults.topics.adapter_open_olt_topic=$NAME-openolt,defaults.topics.adapter_open_onu_topic=$NAME-brcm_openomci_onu,defaults.kv_store_data_prefix=service/$NAME"
if is_in "$WITH_ETCD" "yes,external"; then
_HOST=etcd.$INFRA_NS.svc
_PORT=2379
@@ -2460,6 +2703,7 @@
STIME="$(date +%s)"
echo -e "Verify BBSIM $PLUG"
bspin - "Verify BBSIM Installed"
+
for instance in $(seq 0 $((NUM_OF_BBSIM-1))); do
if [ "$LEGACY_BBSIM_INDEX" == "yes" ]; then
@@ -2483,8 +2727,7 @@
_TAG="$((900+instance))"
BBSIM_TMP="$(mktemp -u)"
sed -e "s/\":TAG:\"/$_TAG/g" "$BBSIM_CFG" > "$BBSIM_TMP"
-
- INTERNAL_EXTRA_HELM_INSTALL_ARGS="--set olt_id=$instance -f $BBSIM_TMP"
+ INTERNAL_EXTRA_HELM_INSTALL_ARGS="--set olt_id=$BBSIM_BASE_INDEX$instance -f $BBSIM_TMP"
else
# these are older versio of BBSim
S_TAG="$((900+instance))"
@@ -2522,7 +2765,7 @@
if [ "$WITH_PORT_FORWARDS" == "yes" ]; then
for instance in $(seq 0 $((NUM_OF_BBSIM-1))); do
bspin - "Forward BBSIM DMI port $FORWARD"
- kill_port_forward "bbsim"
+ kill_port_forward "$BBSIM_NS" "bbsim${instance}"
_PORT=$((50075+instance))
port_forward "$BBSIM_NS" "bbsim${instance}" "50075:$_PORT"
espin - "$VERIFIED"
@@ -2535,120 +2778,11 @@
fi
fi
-if [ "$WITH_EFK" == "yes" ]; then
- STIME="$(date +%s)"
- echo -e "Verify EFK $PLUG"
- bspin - "Verify EFK Installed"
- if [ "$HELM_USE_UPGRADE" == "yes" ] || [ "$(helm_is_deployed "$INFRA_NS" "^elasticsearch\$")" -ne 1 ] || [ "$(helm_is_deployed "$INFRA_NS" "^kibana\$")" -ne 1 ] || [ "$(helm_is_deployed "$INFRA_NS" "^fluentd\$")" -ne 1 ]; then
- espin - "$NOT_VERIFIED"
- if [ "$HELM_USE_UPGRADE" == "yes" ] || [ "$(helm_is_deployed "$INFRA_NS" "^elasticsearch\$")" -ne 1 ]; then
- helm_install - "$INFRA_NS" elasticsearch "$ELASTICSEARCH_CHART" "$ELASTICSEARCH_CHART_VERSION" elasticsearch "$_HELM_DESC elasticsearch"
- fi
- if [ "$HELM_USE_UPGRADE" == "yes" ] || [ "$(helm_is_deployed "$INFRA_NS" "^kibana\$")" -ne 1 ]; then
- helm_install - "$INFRA_NS" kibana "$KIBANA_CHART" "$KIBANA_CHART_VERSION" kibana "$_HELM_DESC kibana"
- fi
- if [ "$HELM_USE_UPGRADE" == "yes" ] || [ "$(helm_is_deployed "$INFRA_NS" "^fluentd\$")" -ne 1 ]; then
- helm_install - "$INFRA_NS" fluentd "$FLUENTD_ELASTICSEARCH_CHART" "$FLUENTD_ELASTICSEARCH_CHART_VERSION" fluentd-elasticsearch "$_HELM_DESC fluentd-elasticsearch"
- fi
- else
- espin - "$VERIFIED"
- fi
- EXPECT=2 # for elastic and kibana
- if [ "$TYPE" == "minimal" ]; then
- EXPECT=$((EXPECT + 2)) # for fluentd on worker 2 worker nodes
- else
- EXPECT=$((EXPECT + 3)) # for fluentd on worker 3 worker nodes
- fi
- if [ "$SCHEDULE_ON_CONTROL_NODES" == "yes" ]; then
- EXPECT=$((EXPECT + 1)) # for fluentd on the control plan node
- fi
-
- wait_for_pods - "$INFRA_NS" "$EXPECT" "includes" "Waiting for EFK to start" "$NO_LABEL" "fluentd-* elasticsearch-* kibana-*"
- if [ "$WITH_TIMINGS" == "yes" ]; then
- NOW="$(date +%s)"
- printtime $((NOW - STIME))
- fi
-fi
-
-if [ "$CONFIG_SADIS" == "external" ]; then
- STIME="$(date +%s)"
- echo -e "Verify BBSIM SADIS Service $PLUG"
- bspin - "Verify required configmap"
- (set -x; kubectl -n "$BBSIM_NS" delete --ignore-not-found configmap kube-config >>"$LOG" 2>&1) >>"$LOG" 2>&1
- (set -x; kubectl -n "$BBSIM_NS" create configmap kube-config "--from-file=kube_config=$KUBECONFIG" >>"$LOG" 2>&1) >>"$LOG" 2>&1
- espin - "$VERIFIED"
- bspin - "Verify BBSIM SADIS Service Installed"
- if [ "$HELM_USE_UPGRADE" == "yes" ] || [ "$(helm_is_deployed "$BBSIM_NS" "^bbsim-sadis-server\$")" -ne 1 ]; then
- espin - "$NOT_VERIFIED"
- INTERNAL_EXTRA_HELM_INSTALL_ARGS="$EXTRA_HELM_FLAGS" helm_install - "$BBSIM_NS" bbsim-sadis-server "$BBSIM_SADIS_SERVER_CHART" "$BBSIM_SADIS_SERVER_CHART_VERSION" "+sadis" "$_HELM_DESC BBSIM SADIS Server"
- INTERNAL_EXTRA_HELM_INSTALL_ARGS=
- else
- espin - "$VERIFIED"
- fi
- wait_for_pods - "$BBSIM_NS" 1 "includes" "Waiting for BBSIM SADIS Server to start" "$NO_LABEL" "bbsim-sadis-server-.*"
-
- if is_in "$WITH_ONOS" "yes,classic,legacy"; then
- if kubectl get -n "$BBSIM_NS" svc/bbsim-sadis-server-bbsim-sadis-server >/dev/null 2>&1; then
- BBSIM_SADIS_SVC="bbsim-sadis-server-bbsim-sadis-server"
- else
- BBSIM_SADIS_SVC="bbsim-sadis-server"
- fi
- push_onos_config "json" \
- "[optional] Push ONOS configuration for custom SADIS and Bandwidth Profile servers" \
- "network/configuration/apps/org.opencord.sadis" \
- "$(cat <<EOJ | tr -d '[:space:]'
-{
- "sadis": {
- "integration": {
- "url": "http://$BBSIM_SADIS_SVC.$BBSIM_NS.svc:58080/subscribers/%s",
- "cache": {
- "enabled": true,
- "maxsize": 50,
- "ttl": "PT1m"
- }
- }
- },
- "bandwidthprofile": {
- "integration": {
- "url": "http://$BBSIM_SADIS_SVC.$BBSIM_NS.svc:58080/profiles/%s",
- "cache": {
- "enabled": true,
- "maxsize": 50,
- "ttl": "PT1m"
- }
- }
- }
-}
-EOJ
-)"
- fi
- if [ "$WITH_TIMINGS" == "yes" ]; then
- NOW="$(date +%s)"
- printtime $((NOW - STIME))
- fi
-fi
-
-if [ "$WITH_RADIUS" == "yes" ]; then
- STIME="$(date +%s)"
- echo -e "Verify RADIUS $LOCK"
- bspin - "Verify RADIUS Installed"
- if [ "$HELM_USE_UPGRADE" == "yes" ] || [ "$(helm_is_deployed "$INFRA_NS" "^radius\$")" -ne 1 ]; then
- espin - "$NOT_VERIFIED"
- helm_install - "$INFRA_NS" radius "$RADIUS_CHART" "$RADIUS_CHART_VERSION" "+radius" "$_HELM_DESC RADIUS"
- else
- espin - "$VERIFIED"
- fi
- wait_for_pods - "$INFRA_NS" 1 "includes" "Waiting for RADIUS to start" "$NO_LABEL" "radius-.*"
- if [ "$WITH_TIMINGS" == "yes" ]; then
- NOW="$(date +%s)"
- printtime $((NOW - STIME))
- fi
-fi
-
if [ "$WITH_PORT_FORWARDS" == "yes" ]; then
STIME="$(date +%s)"
bspin - "Forward VOLTHA API port $FORWARD"
- kill_port_forward voltha-api voltha-voltha-api
+ kill_port_forward "$VOLTHA_NS" voltha-api
+ kill_port_forward "$VOLTHA_NS" voltha-voltha-api
VOLTHA_PREFIX=
if kubectl get -n "$VOLTHA_NS" "svc/voltha-voltha-api" >/dev/null 2>&1; then
VOLTHA_PREFIX="voltha-"
@@ -2656,75 +2790,30 @@
port_forward "$VOLTHA_NS" "${VOLTHA_PREFIX}voltha-api" "$VOLTHA_API_PORT:55555"
espin - "$VERIFIED"
- if is_in "$WITH_ETCD" "yes,external"; then
- bspin - "Forward VOLTHA ETCD port $FORWARD"
- kill_port_forward "etcd"
- port_forward "$INFRA_NS" "etcd" "$VOLTHA_ETCD_PORT:2379"
- espin - "$VERIFIED"
- fi
- if is_in "$WITH_KAFKA" "yes,external"; then
- bspin - "Forward VOLTHA Kafka port $FORWARD"
- kill_port_forward "kafka"
- port_forward "$INFRA_NS" kafka "$VOLTHA_KAFKA_PORT:9092"
- espin - "$VERIFIED"
- fi
- if [ "$WITH_EFK" == "yes" ]; then
- bspin - "Forward EFK port $FORWARD"
- kill_port_forward elasticsearch-master
- kill_port_forward kibana-kibana
- port_forward "$INFRA_NS" elasticsearch-master "$ELASTICSEARCH_PORT:9200"
- port_forward "$INFRA_NS" kibana-kibana "$KIBANA_PORT:5601"
- espin - "$VERIFIED"
- fi
+
if [ "$WITH_PPROF" == "yes" ]; then
VOLTHA_OPENOLT_PREFIX=
if kubectl get -n "$ADAPTER_NS" "svc/open-olt-adapter-open-olt-profiler" >/dev/null 2>&1; then
VOLTHA_OPENOLT_PREFIX="open-olt-"
fi
bspin - "Forward PProf ports port $FORWARD"
- kill_port_forward voltha-rw-core-profiler voltha-voltha-rw-core-profiler
- kill_port_forward adapter-open-olt-profiler open-olt-adapter-open-olt-profiler
- kill_port_forward voltha-of-agent-profiler voltha-voltha-of-agent-profiler
+ kill_port_forward "$VOLTHA_NS" voltha-rw-core-profiler
+ kill_port_forward "$VOLTHA_NS" voltha-voltha-rw-core-profiler
+ kill_port_forward "$VOLTHA_NS" adapter-open-olt-profiler
+ kill_port_forward "$VOLTHA_NS" open-olt-adapter-open-olt-profiler
+ kill_port_forward "$VOLTHA_NS" voltha-of-agent-profiler
+ kill_port_forward "$VOLTHA_NS" voltha-voltha-of-agent-profiler
port_forward "$VOLTHA_NS" "${VOLTHA_PREFIX}voltha-rw-core-profiler" "$VOLTHA_PPROF_PORT:6060"
port_forward "$ADAPTER_NS" "${VOLTHA_OPENOLT_PREFIX}adapter-open-olt-profiler" "$OPENOLT_PPROF_PORT:6060"
port_forward "$VOLTHA_NS" "${VOLTHA_PREFIX}voltha-of-agent-profiler" "$OFAGENT_PPROF_PORT:6060"
espin - "$VERIFIED"
fi
- if [ "$WITH_TRACING" == "yes" ]; then
- bspin - "Forward VOLTHA Tracing GUI port $FORWARD"
- VOLTHA_TRACING_CHART_NAME=$(resolve_chart_name "$VOLTHA_TRACING_CHART")
- kill_port_forward "tracing-${VOLTHA_TRACING_CHART_NAME}-jaeger-gui"
- port_forward "$INFRA_NS" "tracing-${VOLTHA_TRACING_CHART_NAME}-jaeger-gui" "$TRACING_GUI_PORT:16686"
- espin - "$VERIFIED"
- fi
if [ "$WITH_TIMINGS" == "yes" ]; then
NOW="$(date +%s)"
printtime $((NOW - STIME))
fi
fi
-if is_in "$WITH_ONOS" "yes,legacy,classic" && [ "$WITH_RADIUS" != "no" ]; then
- SVC_NAME=radius
- if kubectl get -n "$INFRA_NS" "svc/radius-freeradius" >/dev/null 2>&1; then
- SVC_NAME="radius-freeradius"
- fi
- _HOST="$SVC_NAME.$INFRA_NS.svc"
- _PORT=1812
- if [ "$WITH_RADIUS" != "yes" ]; then
- _HOST="$(echo "$WITH_RADIUS" | cut -d: -f1)"
- _PORT="$(echo "$WITH_RADIUS" | cut -s -d: -f2)"
- _PORT=${_PORT:-1812}
- fi
- bspin "Configure ONOS RADIUS Connection $GEAR"
- (set -x; sed -e "s/:RADIUS_SVC:/$_HOST/g" -e "s/:RADIUS_PORT:/$_PORT/" onos-files/onos-aaa.json | curl --fail -sSL --user karaf:karaf -X POST "http://$_ONOS_API_EP/onos/v1/network/configuration/apps/org.opencord.aaa" -H Content-type:application/json -d@- >>"$LOG" 2>&1) >>"$LOG" 2>&1
- espin "$VERIFIED"
-fi
-
-if [ "$WITH_EFK" == "yes" ]; then
- do_curl "" "POST" "" "" "http://localhost:$KIBANA_PORT/api/saved_objects/index-pattern/logst*" "json" '{"attributes":{"title":"logst*","timeFieldName":"@timestamp"}}' "Verify logging index in EFK" "409,200" "-H Content-type:application/json -H kbn-xsrf:true" "$GEAR"
-# fi
-fi
-
if [ "$WITH_CHAOS" == "yes" ]; then
STIME="$(date +%s)"
echo -e "Verify kube-monkey $LOCK"