Seeing negative values for wlentime and rlentime
Linux kstat IO and TIMER printed values as signed. However the counters only increment. Thus humans looking at the data can be confused when the counters roll over. Note: The recommended use of these values is to monitor the derivative, which don't really care about the sign. See explanations related to non-negative derivatives in the various time-series databases. Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov> Reviewed-by: Giuseppe Di Natale <guss80@gmail.com> Reviewed-by: Tony Hutter <hutter2@llnl.gov> Signed-off-by: Richard Elling <Richard.Elling@RichardElling.com> Closes #8131 Closes #8198
This commit is contained in:
parent
fa61e72340
commit
a48cd034c8
|
@ -261,9 +261,10 @@ kstat_seq_show_intr(struct seq_file *f, kstat_intr_t *kip)
|
||||||
static int
|
static int
|
||||||
kstat_seq_show_io(struct seq_file *f, kstat_io_t *kip)
|
kstat_seq_show_io(struct seq_file *f, kstat_io_t *kip)
|
||||||
{
|
{
|
||||||
|
/* though wlentime & friends are signed, they will never be negative */
|
||||||
seq_printf(f,
|
seq_printf(f,
|
||||||
"%-8llu %-8llu %-8u %-8u %-8lld %-8lld "
|
"%-8llu %-8llu %-8u %-8u %-8llu %-8llu "
|
||||||
"%-8lld %-8lld %-8lld %-8lld %-8u %-8u\n",
|
"%-8llu %-8llu %-8llu %-8llu %-8u %-8u\n",
|
||||||
kip->nread, kip->nwritten,
|
kip->nread, kip->nwritten,
|
||||||
kip->reads, kip->writes,
|
kip->reads, kip->writes,
|
||||||
kip->wtime, kip->wlentime, kip->wlastupdate,
|
kip->wtime, kip->wlentime, kip->wlastupdate,
|
||||||
|
@ -277,7 +278,7 @@ static int
|
||||||
kstat_seq_show_timer(struct seq_file *f, kstat_timer_t *ktp)
|
kstat_seq_show_timer(struct seq_file *f, kstat_timer_t *ktp)
|
||||||
{
|
{
|
||||||
seq_printf(f,
|
seq_printf(f,
|
||||||
"%-31s %-8llu %-8lld %-8lld %-8lld %-8lld %-8lld\n",
|
"%-31s %-8llu %-8llu %-8llu %-8llu %-8llu %-8llu\n",
|
||||||
ktp->name, ktp->num_events, ktp->elapsed_time,
|
ktp->name, ktp->num_events, ktp->elapsed_time,
|
||||||
ktp->min_time, ktp->max_time,
|
ktp->min_time, ktp->max_time,
|
||||||
ktp->start_time, ktp->stop_time);
|
ktp->start_time, ktp->stop_time);
|
||||||
|
|
Loading…
Reference in New Issue