mirror of
https://github.com/minio/minio.git
synced 2025-01-11 15:03:22 -05:00
ignore unreadable metrics on certain closed systems (#14234)
fixes #14233
This commit is contained in:
parent
63a2e0bab6
commit
01e550a9be
@ -942,94 +942,109 @@ func getMinioProcMetrics() *MetricsGroup {
|
|||||||
logger.LogOnceIf(ctx, err, nodeMetricNamespace)
|
logger.LogOnceIf(ctx, err, nodeMetricNamespace)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
var openFDs int
|
|
||||||
openFDs, err = p.FileDescriptorsLen()
|
|
||||||
if err != nil {
|
|
||||||
logger.LogOnceIf(ctx, err, getMinioFDOpenMD())
|
|
||||||
return
|
|
||||||
}
|
|
||||||
l, err := p.Limits()
|
|
||||||
if err != nil {
|
|
||||||
logger.LogOnceIf(ctx, err, getMinioFDLimitMD())
|
|
||||||
return
|
|
||||||
}
|
|
||||||
io, err := p.IO()
|
|
||||||
if err != nil {
|
|
||||||
logger.LogOnceIf(ctx, err, ioSubsystem)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
stat, err := p.Stat()
|
|
||||||
if err != nil {
|
|
||||||
logger.LogOnceIf(ctx, err, processSubsystem)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
startTime, err := stat.StartTime()
|
|
||||||
if err != nil {
|
|
||||||
logger.LogOnceIf(ctx, err, startTime)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
|
openFDs, _ := p.FileDescriptorsLen()
|
||||||
|
l, _ := p.Limits()
|
||||||
|
io, _ := p.IO()
|
||||||
|
stat, _ := p.Stat()
|
||||||
|
startTime, _ := stat.StartTime()
|
||||||
|
|
||||||
|
if openFDs > 0 {
|
||||||
metrics = append(metrics,
|
metrics = append(metrics,
|
||||||
Metric{
|
Metric{
|
||||||
Description: getMinioFDOpenMD(),
|
Description: getMinioFDOpenMD(),
|
||||||
Value: float64(openFDs),
|
Value: float64(openFDs),
|
||||||
},
|
},
|
||||||
)
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
if l.OpenFiles > 0 {
|
||||||
metrics = append(metrics,
|
metrics = append(metrics,
|
||||||
Metric{
|
Metric{
|
||||||
Description: getMinioFDLimitMD(),
|
Description: getMinioFDLimitMD(),
|
||||||
Value: float64(l.OpenFiles),
|
Value: float64(l.OpenFiles),
|
||||||
})
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
if io.SyscR > 0 {
|
||||||
metrics = append(metrics,
|
metrics = append(metrics,
|
||||||
Metric{
|
Metric{
|
||||||
Description: getMinIOProcessSysCallRMD(),
|
Description: getMinIOProcessSysCallRMD(),
|
||||||
Value: float64(io.SyscR),
|
Value: float64(io.SyscR),
|
||||||
})
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
if io.SyscW > 0 {
|
||||||
metrics = append(metrics,
|
metrics = append(metrics,
|
||||||
Metric{
|
Metric{
|
||||||
Description: getMinIOProcessSysCallWMD(),
|
Description: getMinIOProcessSysCallWMD(),
|
||||||
Value: float64(io.SyscW),
|
Value: float64(io.SyscW),
|
||||||
})
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
if io.ReadBytes > 0 {
|
||||||
metrics = append(metrics,
|
metrics = append(metrics,
|
||||||
Metric{
|
Metric{
|
||||||
Description: getMinioProcessIOReadBytesMD(),
|
Description: getMinioProcessIOReadBytesMD(),
|
||||||
Value: float64(io.ReadBytes),
|
Value: float64(io.ReadBytes),
|
||||||
})
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
if io.WriteBytes > 0 {
|
||||||
metrics = append(metrics,
|
metrics = append(metrics,
|
||||||
Metric{
|
Metric{
|
||||||
Description: getMinioProcessIOWriteBytesMD(),
|
Description: getMinioProcessIOWriteBytesMD(),
|
||||||
Value: float64(io.WriteBytes),
|
Value: float64(io.WriteBytes),
|
||||||
})
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
if io.RChar > 0 {
|
||||||
metrics = append(metrics,
|
metrics = append(metrics,
|
||||||
Metric{
|
Metric{
|
||||||
Description: getMinioProcessIOReadCachedBytesMD(),
|
Description: getMinioProcessIOReadCachedBytesMD(),
|
||||||
Value: float64(io.RChar),
|
Value: float64(io.RChar),
|
||||||
})
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
if io.WChar > 0 {
|
||||||
metrics = append(metrics,
|
metrics = append(metrics,
|
||||||
Metric{
|
Metric{
|
||||||
Description: getMinioProcessIOWriteCachedBytesMD(),
|
Description: getMinioProcessIOWriteCachedBytesMD(),
|
||||||
Value: float64(io.WChar),
|
Value: float64(io.WChar),
|
||||||
})
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
if startTime > 0 {
|
||||||
metrics = append(metrics,
|
metrics = append(metrics,
|
||||||
Metric{
|
Metric{
|
||||||
Description: getMinIOProcessStartTimeMD(),
|
Description: getMinIOProcessStartTimeMD(),
|
||||||
Value: startTime,
|
Value: startTime,
|
||||||
})
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
if !globalBootTime.IsZero() {
|
||||||
metrics = append(metrics,
|
metrics = append(metrics,
|
||||||
Metric{
|
Metric{
|
||||||
Description: getMinIOProcessUptimeMD(),
|
Description: getMinIOProcessUptimeMD(),
|
||||||
Value: time.Since(globalBootTime).Seconds(),
|
Value: time.Since(globalBootTime).Seconds(),
|
||||||
})
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
if stat.ResidentMemory() > 0 {
|
||||||
metrics = append(metrics,
|
metrics = append(metrics,
|
||||||
Metric{
|
Metric{
|
||||||
Description: getMinIOProcessResidentMemory(),
|
Description: getMinIOProcessResidentMemory(),
|
||||||
Value: float64(stat.ResidentMemory()),
|
Value: float64(stat.ResidentMemory()),
|
||||||
})
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
if stat.CPUTime() > 0 {
|
||||||
metrics = append(metrics,
|
metrics = append(metrics,
|
||||||
Metric{
|
Metric{
|
||||||
Description: getMinIOProcessCPUTime(),
|
Description: getMinIOProcessCPUTime(),
|
||||||
Value: stat.CPUTime(),
|
Value: stat.CPUTime(),
|
||||||
})
|
})
|
||||||
|
}
|
||||||
return
|
return
|
||||||
})
|
})
|
||||||
return mg
|
return mg
|
||||||
|
Loading…
Reference in New Issue
Block a user