-
Notifications
You must be signed in to change notification settings - Fork 0
/
entrypoint.sh
35 lines (30 loc) · 1.62 KB
/
entrypoint.sh
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
#!/bin/bash
set -e
if [ ! -z "$ELASTICSEARCH_URL" ]; then
: ${ELASTICSEARCH_URL:='http://elasticsearch:9200'}
sed -ri "s!^(\#\s*)?(elasticsearch\.url:).*!\2 '$ELASTICSEARCH_URL'!" /opt/kibi/config/kibi.yml
# Remove Auth Plugin
/opt/kibi/bin/kibi plugin -r kibana-auth-plugin
echo "Remote Server! No ES Logs available." > /var/log/elasticsearch/nolog.log
else
echo "No ES URL parameter, starting local instance... "
# Patch demo ES to listen to all interfaces using elasticfence authentication
echo "network.host: 0.0.0.0" >> /etc/elasticsearch/elasticsearch.yml
echo "elasticfence.disabled: false" >> /etc/elasticsearch/elasticsearch.yml
echo "elasticfence.root.password: elasticFence" >> /etc/elasticsearch/elasticsearch.yml
echo "elasticfence.whitelist: [\"127.0.0.1\", \"172.17.0.2\"]" >> /etc/elasticsearch/elasticsearch.yml
service elasticsearch start
sleep 8
# create admin user
curl "127.0.0.1:9200/_httpuserauth?mode=adduser&username=admin&password=elasticFence" -u root:elasticFence
curl "127.0.0.1:9200/_httpuserauth?mode=updateindex&username=admin&index=/.*" -u root:elasticFence
# load default dashboards
cd /usr/src/kibi-dashboards && ./load.sh -url 127.0.0.1:9200 -user root:elasticFence
fi
# Patch demo kibi to use standard ES port
perl -p -i -e "s/9220/9200/" /opt/kibi/config/kibi.yml
perl -p -i -e "s/localhost/0.0.0.0/" /opt/kibi/config/kibi.yml
perl -p -i -e "s/default_dashboard_title: Articles//" /opt/kibi/config/kibi.yml
# Start Kibi
/etc/init.d/kibi start
tail -f /var/log/elasticsearch/*.log