ignore unreadable metrics on certain closed systems (#14234)

fixes #14233
This commit is contained in:
Harshavardhana 2022-02-03 09:45:12 -08:00 committed by GitHub
parent 63a2e0bab6
commit 01e550a9be
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -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