multipathd: allow resetting stats
authorBenjamin Marzinski <bmarzins@redhat.com>
Mon, 27 Feb 2017 18:26:42 +0000 (12:26 -0600)
committerChristophe Varoqui <christophe.varoqui@opensvc.com>
Mon, 27 Feb 2017 20:41:33 +0000 (21:41 +0100)
This patch adds two multipathd interactive commands:

multipathd reset maps stats

and

multipathd reset map <map> stats

to reset the statistics that are shown with the "show stats" commands.

Signed-off-by: Benjamin Marzinski <bmarzins@redhat.com>
multipathd/cli.c
multipathd/cli_handlers.c
multipathd/cli_handlers.h
multipathd/main.c

index 50161be..32d4976 100644 (file)
@@ -547,6 +547,8 @@ cli_init (void) {
        add_handler(LIST+BLACKLIST, NULL);
        add_handler(LIST+DEVICES, NULL);
        add_handler(LIST+WILDCARDS, NULL);
+       add_handler(RESET+MAPS+STATS, NULL);
+       add_handler(RESET+MAP+STATS, NULL);
        add_handler(ADD+PATH, NULL);
        add_handler(DEL+PATH, NULL);
        add_handler(ADD+MAP, NULL);
index b0eeca6..b20b054 100644 (file)
@@ -277,6 +277,17 @@ show_config (char ** r, int * len)
        return 0;
 }
 
+void
+reset_stats(struct multipath * mpp)
+{
+       mpp->stat_switchgroup = 0;
+       mpp->stat_path_failures = 0;
+       mpp->stat_map_loads = 0;
+       mpp->stat_total_queueing_time = 0;
+       mpp->stat_queueing_timeouts = 0;
+       mpp->stat_map_failures = 0;
+}
+
 int
 cli_list_config (void * v, char ** reply, int * len, void * data)
 {
@@ -626,6 +637,39 @@ cli_list_daemon (void * v, char ** reply, int * len, void * data)
        return show_daemon(reply, len);
 }
 
+int
+cli_reset_maps_stats (void * v, char ** reply, int * len, void * data)
+{
+       struct vectors * vecs = (struct vectors *)data;
+       int i;
+       struct multipath * mpp;
+
+       condlog(3, "reset multipaths stats (operator)");
+
+       vector_foreach_slot(vecs->mpvec, mpp, i) {
+               reset_stats(mpp);
+       }
+       return 0;
+}
+
+int
+cli_reset_map_stats (void * v, char ** reply, int * len, void * data)
+{
+       struct vectors * vecs = (struct vectors *)data;
+       struct multipath * mpp;
+       char * param = get_keyparam(v, MAP);
+
+       param = convert_dev(param, 0);
+       mpp = find_mp_by_str(vecs->mpvec, param);
+
+       if (!mpp)
+               return 1;
+
+       condlog(3, "reset multipath %s stats (operator)", param);
+       reset_stats(mpp);
+       return 0;
+}
+
 int
 cli_add_path (void * v, char ** reply, int * len, void * data)
 {
index 19e003d..f4d02cc 100644 (file)
@@ -19,6 +19,8 @@ int cli_list_config (void * v, char ** reply, int * len, void * data);
 int cli_list_blacklist (void * v, char ** reply, int * len, void * data);
 int cli_list_devices (void * v, char ** reply, int * len, void * data);
 int cli_list_wildcards (void * v, char ** reply, int * len, void * data);
+int cli_reset_maps_stats (void * v, char ** reply, int * len, void * data);
+int cli_reset_map_stats (void * v, char ** reply, int * len, void * data);
 int cli_add_path (void * v, char ** reply, int * len, void * data);
 int cli_del_path (void * v, char ** reply, int * len, void * data);
 int cli_add_map (void * v, char ** reply, int * len, void * data);
index 1d73f9d..e317a4c 100644 (file)
@@ -1238,6 +1238,8 @@ uxlsnrloop (void * ap)
        set_handler_callback(LIST+BLACKLIST, cli_list_blacklist);
        set_handler_callback(LIST+DEVICES, cli_list_devices);
        set_handler_callback(LIST+WILDCARDS, cli_list_wildcards);
+       set_handler_callback(RESET+MAPS+STATS, cli_reset_maps_stats);
+       set_handler_callback(RESET+MAP+STATS, cli_reset_map_stats);
        set_handler_callback(ADD+PATH, cli_add_path);
        set_handler_callback(DEL+PATH, cli_del_path);
        set_handler_callback(ADD+MAP, cli_add_map);