-
Notifications
You must be signed in to change notification settings - Fork 8
/
logjam-prometheus-config
executable file
·80 lines (69 loc) · 2.2 KB
/
logjam-prometheus-config
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
#!/bin/bash
url="http://localhost"
scrape_url="localhost:8081"
included=""
streams=""
function usage() {
echo "$(basename $0) [ -i|--include streams to include ] [ -l|--logjam-url url ] [ -s|--scrape-url]"
echo "use -l to specify the logjam enpoint"
echo "use -i to specify a string which is used to select a subset of streams (substring match)"
echo "use -p to specify the srcaping endpoint"
exit 1
}
while true; do
case "$1" in
-i | --include ) included="$2"; shift 2 ;;
-l | --logjam-url ) url="$2"; shift 2 ;;
-s | --scrape-url ) scrape_url="$2"; shift 2 ;;
-h | --help ) usage ;;
* ) break ;;
esac
done
if [ "$included" == "" ]; then
streams=$(curl -s $url/admin/streams | jq -r 'keys | .[]')
else
streams=$(curl -s $url/admin/streams | jq -r 'keys | .[]' | grep "$included")
fi
if [ "$streams" == "" ]; then
echo "could not retrieve any streams from $url/admin/streams"
usage
fi
cat <<'EOF'
# my global config
global:
scrape_interval: 15s # Set the scrape interval to every 15 seconds. Default is every 1 minute.
evaluation_interval: 15s # Evaluate rules every 15 seconds. The default is every 1 minute.
# scrape_timeout is set to the global default (10s).
# Alertmanager configuration
alerting:
alertmanagers:
- static_configs:
- targets:
# - alertmanager:9093
# Load rules once and periodically evaluate them according to the global 'evaluation_interval'.
rule_files:
# - "first_rules.yml"
# - "second_rules.yml"
# A scrape configuration containing exactly one endpoint to scrape:
# Here it's Prometheus itself.
scrape_configs:
# The job name is added as a label `job=<job_name>` to any timeseries scraped from this config.
- job_name: 'prometheus'
# metrics_path defaults to '/metrics'
# scheme defaults to 'http'.
static_configs:
- targets: ['localhost:9090']
EOF
for stream in $streams; do
app=$(echo $stream | rev | cut -d'-' -f2- | rev)
env=$(echo $stream | awk -F '{print $NF}')
cat <<EOF
- job_name: '$stream'
scrape_interval: 60s
scrape_timeout: 60s
honor_labels: true
metrics_path: 'metrics/$app/$env'
static_configs:
- targets: ['$scrape_url']
EOF
done