1
0
Fork 0
arangodb/scripts/setupPerfEvents.sh

49 lines
1.4 KiB
Bash
Executable File

#!/bin/bash
# This requires the perf utility to be installed and the OS must be linux.
# Compile with CMAKE_BUILD_TYPE=RelWithDebInfo in the subdirectory "build".
# Run this script in the main source directory.
#
# This script sets up performance monitoring events to measure single
# document operations. Run this script with sudo when the ArangoDB
# process is already running. Then do
# sudo perf record -e "probe_arangod:*" -aR sleep 60
# (to sample for 60 seconds). A file "perf.data" is written to the
# current directory.
# Dump the events in this file with
# sudo perf script
# This logs the times when individual threads hit the events.
# Remove all events with
# sudo perf probe -d "probe_arangod:*"
# List events with
# sudo perf probe -l
ARANGOD_EXECUTABLE=build/bin/arangod
perf probe -x $ARANGOD_EXECUTABLE -d "probe_arangod:*"
echo Adding events, this takes a few seconds...
addEvent() {
x=$1
echo $x
perf probe -x $ARANGOD_EXECUTABLE -a $x=$x 2> /dev/null
perf probe -x $ARANGOD_EXECUTABLE -a ${x}Ret=$x%return 2> /dev/null
}
echo Single document operations...
addEvent insertLocal
addEvent removeLocal
addEvent modifyLocal
addEvent documentLocal
echo Single document operations on coordinator...
addEvent insertCoordinator
addEvent removeCoordinator
addEvent updateCoordinator
addEvent replaceCoordinator
addEvent documentCoordinator
echo work method in HttpServerJob
addEvent work@HttpServerJob.cpp
echo Done.