forked from apache/geode
-
Notifications
You must be signed in to change notification settings - Fork 0
/
capture-call-stacks.sh
executable file
·95 lines (77 loc) · 3.38 KB
/
capture-call-stacks.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
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
#!/usr/bin/env bash
#
# Licensed to the Apache Software Foundation (ASF) under one or more
# contributor license agreements. See the NOTICE file distributed with
# this work for additional information regarding copyright ownership.
# The ASF licenses this file to You under the Apache License, Version 2.0
# (the "License"); you may not use this file except in compliance with
# the License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#
export TERM=${TERM:-dumb}
export PAGER=cat
SOURCE="${BASH_SOURCE[0]}"
while [ -h "$SOURCE" ]; do # resolve $SOURCE until the file is no longer a symlink
SCRIPTDIR="$( cd -P "$( dirname "$SOURCE" )" && pwd )"
SOURCE="$(readlink "$SOURCE")"
[[ $SOURCE != /* ]] && SOURCE="$DIR/$SOURCE" # if $SOURCE was a relative symlink, we need to resolve it relative to the path where the symlink file was located
done
SCRIPTDIR="$( cd -P "$( dirname "$SOURCE" )" && pwd )"
export GEODE_BUILD=~/geode
export CALLSTACKS_DIR=${GEODE_BUILD}/callstacks
#SLEEP_TIME is in seconds
PARALLEL_DUNIT=${1}
SLEEP_TIME=${2}
COUNT=3
STACK_INTERVAL=5
if [[ -z "${PARALLEL_DUNIT}" ]]; then
echo "PARALLEL_DUNIT must be set. exiting..."
exit 1
fi
if [[ -z "${SLEEP_TIME}" ]]; then
echo "SLEEP_TIME must be set. exiting..."
exit 1
fi
mkdir -p ${CALLSTACKS_DIR}
sleep ${SLEEP_TIME}
echo "Capturing call stacks"
for (( h=0; h<${COUNT}; h++)); do
today=`date +%Y-%m-%d-%H-%M-%S`
logfile=${CALLSTACKS_DIR}/callstacks-${today}.txt
# Capture call stacks from each Java process
mapfile -t processes < <(jps | cut -d ' ' -f 1)
echo "Got past processes."
[ -x $JAVA_HOME/bin/jstack ] && JSTACK=$JAVA_HOME/bin/jstack || JSTACK=jstack
for ((j=0; j<${#processes[@]}; j++ )); do
echo "********* Dumping stack for process ${processes[j]}:" | tee -a ${logfile}
$JSTACK -l ${processes[j]} >> ${logfile}
done
# Capture call stacks from each Java process running in a Docker container
mapfile -t containers < <(docker ps --format '{{.Names}}')
for (( i=0; i<${#containers[@]}; i++ )); do
echo "Container: ${containers[i]}" | tee -a ${logfile};
[ -x $JAVA_HOME/bin/jps ] && JPS=$JAVA_HOME/bin/jps || JPS=jps
mapfile -t processes < <(docker exec ${containers[i]} ${JPS} | cut -d ' ' -f 1)
echo "Got past processes."
for ((j=0; j<${#processes[@]}; j++ )); do
echo "********* Dumping stack for process ${processes[j]}:" | tee -a ${logfile}
docker exec ${containers[i]} /bin/bash -c '[ -x $JAVA_HOME/bin/jstack ] && JSTACK=$JAVA_HOME/bin/jstack || JSTACK=jstack; $JSTACK -l '"${processes[j]}" >> ${logfile}
done
done
sleep ${STACK_INTERVAL}
done
echo "Checking progress files:"
if [ -n "${PARALLEL_DUNIT}" ]; then
mapfile -t progressfiles < <(find ${GEODE_BUILD} -name "*-progress.txt")
for (( i=0; i<${#progressfiles[@]}; i++)); do
echo "Checking progress file: ${progressfiles[i]}"
/usr/local/bin/dunit-progress hang ${progressfiles[i]} | tee -a ${CALLSTACKS_DIR}/dunit-hangs.txt
done
fi