summaryrefslogtreecommitdiffstats
path: root/logsmanagement/rrd_api/rrd_api_kernel.c
blob: 9372f773568256ec25cb936320f26b9cfef934f3 (plain)
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
// SPDX-License-Identifier: GPL-3.0-or-later

#include "rrd_api_kernel.h"

void kernel_chart_init(struct File_info *p_file_info){
    p_file_info->chart_meta->chart_data_kernel = callocz(1, sizeof (struct Chart_data_kernel));
    chart_data_kernel_t *chart_data = p_file_info->chart_meta->chart_data_kernel;
    chart_data->last_update = now_realtime_sec(); // initial value shouldn't be 0
    long chart_prio = p_file_info->chart_meta->base_prio;

    lgs_mng_do_num_of_logs_charts_init(p_file_info, chart_prio);

    /* Syslog severity level (== Systemd priority) - initialise */
    if(p_file_info->parser_config->chart_config & CHART_SYSLOG_SEVER){
        lgs_mng_create_chart(
            (char *) p_file_info->chartname     // type
            , "severity_levels"                 // id
            , "Severity Levels"                 // title
            , "severity levels"                 // units
            , "severity"                        // family
            , NULL                              // context
            , RRDSET_TYPE_AREA_NAME             // chart_type
            , ++chart_prio                      // priority
            , p_file_info->update_every         // update_every
        ); 

        for(int i = 0; i < SYSLOG_SEVER_ARR_SIZE; i++)
            lgs_mng_add_dim(dim_sever_str[i], RRD_ALGORITHM_INCREMENTAL_NAME, 1, 1);
  
    }

    /* Subsystem - initialise */
    if(p_file_info->parser_config->chart_config & CHART_KMSG_SUBSYSTEM){
        chart_data->cs_subsys = lgs_mng_create_chart(
            (char *) p_file_info->chartname             // type
            , "subsystems"                              // id
            , "Subsystems"                              // title
            , "subsystems"                              // units
            , "subsystem"                               // family
            , NULL                                      // context
            , RRDSET_TYPE_AREA_NAME                     // chart_type
            , ++chart_prio                              // priority
            , p_file_info->update_every                 // update_every
        );
    }

    /* Device - initialise */
    if(p_file_info->parser_config->chart_config & CHART_KMSG_DEVICE){
        chart_data->cs_device = lgs_mng_create_chart(
            (char *) p_file_info->chartname             // type
            , "devices"                                 // id
            , "Devices"                                 // title
            , "devices"                                 // units
            , "device"                                  // family
            , NULL                                      // context
            , RRDSET_TYPE_AREA_NAME                     // chart_type
            , ++chart_prio                              // priority
            , p_file_info->update_every                 // update_every
        ); 
    }

    lgs_mng_do_custom_charts_init(p_file_info);
}

void kernel_chart_update(struct File_info *p_file_info){
    chart_data_kernel_t *chart_data = p_file_info->chart_meta->chart_data_kernel;

    if(chart_data->last_update != p_file_info->parser_metrics->last_update){

        time_t lag_in_sec = p_file_info->parser_metrics->last_update - chart_data->last_update - 1;

        lgs_mng_do_num_of_logs_charts_update(p_file_info, lag_in_sec, chart_data);

        /* Syslog severity level (== Systemd priority) - update */
        if(p_file_info->parser_config->chart_config & CHART_SYSLOG_SEVER){
            for(time_t  sec = p_file_info->parser_metrics->last_update - lag_in_sec;
                        sec < p_file_info->parser_metrics->last_update;
                        sec++){
            
                lgs_mng_update_chart_begin(p_file_info->chartname, "severity_levels");
                for(int idx = 0; idx < SYSLOG_SEVER_ARR_SIZE; idx++)
                    lgs_mng_update_chart_set(dim_sever_str[idx], chart_data->num_sever[idx]);
                lgs_mng_update_chart_end(sec);
            }

            lgs_mng_update_chart_begin(p_file_info->chartname, "severity_levels");
            for(int idx = 0; idx < SYSLOG_SEVER_ARR_SIZE; idx++){
                chart_data->num_sever[idx] = p_file_info->parser_metrics->kernel->sever[idx];
                lgs_mng_update_chart_set(dim_sever_str[idx], chart_data->num_sever[idx]);
            }
            lgs_mng_update_chart_end(p_file_info->parser_metrics->last_update); 
        }

        /* Subsystem - update */
        if(p_file_info->parser_config->chart_config & CHART_KMSG_SUBSYSTEM){
            metrics_dict_item_t *it;

            for(time_t  sec = p_file_info->parser_metrics->last_update - lag_in_sec;
                        sec < p_file_info->parser_metrics->last_update;
                        sec++){

                lgs_mng_update_chart_begin(p_file_info->chartname, "subsystems");
                dfe_start_read(p_file_info->parser_metrics->kernel->subsystem, it){
                    if(it->dim_initialized)
                        lgs_mng_update_chart_set(it_dfe.name, (collected_number) it->num);
                } 
                dfe_done(it);
                lgs_mng_update_chart_end(sec);
            }

            dfe_start_write(p_file_info->parser_metrics->kernel->subsystem, it){
                if(!it->dim_initialized){
                    it->dim_initialized = true;
                    lgs_mng_add_dim_post_init(  &chart_data->cs_subsys, it_dfe.name, 
                                                RRD_ALGORITHM_INCREMENTAL_NAME, 1, 1);
                }
            }
            dfe_done(it);

            lgs_mng_update_chart_begin(p_file_info->chartname, "subsystems");
            dfe_start_write(p_file_info->parser_metrics->kernel->subsystem, it){
                it->num = it->num_new;
                lgs_mng_update_chart_set(it_dfe.name, (collected_number) it->num);
            }
            dfe_done(it);
            lgs_mng_update_chart_end(p_file_info->parser_metrics->last_update); 
        }

        /* Device - update */
        if(p_file_info->parser_config->chart_config & CHART_KMSG_DEVICE){
            metrics_dict_item_t *it;

            for(time_t  sec = p_file_info->parser_metrics->last_update - lag_in_sec;
                        sec < p_file_info->parser_metrics->last_update;
                        sec++){

                lgs_mng_update_chart_begin(p_file_info->chartname, "devices");
                dfe_start_read(p_file_info->parser_metrics->kernel->device, it){
                    if(it->dim_initialized)
                        lgs_mng_update_chart_set(it_dfe.name, (collected_number) it->num);
                } 
                dfe_done(it);
                lgs_mng_update_chart_end(sec);
            }

            dfe_start_write(p_file_info->parser_metrics->kernel->device, it){
                if(!it->dim_initialized){
                    it->dim_initialized = true;
                    lgs_mng_add_dim_post_init(  &chart_data->cs_device, it_dfe.name,
                                                RRD_ALGORITHM_INCREMENTAL_NAME, 1, 1);
                }
            }
            dfe_done(it);

            lgs_mng_update_chart_begin(p_file_info->chartname, "devices");
            dfe_start_write(p_file_info->parser_metrics->kernel->device, it){
                it->num = it->num_new;
                lgs_mng_update_chart_set(it_dfe.name, (collected_number) it->num);
            }
            dfe_done(it);
            lgs_mng_update_chart_end(p_file_info->parser_metrics->last_update); 
        }

        lgs_mng_do_custom_charts_update(p_file_info, lag_in_sec);

        chart_data->last_update = p_file_info->parser_metrics->last_update;
    }
}