onos-watch
1.35 KB
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
#!/bin/bash
# -----------------------------------------------------------------------------
# Monitors selected set of ONOS commands using the system watch command.
# -----------------------------------------------------------------------------
function _usage () {
cat << _EOF_
usage:
$(basename $0) [node] <commands> [watchflags]
options:
- [node] <commands> : the node to run the commands against
- [watchflags] : flags to be passed to the watch command.
summary:
Monitors selected set of ONOS commands using the system watch command.
<commands> is a comma-sepatarted list of ONOS CLI commands. If no commands
are supplied, the commands run are 'summary', 'intents', 'flows', and
'hosts' against \$OCI.
Note that [watchflags] only applies to platforms with the Linux-like watch
command. For other platforms, the default behavior of watch (refresh every 2
s) is emulated.
_EOF_
}
[ "$1" = "-h" ] && _usage && exit 0
[ ! -d "$ONOS_ROOT" ] && echo "ONOS_ROOT is not defined" >&2 && exit 1
. $ONOS_ROOT/tools/build/envDefaults
node=${1:-$OCI}
commands="${2:-summary,intents,flows,hosts}"
aux=/tmp/onos-watch.$$
trap "rm -f $aux" EXIT
echo "$commands" | tr ',' '\n' > $aux
# emulate watch if not Linux.
if [ "$(uname)" != "Linux" ]; then
while clear; "onos $node -b <$aux 2>/dev/null" ; do sleep 2; done
else
watch $3 "onos $node -b <$aux 2>/dev/null"
fi