aboutsummaryrefslogtreecommitdiffstats
path: root/node-admin/configserver-app/start-config-server.sh
blob: a592ec3cbd3e7018c677f9274697d6452fc8700c (plain) (blame)
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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
#!/bin/bash
# Copyright 2016 Yahoo Inc. Licensed under the terms of the Apache 2.0 license. See LICENSE in the project root.

# BEGIN environment bootstrap section
# Do not edit between here and END as this section should stay identical in all scripts

findpath () {
    myname=${0}
    mypath=${myname%/*}
    myname=${myname##*/}
    if [ "$mypath" ] && [ -d "$mypath" ]; then
        return
    fi
    mypath=$(pwd)
    if [ -f "${mypath}/${myname}" ]; then
        return
    fi
    echo "FATAL: Could not figure out the path where $myname lives from $0"
    exit 1
}

COMMON_ENV=libexec/vespa/common-env.sh

source_common_env () {
    if [ "$VESPA_HOME" ] && [ -d "$VESPA_HOME" ]; then
        # ensure it ends with "/" :
        VESPA_HOME=${VESPA_HOME%/}/
        export VESPA_HOME
        common_env=$VESPA_HOME/$COMMON_ENV
        if [ -f "$common_env" ]; then
            . $common_env
            return
        fi
    fi
    return 1
}

findroot () {
    source_common_env && return
    if [ "$VESPA_HOME" ]; then
        echo "FATAL: bad VESPA_HOME value '$VESPA_HOME'"
        exit 1
    fi
    if [ "$ROOT" ] && [ -d "$ROOT" ]; then
        VESPA_HOME="$ROOT"
        source_common_env && return
    fi
    findpath
    while [ "$mypath" ]; do
        VESPA_HOME=${mypath}
        source_common_env && return
        mypath=${mypath%/*}
    done
    echo "FATAL: missing VESPA_HOME environment variable"
    echo "Could not locate $COMMON_ENV anywhere"
    exit 1
}

findroot

# END environment bootstrap section

export LC_ALL=C

function VerifyRequiredEnvironmentVariablesAreSet {
    if [ -z "$HOSTED_VESPA_REGION" ]
    then
        Fail "Environment variable HOSTED_VESPA_REGION is not set"
    fi
    if [ -z "$CONFIG_SERVER_HOSTNAME" ]
    then
        Fail "Environment variable CONFIG_SERVER_HOSTNAME is not set"
    fi

    case "$HOSTED_VESPA_ENVIRONMENT" in
        prod|test|dev|staging|perf) : ;;
        *) Fail "The HOSTED_VESPA_ENVIRONMENT environment variable must be one of prod, test, dev, staging, or perf" ;;
    esac
}

function InternalMain {
    VerifyRequiredEnvironmentVariablesAreSet

    mkdir -p $VESPA_HOME/logs
    chmod 1777 $VESPA_HOME/logs
    mkdir -p $VESPA_HOME/logs/jdisc_core

    rm -rf $VESPA_HOME/var/vespa/bundlecache/standalone

    yinst set \
          cloudconfig_server.multitenant=true \
          cloudconfig_server.region="$HOSTED_VESPA_REGION" \
          cloudconfig_server.autostart=on \
          cloudconfig_server.default_flavor=docker \
          cloudconfig_server.environment="$HOSTED_VESPA_ENVIRONMENT" \
          cloudconfig_server.hosted_vespa=true \
          services.addr_configserver="$CONFIG_SERVER_HOSTNAME" \
          vespa_zkfacade.restrict=""

    # Can also set jvmargs if necessary:
    # set cloudconfig_server.jvmargs=-Dvespa.freezedetector.disable=true -XX:NewRatio=1 -verbose:gc -XX:+PrintGCDateStamps -agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=5005 -Xms6g -Xmx6g

    yinst start cloudconfig_server

    touch $VESPA_HOME/logs/jdisc_core/jdisc_core.log
    $VESPA_HOME/bin/logfmt -N -f $VESPA_HOME/logs/jdisc_core/jdisc_core.log
}

function Main {
    # Prefix each line to stdout/stderr with a timestamp to make it easier to
    # understand the progress.
    InternalMain |& while read -r
    do
        printf "%s %s\n" "$(date +%FT%T)" "$REPLY"
    done
}

Main "$@"