-
Notifications
You must be signed in to change notification settings - Fork 3
/
c13statistics.xml
110 lines (109 loc) · 3.4 KB
/
c13statistics.xml
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
<chapter id="c13statistics">
<title>Statistics</title>
<para>
These are integer numbers that collect information about &kamailio; internals. They are providing real-time
feedback about health and load of an &kamailio; instance. In fact, they are represented by an integer variable or
a function that returns an integer.
</para>
<para>
The <emphasis role="strong">statistics engine</emphasis> is implemented in the files
<emphasis role="strong">lib/kcore/statistics..{c,h}</emphasis> - practically they are part
of internal library <emphasis role="strong">kcore</emphasis>. If you want to extend it, you have to read and
understand the code in those file. The purpose of this chapter is to teach how to add new statistic
variables.
</para>
<para>
You have to include the header file <emphasis role="strong">lib/kcore/statistics.h</emphasis> and declare the
statistic variable. We exemplify with the statistic <emphasis role="strong">stored_messages</emphasis>
from module <emphasis role="strong">msilo</emphasis>. In the file
<emphasis role="strong">modules/msilo/msilo.c</emphasis>.
</para>
<programlisting format="linespecific">
...
#include "../../lib/kcore/statistics.h"
stat_var* ms_stored_msgs;
...
</programlisting>
<para>
Next is to register the statistic to the engine, which can done there via
register_module_stats(...) function when you have an array of new statistics.
</para>
<programlisting format="linespecific">
...
stat_export_t msilo_stats[] = {
{"stored_messages" , 0, &ms_stored_msgs },
...
if (register_module_stats( exports.name, msilo_stats)!=0 ) {
LM_ERR("failed to register core statistics\n");
return -1;
}
...
</programlisting>
<para>
Alternative is to use the function <emphasis role="strong">register_stat(...)</emphasis> defined in
<emphasis role="strong">lib/kcore/statistics.{c,h}</emphasis>.
</para>
<programlisting format="linespecific">
...
int register_stat( char *module, char *name, stat_var **pvar, int flags);
...
</programlisting>
<para>
The parameters are:
</para>
<itemizedlist>
<listitem>
<para>
module - name of the module exporting the statistic
</para>
</listitem>
<listitem>
<para>
name - name of the statistic
</para>
</listitem>
<listitem>
<para>
var - where the statistic value will be stored
</para>
</listitem>
<listitem>
<para>
flags - flags describing the statistic
</para>
</listitem>
</itemizedlist>
<para>
Updating the value of the statistic is done in function <emphasis role="strong">m_store(...)</emphasis>,
once a new message is stored in database.
</para>
<programlisting format="linespecific">
...
update_stat(ms_stored_msgs, 1);
...
</programlisting>
<section id="c13macros">
<title>Statistic Macros</title>
<para>
There are three macros that help to deal with statistic values easily.
</para>
<itemizedlist>
<listitem>
<para>
update_stat (stat, val) - add to the statistic value the <emphasis role="strong">val</emphasis>.
<emphasis role="strong">val</emphasis> can be negative as well, resulting in substraction.
</para>
</listitem>
<listitem>
<para>
reset_stat (stat) - set the value of the statistic to <emphasis role="strong">0</emphasis>
</para>
</listitem>
<listitem>
<para>
get_stat_val (stat) - return the value of the statistic
</para>
</listitem>
</itemizedlist>
</section>
</chapter>