Skip to content

Commit

Permalink
sadf: PCP: Add support for A_NET_NFS activity
Browse files Browse the repository at this point in the history
Add metrics displayed by "sar -n NFS" (NFS client statistics) to PCP
archive.

Signed-off-by: Sebastien GODARD <sysstat@users.noreply.github.com>
  • Loading branch information
sysstat committed Mar 24, 2019
1 parent 00cf117 commit e190723
Show file tree
Hide file tree
Showing 6 changed files with 88 additions and 0 deletions.
1 change: 1 addition & 0 deletions activity.c
Original file line number Diff line number Diff line change
Expand Up @@ -693,6 +693,7 @@ struct activity net_nfs_act = {
.f_json_print = json_print_net_nfs_stats,
.f_svg_print = svg_print_net_nfs_stats,
.f_raw_print = raw_print_net_nfs_stats,
.f_pcp_print = pcp_print_net_nfs_stats,
.f_count_new = NULL,
.item_list = NULL,
.desc = "NFS client statistics",
Expand Down
34 changes: 34 additions & 0 deletions pcp_def_metrics.c
Original file line number Diff line number Diff line change
Expand Up @@ -598,3 +598,37 @@ void pcp_def_serial_metrics(struct activity *a)
}
#endif /* HAVE_PCP */
}

/*
***************************************************************************
* Define PCP metrics for NFS client statistics.
***************************************************************************
*/
void pcp_def_net_nfs_metrics(void)
{
#ifdef HAVE_PCP
pmiAddMetric("network.fs.client.call",
PM_IN_NULL, PM_TYPE_FLOAT, PM_INDOM_NULL, PM_SEM_INSTANT,
pmiUnits(0, -1, 1, 0, PM_TIME_SEC, PM_COUNT_ONE));

pmiAddMetric("network.fs.client.retrans",
PM_IN_NULL, PM_TYPE_FLOAT, PM_INDOM_NULL, PM_SEM_INSTANT,
pmiUnits(0, -1, 1, 0, PM_TIME_SEC, PM_COUNT_ONE));

pmiAddMetric("network.fs.client.read",
PM_IN_NULL, PM_TYPE_FLOAT, PM_INDOM_NULL, PM_SEM_INSTANT,
pmiUnits(0, -1, 1, 0, PM_TIME_SEC, PM_COUNT_ONE));

pmiAddMetric("network.fs.client.write",
PM_IN_NULL, PM_TYPE_FLOAT, PM_INDOM_NULL, PM_SEM_INSTANT,
pmiUnits(0, -1, 1, 0, PM_TIME_SEC, PM_COUNT_ONE));

pmiAddMetric("network.fs.client.access",
PM_IN_NULL, PM_TYPE_FLOAT, PM_INDOM_NULL, PM_SEM_INSTANT,
pmiUnits(0, -1, 1, 0, PM_TIME_SEC, PM_COUNT_ONE));

pmiAddMetric("network.fs.client.getatt",
PM_IN_NULL, PM_TYPE_FLOAT, PM_INDOM_NULL, PM_SEM_INSTANT,
pmiUnits(0, -1, 1, 0, PM_TIME_SEC, PM_COUNT_ONE));
#endif /* HAVE_PCP */
}
1 change: 1 addition & 0 deletions pcp_def_metrics.h
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@ void pcp_def_ktables_metrics(void);
void pcp_def_queue_metrics(void);
void pcp_def_serial_metrics(struct activity *);
void pcp_def_net_dev_metrics(struct activity *);
void pcp_def_net_nfs_metrics(void);

/* Define domains number */
#define PM_INDOM_CPU 0
Expand Down
46 changes: 46 additions & 0 deletions pcp_stats.c
Original file line number Diff line number Diff line change
Expand Up @@ -792,3 +792,49 @@ __print_funct_t pcp_print_serial_stats(struct activity *a, int curr, unsigned lo
}
#endif /* HAVE_PCP */
}

/*
***************************************************************************
* Display NFS client statistics in PCP format.
*
* IN:
* @a Activity structure with statistics.
* @curr Index in array for current sample statistics.
* @itv Interval of time in 1/100th of a second.
* @record_hdr Record header for current sample.
***************************************************************************
*/
__print_funct_t pcp_print_net_nfs_stats(struct activity *a, int curr, unsigned long long itv,
struct record_header *record_hdr)
{
#ifdef HAVE_PCP
char buf[64];
struct stats_net_nfs
*snnc = (struct stats_net_nfs *) a->buf[curr],
*snnp = (struct stats_net_nfs *) a->buf[!curr];

snprintf(buf, sizeof(buf), "%f",
S_VALUE(snnp->nfs_rpccnt, snnc->nfs_rpccnt, itv));
pmiPutValue("network.fs.client.call", NULL, buf);

snprintf(buf, sizeof(buf), "%f",
S_VALUE(snnp->nfs_rpcretrans, snnc->nfs_rpcretrans, itv));
pmiPutValue("network.fs.client.retrans", NULL, buf);

snprintf(buf, sizeof(buf), "%f",
S_VALUE(snnp->nfs_readcnt, snnc->nfs_readcnt, itv));
pmiPutValue("network.fs.client.read", NULL, buf);

snprintf(buf, sizeof(buf), "%f",
S_VALUE(snnp->nfs_writecnt, snnc->nfs_writecnt, itv));
pmiPutValue("network.fs.client.write", NULL, buf);

snprintf(buf, sizeof(buf), "%f",
S_VALUE(snnp->nfs_accesscnt, snnc->nfs_accesscnt, itv));
pmiPutValue("network.fs.client.access", NULL, buf);

snprintf(buf, sizeof(buf), "%f",
S_VALUE(snnp->nfs_getattcnt, snnc->nfs_getattcnt, itv));
pmiPutValue("network.fs.client.getatt", NULL, buf);
#endif /* HAVE_PCP */
}
2 changes: 2 additions & 0 deletions pcp_stats.h
Original file line number Diff line number Diff line change
Expand Up @@ -37,5 +37,7 @@ __print_funct_t pcp_print_net_dev_stats
(struct activity *, int, unsigned long long, struct record_header *);
__print_funct_t pcp_print_net_edev_stats
(struct activity *, int, unsigned long long, struct record_header *);
__print_funct_t pcp_print_net_nfs_stats
(struct activity *, int, unsigned long long, struct record_header *);

#endif /* _PCP_STATS_H */
4 changes: 4 additions & 0 deletions sadf_misc.c
Original file line number Diff line number Diff line change
Expand Up @@ -541,6 +541,10 @@ __printf_funct_t print_pcp_statistics(int *tab, int action, struct activity *act
case A_NET_EDEV:
pcp_def_net_dev_metrics(act[p]);
break;

case A_NET_NFS:
pcp_def_net_nfs_metrics();
break;
}
}
}
Expand Down

0 comments on commit e190723

Please sign in to comment.