forked from Checkmk/checkmk
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmk-job
executable file
·59 lines (48 loc) · 1.78 KB
/
mk-job
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
#!/bin/bash
# Copyright (C) 2019 tribe29 GmbH - License: GNU General Public License v2
# This file is part of Checkmk (https://checkmk.com). It is subject to the terms and
# conditions defined in the file COPYING, which is part of this source code package.
export MK_VARDIR=/var/lib/check_mk_agent
help() {
echo "Usage: mk-job IDENT PROGRAM [ARGS...]"
echo ""
echo "Execute PROGRAM as subprocess while measuring performance information"
echo "about the running process and writing it to an output file. This file"
echo "can be monitored using Check_MK. The Check_MK Agent will forward the"
echo "information of all job files to the monitoring server."
echo ""
echo "This file is being distributed with the Check_MK Agent."
}
if [ $# -lt 2 ]; then
help >&2
exit 1
fi
MYSELF=$(id -nu)
OUTPUT_PATH=$MK_VARDIR/job/$MYSELF
IDENT=$1
RUNNING_FILE="$OUTPUT_PATH/$IDENT.$$running"
shift
if [ ! -d "$OUTPUT_PATH" ]; then
if [ "$MYSELF" = root ] ; then
mkdir -p "$OUTPUT_PATH"
else
echo "ERROR: Missing output directory $OUTPUT_PATH for non-root user '$MYSELF'." >&2
exit 1
fi
fi
if ! type $1 >/dev/null 2>&1; then
echo -e "ERROR: Cannot run $1. Command not found.\n" >&2
help >&2
exit 1
fi
date +"start_time %s" > "$RUNNING_FILE" 2>/dev/null
if [ ! -w "$RUNNING_FILE" ] ; then
# Looks like we are lacking the permissions to create this file..
# In this scenario no mk-job status file is created. We simply execute the command
exec "$@"
fi
/usr/bin/time -o "$RUNNING_FILE" --append \
-f "exit_code %x\nreal_time %E\nuser_time %U\nsystem_time %S\nreads %I\nwrites %O\nmax_res_kbytes %M\navg_mem_kbytes %K\ninvol_context_switches %c\nvol_context_switches %w" "$@"
RC=$?
mv "$RUNNING_FILE" "$OUTPUT_PATH/$IDENT"
exit $RC