File: stats.sgml

package info (click to toggle)
ircd-irc2 2.11.1p1%2Bdfsg-2
  • links: PTS
  • area: main
  • in suites: lenny
  • size: 2,920 kB
  • ctags: 3,075
  • sloc: ansic: 36,365; sh: 3,245; makefile: 372
file content (328 lines) | stat: -rw-r--r-- 16,367 bytes parent folder | download | duplicates (2)
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
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
<!doctype linuxdoc system>

<article>

<title>STATS unleashed
<author>Piotr Kucharski
<date>$Id: stats.sgml,v 1.7 2005/01/30 15:31:35 chopin Exp $
<abstract>
This document describes all STATS for ircd server 2.11.
</abstract>

<sect>Introduction
<p>
So far STATS has one-char parameter. The result always ends with 219 numeric
,,End of STATS report''. Whether it was empty output or invalid parameter
can be determined by the char in 219 numeric (after the nickname): if it is
the char we passed as parameter, the output was empty, if it was asterisk ,,*'',
there was no such STATS we requested. 

<sect>STATS unleashed
<p>
All examples are raw ircd output minus
prefix (server name), numeric (varies from stats to stats) and nickname of a client
requesting STATS. Also ending 219 numeric is omitted in whole.

<descrip>
<tag/a, A - iauth configuration/
<tscreen><verb>
* rfc931
* socks reject,megaparanoid,cache=0
</verb></tscreen>
Shows all succesfully loaded iauth modules and their options.

<tag/b, B - bounce lines/
<tscreen><verb>B -1 <NULL> irc.example.org 4444 0
B <NULL> <NULL> irc.example.net 4444 0</verb></tscreen>
2nd field is class number or the hostname/IP mask
to match the client; if NULL, it matches any class or hostname,
if ``-1'', it is used only for those clients that were
rejected for connecting to server-only port. 
4th is server name and 5th the port, both telling the client where
it should connect to.

<tag/c - connect, zipped connect and noconnect lines/
<tscreen><verb>C *@192.168.0.13 * *.example.net 6667 10</verb></tscreen>
``C'' or ``c'' (lowercase is a mark for zipped links) are connect lines,
that is the list of servers we will connect to. 2nd field is remote server
IP (or name), 3rd the password for connection (disguised as ``*''), 4th IRC
name of a server, 5th -- port that autoconnection will be attempted to
(non-positive disables A/C) and finally the
class this server will be using is in 6th field.

<tscreen><verb>N *@192.168.0.13 * *.example.net 1 10</verb></tscreen>
``N'' stands for no-connect lines, and these are the servers that will
connect to us. It is required that each ``C'' has its corresponding ``N''.
The format is the same as ``C'' with an exception of last but one field:
it is not a port, but a number of labels (parts of hostname between dots)
from start to replace with ``*'' when introducing us to this server (allows
masking).

<tag/d, D - defines/
<tscreen><verb>
HUB:yes MS:3
LQ:128 MXC:100 TS:60 HRD:30 HGL:900 WWD:15 ATO:90
KCTL:90 DCTL:1800 LDCTL:5400 CF:1000 MCPU:10
H:63 N:9 D:9 U:10 R:50 T:160 C:50 P:20 K:23
BS:512 MXR:20 MXB:30 MXBL:1024 PY:10
ZL:-1 CM:2 CP:10 DC:15
AC: 1 CA:1 S:0 SS:20 SU:40000
CCL: 0x1</verb></tscreen>

These shows values of most variables set in config.h or struct_def.h,
compiled in the server:
<itemize>
<item>HUB (HUB): whether server can be a hub (more than one server connected)
<item>MS (MAXSERVERS): initial buffers allocation for that many servers (it can grow later anyway)
<item>LQ (LISTENQUEUE): maximum number of connections waiting to be accepted on one port
<item>MXC (MAXCONNECTIONS): maximum number of all open file descriptors allowed for ircd (this includes client connections, dns, motd, opening conf fds, pipes, P-lines etc.)
<item>TS (TIMESEC): allowed idle seconds (doing nothing waiting for messages to come)
<item>HRD (HANGONRETRYDELAY): wait that seconds before fast server reconnection
<item>HGL (HANGONGOODLINK): allow fast server reconnection if link has been open for that many seconds
<item>WWD (WRITEWAITDELAY): seconds to wait for write() call to complete if stuck
<item>ATO (ACCEPTTIMEOUT): seconds to wait for all auth/dns to complete (after that client quits with a ``Ping timeout'' reason)
<item>KCTL (KILLCHASETIMELIMIT): seconds within which KILL, KICK or MODE reaches target after it changed nick
<item>DCTL (DELAYCHASETIMELIMIT): seconds of channel delay protection
<item>LDCTL (LDELAYCHASETIMELIMIT): seconds of !-channel delay protection
<item>CF (CLIENT_FLOOD): number of bytes that can be sent to server without quitting with an ``Excess flood'' reason
<item>MCPU (MAXCHANNELSPERUSER): maximum number of channels per user (service channels not counted in)
<item>H (HOSTLEN): maximum length of a hostname for a client (if longer, it's seen as IP)
<item>N (NICKLEN): maximum length of a nicks allowed for local clients
<item>D (UIDLEN): length of an UID
<item>U (USERLEN): maximum length of a user (aka ident) field
<item>R (REALLEN): maximum length of an info field of a client
<item>T (TOPICLEN): maximum length of a topic on a channel
<item>C (CHANNELLEN): maximum length of a channel name
<item>P (PASSWDLEN): maximum length of a passwords (in I-, C-lines etc.)
<item>K (KEYLEN): maximum length of a key on a channel
<item>BS (BUFSIZE): internal buffer size
<item>MXR (MAXRECIPIENTS): maximum number of targets (recipients) allowed in one command
<item>MXB (MAXBANS): maximum number of all beIR modes per channel
<item>MXBL (MAXBANLENGTH): maximum length of all beIR modes per channel
<item>PY (MAXPENALTY): penalty points (received in various number for each command) after which client commands are not processed anymore
<item>ZL (ZIP_LEVEL): level of compression for ziplinks (``-1'' if none)
<item>CM (CLONE_MAX): maximum number of clients (``-1'' if none), that...
<item>CP (CLONE_PERIOD): ... in that many seconds may connect to server without being rejected for too fast connecting clients (``-1'' if none)
<item>DC (DELAY_CLOSE): seconds to keep too fast reconnecting clones delayed before closing their sockets (``-1'' if none)
<item>AC: auto connect status (0 disabled, 1 enabled)
<item>CA: client accept status (0 disabled, 1 enabled, 2 enabled if not split)
<item>S: split status (0 no split, 1 in split)
<item>SS (SPLIT_SERVERS): state of split if number of servers on the network is below that number
<item>SU (SPLIT_USERS): state of split if number of users on the network is below that number
<item>CCL: bitmask telling what is sent to &amp;CLIENTS channel.
</itemize>

<tag/f, F - file descriptors report/
<tscreen><verb>1 0.0.0.0 4444 192.168.1.13 51397 Beeth chopin 3774</verb></tscreen>
For security reasons it is available to operators only. The meaning of fields
is: file descriptor number, local ip, local port, client ip, client port,
client nick, client auth (ident), idle.

<tag/h, H - hub, leaf, deny lines/
<tscreen><verb>H * 616* hub.example.org 0 :-1</verb></tscreen>
Hub line define what servers (2nd field) and what SIDs (3rd field)
are allowed to be introduced by the server specified in 4th field.

<tscreen><verb>L * * leaf.example.org 0 :-1</verb></tscreen>
Leaf line ensures that servers we are connected to (matching 4th field)
do not become hubs introducing us servers matching the mask (2nd
field). 3th field is ignored, 5th field is max depth.

<tscreen><verb>D *.org <NULL> <NULL> 99 :0</verb></tscreen>
Deny autoconnect to servers that names match 4th field or that are in
a class specified by 5th field if any of the servers matching 2nd field
or defined to be in class specified in 3rd field are currently present
on the network or, if 2nd field prefixed with ``!'', denies autoconnect
if none of the servers matching 2nd field is present on the network.

<tag/i, I - allowed user connections/
<tscreen><verb>I 127.0.0.1 <NULL> <NULL> 0 10 -</verb></tscreen>
2nd field is an IP address, IP mask or CIDR, 3rd is password (disguised by ``*''
if present), 4th is a hostname required to match, 5th is a port this line
is valid for, 6th is the class client will be put in and finally 7th field
is I-line flags (all explained in the INSTALL file). 2nd and 4th fields can
be prefixed by ``user@'', which means ident must match as well.

<tag/K - disallowed user connections (aka kill lines)/
<tscreen><verb>K pc*.example.org sorry,no,entrance * 0 -1</verb></tscreen>
The hostname or IP to match (CIDR allowed), kill line comment or (very rarely used)
time interval when kill line is effective, username or auth to match, 
port on which kill line is effective. Lowercase ``k'' matches on auth,
read the INSTALL file for more info.

<tag/k - disallowed user connections (aka temporary kill lines)/
<tscreen><verb>K pc*.example.org sorry,no,entrance * 1200 -1</verb></tscreen>
The same as for ``stats K'' with one exception: field last but one shows time 
to live of a temporary kill line (and it always matches on all ports).

<tag/l, L - link info/
<tscreen><verb>clientname[username@host.name] 0 181 11431 37 318 :6442</verb></tscreen>
1st field is client info (client can be server, too). If uppercase ``L''
is used, then the real IP is shown, not the hostname. 
2nd field is
sendQ, 3rd received lines, 4th received bytes, 5th sent lines, 6th
sent bytes, 7th is client uptime.

This command accepts second parameter: if present, it shows the above
info only for the specified client.

<tag/m, M - commands usage stats/
<tscreen><verb>COMMANDNAME 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 3 8 0 0</verb></tscreen>
1st field is command name, the rest is in groups of 4 digits: total count, 
total argument bytes, remote count, remote bytes; each of 5 groups shows usage 
within given handler (function responsible for dealing with command coming from
a given type of client), in the following sequence: server, client, oper, 
service, unregistered.

<tag/o, O - operator lines/
<tscreen><verb>o *@*.example.org * Beeth 0 10</verb></tscreen>
1st field is operator type, lowercase is global operator, uppercase is local.
2nd field is the user@hostname required to match, 3rd is password (disguised as ``*''),
4th is the nickname, 5th is port (though unused) and 6th is the class user
will get after becoming operator.

<tag/p - ping reports/
<tscreen><verb>irc.example.org[*@192.168.1.13] 11 0 0 -1</verb></tscreen>
1st is servername (and its socketname), 2nd is sequence number of last
udp ping sent, 3rd is number of received answers, 4th is average response time
in miliseconds, 5th is preference used in autoconnecting. Only last 20 minutes
are remembered.

<tag/P - ports listening/
<tscreen><verb>4444 * - 0 246 14989 48 427 7169 1 active</verb></tscreen>
1st field is port number, 2nd is IP we listen on (or unix socket directory),
3rd is P-line flags, 
4th field is sendQ, 5th received lines, 6th received bytes, 7th sent lines, 8th
sent bytes, 9th is client uptime, 10th is number of clients using that P-line
and finally, 11th shows whether it is ``active'' or ``inactive'' (delayed accept).

<tag/q, Q - quarantine lines/
<tscreen><verb>Q <NULL> security_reasons irc.example.com 0 -1</verb></tscreen>
3rd field is a reason for quarantining server matching 4th field.

<tag/r, R - system usage/
<tscreen><verb>
CPU Secs 1269:55 User 975:10 System 294:45
RSS 180656 ShMem 4294962080 Data 1446 Stack 4294963143
Swaps 0 Reclaims 882162 Faults 14516
Block in 13 out 0
Msg Rcv 21277744 Send 56443634
Signals 16 Context Vol. 14305344 Invol 6442565
DBUF alloc 60 blocks 40867</verb></tscreen>
Just read man getrusage().

<tag/s, S - service lines/
<tscreen><verb>S *@192.168.1.13 * ServiceName 0x3F00FFFF 0</verb></tscreen>
2nd field is hostmask service is allowed to connect from, 3rd is password (diguised
as ``*''), 4th is service name, 5th is service type and 6th is class number.

<tag/t, T - statistics/
<tscreen><verb>accepts 1269601 refused 1173948</verb></tscreen>
Clients accepted and refused.
<tscreen><verb>unknown: commands 534523 prefixes 88</verb></tscreen>
Unknown commands and prefixes received.
<tscreen><verb>nick collisions 47 saves 10, unknown closes 1210400</verb></tscreen>
Unknown closes are all those closed that never got to client (user, service or server) state.
<tscreen><verb>wrong direction 0 empty 1937</verb></tscreen>
Messages coming from wrong direction and empty messages.
<tscreen><verb>users without servers 0 ghosts N/A
numerics seen 261332 mode fakes 2894
auth: successes 0 fails 0
local connections 12 udp packets 0
udp errors 0 udp dropped 0</verb></tscreen>
<tscreen><verb>link checks 38 passed 1 15s/35 30s dropped 0Sq/0Yg/2Fl</verb></tscreen>
Calls to check_link(), accepted early (last one made more than 15s ago, but 
little sendQ), accepted (more than 30s ago),
dropped because of too high sendQ (64kB), too young link (less than 60 sec), simply
refused.
<tscreen><verb>whowas turnover 490/13570/34247 [90]
ndelay turnover 8001/46556/195114 [1800]
abuse protections 1 strict 1
delay close 0 total 996</verb></tscreen>
Current number of delayed fds and total.
<tscreen><verb>Client - Server
connected 58205 1
bytes sent 4566999994 30687304
bytes recv 376478537 500907236
time connected 844868798 367786</verb></tscreen>
Summary of (respectively) client and server: connected amounts,
bytes sent, bytes received and overall time connected.
<tscreen><verb>iauth modules statistics (Wed Mar 24 22:44:05 2004)
spawned: 1, current options: 3 (2.11.0a5)
rfc931 connected 516946 unix 292818 other 7809 bad 205665 out of 1268450
rfc931 skipped 0 aborted 83143 / 77594
socks open 8/1/0 closed 0/20/0 noproxy 21655
socks cache open 15 closed 2 noproxy 1110772 miss 157676 (285 &lt;= 1029)</verb></tscreen>
Apart from iauth stats (start time, number of times respawned, options),
all iauth modules statistics (if available).

<p>
Most of these are self-explanatory. Should you want more words about
some, drop me a note.

<tag/u, U - uptime/
<tscreen><verb>
Server Up 0 days, 0:31:55
</verb></tscreen>
You guessed right, that's ircd uptime.

<tag/v, V - version restriction lines/
<tscreen><verb>V IRC/0210* IRC/D * 0 0</verb></tscreen>
2nd field is version to match, 3rd is server flags, 4th is server name mask.
(If all match, server is rejected; this one rejects all 2.10 servers compiled
with 'D' (debugmode).)

<tag/X - denied connections/
<tscreen><verb>X * . . *</verb></tscreen>
Denies client connection based on what client sends in USER command. Fields
of X line correspond one by one to those of USER.

<tag/y, Y - class lines/
<tscreen><verb>Y 0 300 0 16000 3000000 12.2 24.2 13</verb></tscreen>
2nd field is class number, 3rd is ping frequency, 4th is connect frequency
(used only by servers), 5th maximum number of clients that can attach to this
class, 6th is maximum sendQ for each client, 7th defines local limits, 8th
field global limits (read the INSTALL file for details) and 9th is number
of clients using this Y line.

<tag/z, Z - memory usage
<tscreen><verb>Client Local 2749(2210196) Remote 111389(8911120) Auth 31(1030)
Users 114064 in/visible 103664/10393(17337728) Invites 17(204)
User channels 418848(5026176) Aways 890(29745)
Attached confs 2719(32628)
Conflines 4888(527572)
Classes 18(792)
Channels 55106(19083997) Modes 65117(1879252) History 0(0) Cache 0(0)
Channel members 418879(5026548) invite 17(204)
Whowas users 111214(16904528) away 109(3679) links 12502(150024)
Whowas array 133852(10172752) Delay array 133852(2677040)
Hash: client 135347(1624164) chan 67741(812892)</verb></tscreen>
All these tell the number of items and (in the parens) the memory
all such items use.
<tscreen><verb>
Dbuf blocks 40867(83205212) (> 40867 [40867]) (45 < 3575) [0]
</verb></tscreen>
Number of dbuf blocks in use (and memory they use), number of dbufs allocated
during startup, the same number again (almost always), dbufs in use, max dbufs in use,
number of times dbufs were increased.
<tscreen><verb>RES table 8072
Structs 20440 IP storage 12344 Name storage 12685</verb></tscreen>
Resolver tables current sizes in bytes.
<tscreen><verb>Total: ww 27080959 ch 25990001 cl 33547797 co 527572 db 83205212</verb></tscreen>
Total amount of memory for whowas (ww), all channel related items (ch),
all client related items (cl), all configuration lines (co) and all dbufs
allocated (db).
<tscreen><verb>TOTAL: 172842930 sbrk(0)-etext: 249755424</verb></tscreen>
Total amount of memory used from sbrk() call.

<tag/? - connected servers info/
<tscreen><verb>irc.example.org (4, 06:31:29) 1S 2725C 491646kB sent 30180kB recv 0kB sq V3z</verb></tscreen>
Server name, (days, hour:min:sec link uptime), servers connected, clients connected, kB sent, kB received, sendQ and link version ('z' for ziplink). There also can be "BURST" word at the end, indicating netjoin in progress.

</descrip>

<sect>Enhancements
<p>If you notice some errors or wish to have some things explained better,
drop a line to <bf>ircd-dev@irc.org</bf>

</article>