echo -e " --elk_stack: additionally deploy an ELK docker stack for event logging"
echo -e " --pm_stack: additionally deploy a Prometheus+Grafana stack for performance monitoring (PM)"
echo -e " -m <MODULE>: install OSM but only rebuild the specified docker images (RO, LCM, NBI, LW-UI, MON, KAFKA, MONGO, NONE)"
- echo -e " -o <ADDON>: do not install OSM, but ONLY one of the addons (vimemu, elk_stack, pm_stack) (assumes OSM is already installed)"
+ echo -e " -o <ADDON>: ONLY (un)installs one of the addons (vimemu, elk_stack, pm_stack)"
echo -e " -D <devops path> use local devops installation path"
echo -e " --nolxd: do not install and configure LXD, allowing unattended installations (assumes LXD is already installed and confifured)"
echo -e " --nodocker: do not install docker, do not initialize a swarm (assumes docker is already installed and a swarm has been initialized)"
#Uninstall lightweight OSM: remove dockers
function uninstall_lightweight() {
- echo -e "\nUninstalling lightweight OSM"
- remove_stack osm
- echo "Now osm docker images and volumes will be deleted"
- newgrp docker << EONG
- docker image rm osm/ro
- docker image rm osm/lcm
- docker image rm osm/light-ui
- docker image rm osm/nbi
- docker image rm osm/mon
- docker image rm osm/pm
- docker volume rm osm_mon_db
- docker volume rm osm_mongo_db
- docker volume rm osm_osm_packages
- docker volume rm osm_ro_db
+ if [ -n "$INSTALL_ONLY" ]; then
+ if [ -n "$INSTALL_ELK" ]; then
+ echo -e "\nUninstalling OSM ELK stack"
+ remove_stack osm_elk
+ sudo rm -rf /etc/osm/docker/osm_elk
+ fi
+ if [ -n "$INSTALL_PERFMON" ]; then
+ echo -e "\nUninstalling OSM Performance Monitoring stack"
+ remove_stack osm_metrics
+ sg docker -c "docker image rm osm/kafka-exporter"
+ sudo rm -rf /etc/osm/docker/osm_metrics
+ fi
+ else
+ echo -e "\nUninstalling OSM"
+ remove_stack osm
+ remove_stack osm_elk
+ remove_stack osm_metrics
+ echo "Now osm docker images and volumes will be deleted"
+ newgrp docker << EONG
+ docker image rm osm/ro
+ docker image rm osm/lcm
+ docker image rm osm/light-ui
+ docker image rm osm/nbi
+ docker image rm osm/mon
+ docker image rm osm/pm
+ docker image rm osm/kafka-exporter
+ docker volume rm osm_mon_db
+ docker volume rm osm_mongo_db
+ docker volume rm osm_osm_packages
+ docker volume rm osm_ro_db
EONG
- echo "Removing /etc/osm and /var/log/osm files"
- rm -rf /etc/osm
- rm -rf /var/log/osm
+ echo "Removing /etc/osm and /var/log/osm files"
+ sudo rm -rf /etc/osm
+ sudo rm -rf /var/log/osm
+ fi
+ echo "Some docker images will be kept in case they are used by other docker stacks"
+ echo "To remove them, just run 'docker image prune' in a terminal"
return 0
}
}
function deploy_elk() {
+ echo "Pulling docker images for ELK"
+ sg docker -c "docker pull docker.elastic.co/elasticsearch/elasticsearch-oss:6.2.3" || FATAL "cannot get elasticsearch docker image"
+ sg docker -c "docker pull docker.elastic.co/logstash/logstash-oss:6.2.3" || FATAL "cannot get logstash docker image"
+ sg docker -c "docker pull docker.elastic.co/kibana/kibana-oss:6.2.3" || FATAL "cannot get kibana docker image"
+ echo "Finished pulling elk docker images"
sudo mkdir -p /etc/osm/docker/osm_elk
sudo cp -b ${OSM_DEVOPS}/installers/docker/osm_elk/* /etc/osm/docker/osm_elk
remove_stack osm_elk
sg docker -c "docker stack deploy -c /etc/osm/docker/osm_elk/docker-compose.yml osm_elk"
echo "Waiting for ELK stack to be up and running"
time=0
- step=2
- timelength=20
+ step=5
+ timelength=40
elk_is_up=1
while [ $time -le $timelength ]; do
- if [[ $(curl -XGET http://127.0.0.1:5601/status -I | grep "HTTP/1.1 200 OK" | wc -l ) -eq 1 ]]; then
+ if [[ $(curl -f -XGET http://127.0.0.1:5601/status -I 2>/dev/null | grep "HTTP/1.1 200 OK" | wc -l ) -eq 1 ]]; then
elk_is_up=0
break
fi
#Create index pattern
curl -f -XPOST -H "Content-Type: application/json" -H "kbn-xsrf: anything" \
"http://127.0.0.1:5601/api/saved_objects/index-pattern/logstash-*" \
- -d"{\"attributes\":{\"title\":\"logstash-*\",\"timeFieldName\":\"@timestamp\"}}"
+ -d"{\"attributes\":{\"title\":\"logstash-*\",\"timeFieldName\":\"@timestamp\"}}" 2>/dev/null
#Make it the default index
- curl -XPOST -H "Content-Type: application/json" -H "kbn-xsrf: anything" \
+ curl -f -XPOST -H "Content-Type: application/json" -H "kbn-xsrf: anything" \
"http://127.0.0.1:5601/api/kibana/settings/defaultIndex" \
- -d"{\"value\":\"logstash-*\"}"
+ -d"{\"value\":\"logstash-*\"}" 2>/dev/null
else
echo "Cannot connect to Kibana to create index pattern."
echo "Once Kibana is running, you can use the following instructions to create index pattern:"
}
function deploy_perfmon() {
+ echo "Pulling docker images for PM (Grafana and Prometheus)"
+ sg docker -c "docker pull prom/prometheus" || FATAL "cannot get prometheus docker image"
+ sg docker -c "docker pull grafana/grafana" || FATAL "cannot get grafana docker image"
+ echo "Finished pulling PM docker images"
echo "Generating osm/kafka-exporter docker image"
sg docker -c "docker build ${OSM_DEVOPS}/installers/docker/osm_metrics/kafka-exporter -f ${OSM_DEVOPS}/installers/docker/osm_metrics/kafka-exporter/Dockerfile -t osm/kafka-exporter --no-cache" || FATAL "cannot build kafka-exporter docker image"
echo "Finished generation of osm/kafka-exporter docker image"
function install_lightweight() {
[ "$USER" == "root" ] && FATAL "You are running the installer as root. The installer is prepared to be executed as a normal user with sudo privileges."
[ -z "$ASSUME_YES" ] && ! ask_user "The installation will configure LXD, install juju, install docker CE and init a docker swarm, as pre-requirements. Do you want to proceed (Y/n)? " y && echo "Cancelled!" && exit 1
+ track proceed
echo "Installing lightweight build of OSM"
LWTEMPDIR="$(mktemp -d -q --tmpdir "installosmlight.XXXXXX")"
trap 'rm -rf "${LWTEMPDIR}"' EXIT
|| sudo apt-get install -y $need_packages_lw \
|| FATAL "failed to install $need_packages_lw"
fi
+ track prereqok
install_juju
OSMLCM_VCA_HOST=`sg lxd -c "juju show-controller"|grep api-endpoints|awk -F\' '{print $2}'|awk -F\: '{print $1}'`
OSMLCM_VCA_SECRET=`grep password ${HOME}/.local/share/juju/accounts.yaml |awk '{print $2}'`