Tagging module iproute2 - iproute2-2.6.16-2
[iproute2.git] / doc / nstat.sgml
1 <!doctype linuxdoc system>
2
3 <article>
4
5 <title>NSTAT, IFSTAT and RTACCT Utilities
6 <author>Alexey Kuznetosv, <tt/kuznet@ms2.inr.ac.ru/
7 <date>some_negative_number, 20 Sep 2001
8 <abstract>
9 <tt/nstat/, <tt/ifstat/ and <tt/rtacct/ are simple tools helping
10 to monitor kernel snmp counters and network interface statistics.
11 </abstract>
12
13 <p> These utilities are very similar, so that I describe
14 them simultaneously, using name <tt/Xstat/ in the places which apply
15 to all of them.
16
17 <p>The format of the command is:
18
19 <tscreen><verb>
20        Xstat [ OPTIONS ] [ PATTERN [ PATTERN ... ] ]
21 </verb></tscreen>
22
23 <p>
24 <tt/PATTERN/ is shell style pattern, selecting identifier
25 of SNMP variables or interfaces to show. Variable is displayed
26 if one of patterns matches its name. If no patterns are given,
27 <tt/Xstat/ assumes that user wants to see all the variables.  
28
29 <p> <tt/OPTIONS/ is list of single letter options, using common unix
30 conventions.
31
32 <itemize>
33 <item><tt/-h/  - show help page
34 <item><tt/-?/  - the same, of course
35 <item><tt/-v/, <tt/-V/  - print version of <tt/Xstat/ and exit
36 <item><tt/-z/ - dump zero counters too. By default they are not shown.
37 <item><tt/-a/ - dump absolute values of counters. By default <tt/Xstat/
38                 calculates increments since the previous use.
39 <item><tt/-s/ - do not update history, so that the next time you will
40                 see counters including values accumulated to the moment
41                 of this measurement too.
42 <item><tt/-n/ - do not display anything, only update history.
43 <item><tt/-r/ - reset history.
44 <item><tt/-d INTERVAL/ - <tt/Xstat/ is run in daemon mode collecting
45                 statistics. <tt/INTERVAL/ is interval between measurements
46                 in seconds.
47 <item><tt/-t INTERVAL/ - time interval to average rates. Default value
48                 is 60 seconds. 
49 <item><tt/-e/ - display extended information about errors (<tt/ifstat/ only).
50 </itemize>
51
52 <p>
53 History is just dump saved in file <tt>/tmp/.Xstat.uUID</tt>
54 or in file given by environment variables <tt/NSTAT_HISTORY/,
55 <tt/IFSTAT_HISTORY/ and <tt/RTACCT_HISTORY/.
56 Each time when you use <tt/Xstat/ values there are updated.
57 If you use patterns, only the values which you _really_ see
58 are updated. If you want to skip an unintersting period,
59 use option <tt/-n/, or just output to <tt>/dev/null</tt>.
60
61 <p>
62 <tt/Xstat/ understands when history is invalidated by system reboot
63 or source of information switched between different instances
64 of daemonic <tt/Xstat/ and kernel SNMP tables and does not
65 use invalid history.
66
67 <p> Beware, <tt/Xstat/ will not produce sane output,
68 when many processes use it simultaneously. If several processes
69 under single user need this utility they should use environment
70 variables to put their history in safe places
71 or to use it with options <tt/-a -s/.
72
73 <p>
74 Well, that's all. The utility is very simple, but nevertheless
75 very handy.
76
77 <p> <bf/Output of XSTAT/
78 <p> The first line of output is <tt/#/ followed by identifier
79 of source of information, it may be word <tt/kernel/, when <tt/Xstat/
80 gets information from kernel or some dotted decimal number followed
81 by parameters, when it obtains information from running <tt/Xstat/ daemon.
82
83 <p>In the case of <tt/nstat/ the rest of output consists of three columns:
84 SNMP MIB identifier,
85 its value (or increment since previous measurement) and average
86 rate of increase of the counter per second. <tt/ifstat/ outputs
87 interface name followed by pairs of counter and rate of its change.
88
89 <p> <bf/Daemonic Xstat/
90 <p> <tt/Xstat/ may be started as daemon by any user. This makes sense
91 to avoid wrapped counters and to obtain reasonable long counters
92 for large time. Also <tt/Xstat/ daemon calculates average rates.
93 For the first goal sampling interval (option <tt/-d/) may be large enough,
94 f.e. for gigabit rates byte counters overflow not more frequently than
95 each 40 seconds and you may select interval of 20 seconds.
96 From the other hand, when <tt/Xstat/ is used for estimating rates
97 interval should be less than averaging period (option <tt/-t/), otherwise
98 estimation loses in quality.
99
100 Client <tt/Xstat/, before trying to get information from the kernel,
101 contacts daemon started by this user, then it tries system wide
102 daemon, which is supposed to be started by superuser. And only if
103 none of them replied it gets information from kernel.
104
105 <p> <bf/Environment/
106 <p> <tt/NSTAT_HISTORY/ - name of history file for <tt/nstat/.
107 <p> <tt/IFSTAT_HISTORY/ - name of history file for <tt/ifstat/.
108 <p> <tt/RTACCT_HISTORY/ - name of history file for <tt/rtacct/.
109
110 </article>