Simon Pasquier | d3a0b91 | 2017-05-02 15:32:20 +0200 | [diff] [blame] | 1 | #!/bin/bash -x |
| 2 | exec > >(tee -i /tmp/"$(basename "$0" .sh)"_"$(date '+%Y-%m-%d_%H-%M-%S')".log) 2>&1 |
| 3 | |
Simon Pasquier | e76e262 | 2017-05-15 15:04:47 +0200 | [diff] [blame] | 4 | CWD="$(dirname "$(readlink -f "$0")")" |
| 5 | |
| 6 | # Import common functions |
| 7 | COMMONS="$CWD"/common_functions.sh |
| 8 | if [ ! -f "$COMMONS" ]; then |
| 9 | echo "File $COMMONS does not exist" |
| 10 | exit 1 |
| 11 | fi |
| 12 | . "$COMMONS" |
| 13 | |
Simon Pasquier | f2b5a3b | 2017-06-06 17:32:21 +0200 | [diff] [blame] | 14 | INFLUXDB_SERVICE=$(salt -C 'I@influxdb:server' test.ping 1>/dev/null 2>&1 && echo true) |
| 15 | |
Simon Pasquier | d3a0b91 | 2017-05-02 15:32:20 +0200 | [diff] [blame] | 16 | # Configure Telegraf |
Simon Pasquier | 4a802be | 2017-06-29 12:54:50 +0200 | [diff] [blame] | 17 | salt -C 'I@telegraf:agent or I@telegraf:remote_agent' state.sls telegraf |
| 18 | |
Dmitry Kalashnik | 35af354 | 2017-07-13 14:09:39 +0400 | [diff] [blame] | 19 | # Configure Prometheus exporters |
| 20 | salt -C 'I@prometheus:exporters' state.sls prometheus |
| 21 | |
Simon Pasquier | 4a802be | 2017-06-29 12:54:50 +0200 | [diff] [blame] | 22 | # Configure log_collector |
| 23 | salt -C 'I@heka:log_collector' state.sls heka.log_collector |
Simon Pasquier | d3a0b91 | 2017-05-02 15:32:20 +0200 | [diff] [blame] | 24 | |
| 25 | # Configure Elasticsearch/Kibana services |
| 26 | salt -C 'I@elasticsearch:server' state.sls elasticsearch.server -b 1 |
| 27 | salt -C 'I@kibana:server' state.sls kibana.server -b 1 |
Simon Pasquier | d3a0b91 | 2017-05-02 15:32:20 +0200 | [diff] [blame] | 28 | salt -C 'I@elasticsearch:client' state.sls elasticsearch.client |
| 29 | salt -C 'I@kibana:client' state.sls kibana.client |
| 30 | |
Simon Pasquier | f2b5a3b | 2017-06-06 17:32:21 +0200 | [diff] [blame] | 31 | if [[ "$INFLUXDB_SERVICE" == "true" ]]; then |
| 32 | salt -C 'I@influxdb:server' state.sls influxdb |
| 33 | fi |
| 34 | |
Simon Pasquier | d3a0b91 | 2017-05-02 15:32:20 +0200 | [diff] [blame] | 35 | # Collect grains needed to configure the services |
| 36 | salt -C 'I@salt:minion' state.sls salt.minion.grains |
| 37 | salt -C 'I@salt:minion' saltutil.refresh_modules |
| 38 | salt -C 'I@salt:minion' mine.update |
| 39 | sleep 5 |
| 40 | |
Simon Pasquier | 4a802be | 2017-06-29 12:54:50 +0200 | [diff] [blame] | 41 | # Generate the configuration for services running in Docker Swarm |
| 42 | salt -C 'I@docker:swarm' state.sls prometheus,heka.remote_collector -b 1 |
| 43 | |
| 44 | # Kick off the services in Docker Swarm |
Simon Pasquier | d3a0b91 | 2017-05-02 15:32:20 +0200 | [diff] [blame] | 45 | salt -C 'I@docker:swarm:role:master' state.sls docker |
| 46 | salt -C 'I@docker:swarm' dockerng.ps |
Simon Pasquier | f853206 | 2017-05-04 11:58:41 +0200 | [diff] [blame] | 47 | |
Simon Pasquier | 4a802be | 2017-06-29 12:54:50 +0200 | [diff] [blame] | 48 | # Configure the Grafana dashboards and datasources |
Simon Pasquier | e76e262 | 2017-05-15 15:04:47 +0200 | [diff] [blame] | 49 | stacklight_vip=$(get_param_value stacklight_monitor_address) |
| 50 | wait_for_http_service "http://${stacklight_vip}:15013/" |
Simon Pasquier | f853206 | 2017-05-04 11:58:41 +0200 | [diff] [blame] | 51 | salt -C 'I@grafana:client' state.sls grafana.client |