aboutsummaryrefslogtreecommitdiffstats
path: root/container-core/src/main/sh/vespa-jvm-dumper
blob: 9b4e450611d55ec04d5ceb22c0844ca245da5b27 (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
119
120
121
122
123
#!/usr/bin/env bash
# Copyright Vespa.ai. 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##*/}
    empty_if_start_slash=${mypath%%/*}
    if [ "${empty_if_start_slash}" ]; then
        mypath=$(pwd)/${mypath}
    fi
    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
        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
}

findhost () {
    if [ "${VESPA_HOSTNAME}" = "" ]; then
        VESPA_HOSTNAME=$(vespa-detect-hostname || hostname -f || hostname || echo "localhost") || exit 1
    fi
    validate="${VESPA_HOME}/bin/vespa-validate-hostname"
    if [ -f "$validate" ]; then
        "$validate" "${VESPA_HOSTNAME}" || exit 1
    fi
    export VESPA_HOSTNAME
}

findroot
findhost

ROOT=${VESPA_HOME%/}
export ROOT

# END environment bootstrap section

set -euo pipefail

if [ $# -ne 2 ]; then
  echo "Usage: $0 <id> <output-directory>"
  echo ""
  vespa-sentinel-cmd list 2>/dev/null
  exit 1
fi

readonly service=$1
readonly output_directory=$2
if ! [ -d "${output_directory}" -a -w "${output_directory}" ]; then
  echo "Directory '${output_directory}' is not writable"
  exit 1
fi
jvm_pid=$(${VESPA_HOME}/libexec/vespa/find-pid "$service")
echo "Pid for '${service}' is '${jvm_pid}'"

echo "Creating heap dump"
readonly heap_dump_file=${output_directory}/jvm-heap-dump.hprof
if test -f "${heap_dump_file}"; then
    rm "${heap_dump_file}"
fi
jmap -dump:live,format=b,file=${heap_dump_file} ${jvm_pid}

echo "Trigger vespa-malloc to dump information to Vespa log"
kill -SIGPROF ${jvm_pid}

echo "Getting jmap information"
jhsdb jmap  --heap --pid ${jvm_pid} > ${output_directory}/jmap-output.txt

echo "Getting jstat information"
jstat -gcutil ${jvm_pid} > ${output_directory}/jstat-output.txt

echo "Getting jstack information"
jstack ${jvm_pid} > ${output_directory}/jstack-output.txt

echo "Getting pmap information"
pmap -x ${jvm_pid} | sort -nk3 | tail -10 > ${output_directory}/pmap-output.txt

echo "Copying vespa logs"
cp ${VESPA_HOME}/logs/vespa/vespa.log ${output_directory}/vespa.log

echo "Done!"