Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
水淹萌龙
kubesphere
提交
9a6880bc
K
kubesphere
项目概览
水淹萌龙
/
kubesphere
与 Fork 源项目一致
Fork自
KubeSphere / kubesphere
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
kubesphere
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
9a6880bc
编写于
11月 23, 2018
作者:
C
Carman Zhang
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
support node-pod/namespace-workload sorting and paging
上级
c7a1011e
变更
5
隐藏空白更改
内联
并排
Showing
5 changed file
with
147 addition
and
29 deletion
+147
-29
pkg/apis/v1alpha/monitoring/monitor_handler.go
pkg/apis/v1alpha/monitoring/monitor_handler.go
+20
-2
pkg/client/prometheusclient.go
pkg/client/prometheusclient.go
+3
-0
pkg/models/metrics/metrics.go
pkg/models/metrics/metrics.go
+90
-14
pkg/models/metrics/metricsrule.go
pkg/models/metrics/metricsrule.go
+12
-1
pkg/models/metrics/metricsruleconst.go
pkg/models/metrics/metricsruleconst.go
+22
-12
未找到文件。
pkg/apis/v1alpha/monitoring/monitor_handler.go
浏览文件 @
9a6880bc
...
...
@@ -59,10 +59,22 @@ func (u Monitor) monitorContainer(request *restful.Request, response *restful.Re
func
(
u
Monitor
)
monitorWorkload
(
request
*
restful
.
Request
,
response
*
restful
.
Response
)
{
requestParams
:=
client
.
ParseMonitoringRequestParams
(
request
)
wlKind
:=
requestParams
.
WorkloadKind
tp
:=
requestParams
.
Tp
if
wlKind
==
""
{
// count all workloads figure
res
:=
metrics
.
MonitorWorkloadCount
(
requestParams
.
NsName
)
response
.
WriteAsJson
(
res
)
if
tp
==
"rank"
{
rawMetrics
:=
metrics
.
MonitorAllMetrics
(
requestParams
,
metrics
.
MetricLevelWorkload
)
// sorting
sortedMetrics
,
maxMetricCount
:=
metrics
.
Sort
(
requestParams
.
SortMetricName
,
requestParams
.
SortType
,
rawMetrics
,
metrics
.
MetricLevelWorkload
)
// paging
pagedMetrics
:=
metrics
.
Page
(
requestParams
.
PageNum
,
requestParams
.
LimitNum
,
sortedMetrics
,
maxMetricCount
)
response
.
WriteAsJson
(
pagedMetrics
)
}
else
{
res
:=
metrics
.
MonitorWorkloadCount
(
requestParams
.
NsName
)
response
.
WriteAsJson
(
res
)
}
}
else
{
res
:=
metrics
.
MonitorAllMetrics
(
requestParams
,
metrics
.
MetricLevelWorkload
)
response
.
WriteAsJson
(
res
)
...
...
@@ -349,6 +361,12 @@ func Register(ws *restful.WebService, subPath string) {
Doc
(
"monitor all workload level metrics"
)
.
Param
(
ws
.
PathParameter
(
"ns_name"
,
"namespace"
)
.
DataType
(
"string"
)
.
Required
(
true
)
.
DefaultValue
(
"kube-system"
))
.
Param
(
ws
.
QueryParameter
(
"metrics_filter"
,
"metrics name cpu memory..."
)
.
DataType
(
"string"
)
.
Required
(
false
))
.
Param
(
ws
.
QueryParameter
(
"workloads_filter"
,
"pod re2 expression filter"
)
.
DataType
(
"string"
)
.
Required
(
false
)
.
DefaultValue
(
""
))
.
Param
(
ws
.
QueryParameter
(
"sort_metric"
,
"sort metric"
)
.
DataType
(
"string"
)
.
Required
(
false
))
.
Param
(
ws
.
QueryParameter
(
"sort_type"
,
"ascending descending order"
)
.
DataType
(
"string"
)
.
Required
(
false
))
.
Param
(
ws
.
QueryParameter
(
"page"
,
"page number"
)
.
DataType
(
"string"
)
.
Required
(
false
)
.
DefaultValue
(
"1"
))
.
Param
(
ws
.
QueryParameter
(
"limit"
,
"metrics name cpu memory...in re2 regex"
)
.
DataType
(
"string"
)
.
Required
(
false
)
.
DefaultValue
(
"4"
))
.
Param
(
ws
.
QueryParameter
(
"type"
,
"rank, statistic"
)
.
DataType
(
"string"
)
.
Required
(
false
)
.
DefaultValue
(
"rank"
))
.
Metadata
(
restfulspec
.
KeyOpenAPITags
,
tags
))
.
Consumes
(
restful
.
MIME_JSON
,
restful
.
MIME_XML
)
.
Produces
(
restful
.
MIME_JSON
)
...
...
pkg/client/prometheusclient.go
浏览文件 @
9a6880bc
...
...
@@ -63,6 +63,7 @@ type MonitoringRequestParams struct {
ContainersFilter
string
MetricsName
string
WorkloadName
string
WlFilter
string
NodeId
string
WsName
string
NsName
string
...
...
@@ -108,6 +109,7 @@ func ParseMonitoringRequestParams(request *restful.Request) *MonitoringRequestPa
nodesFilter
:=
strings
.
Trim
(
request
.
QueryParameter
(
"nodes_filter"
),
" "
)
wsFilter
:=
strings
.
Trim
(
request
.
QueryParameter
(
"workspaces_filter"
),
" "
)
nsFilter
:=
strings
.
Trim
(
request
.
QueryParameter
(
"namespaces_filter"
),
" "
)
wlFilter
:=
strings
.
Trim
(
request
.
QueryParameter
(
"workloads_filter"
),
" "
)
podsFilter
:=
strings
.
Trim
(
request
.
QueryParameter
(
"pods_filter"
),
" "
)
containersFilter
:=
strings
.
Trim
(
request
.
QueryParameter
(
"containers_filter"
),
" "
)
...
...
@@ -135,6 +137,7 @@ func ParseMonitoringRequestParams(request *restful.Request) *MonitoringRequestPa
ContainersFilter
:
containersFilter
,
MetricsName
:
metricsName
,
WorkloadName
:
workloadName
,
WlFilter
:
wlFilter
,
NodeId
:
nodeId
,
WsName
:
wsName
,
NsName
:
nsName
,
...
...
pkg/models/metrics/metrics.go
浏览文件 @
9a6880bc
...
...
@@ -120,6 +120,51 @@ type OneComponentStatus struct {
Error
string
`json:"error,omitempty"`
}
func
renameWorkload
(
formatedMetric
*
FormatedMetric
,
relationMap
map
[
string
]
string
)
{
if
formatedMetric
.
Status
==
MetricStatusSuccess
{
for
i
:=
0
;
i
<
len
(
formatedMetric
.
Data
.
Result
);
i
++
{
metricDesc
:=
formatedMetric
.
Data
.
Result
[
i
][
ResultItemMetric
]
metricDescMap
,
ensure
:=
metricDesc
.
(
map
[
string
]
interface
{})
if
ensure
{
if
wl
,
exist
:=
metricDescMap
[
MetricLevelWorkload
];
exist
{
if
deployName
,
exist
:=
relationMap
[
wl
.
(
string
)];
exist
{
metricDescMap
[
MetricLevelWorkload
]
=
deployName
}
}
}
}
}
}
func
getReplicaAndDeployRelation
(
nsName
string
)
map
[
string
]
string
{
rule
:=
strings
.
Replace
(
WorkloadReplicaSetOwnerRule
,
"$1"
,
nsName
,
-
1
)
params
:=
makeRequestParamString
(
rule
,
make
(
url
.
Values
))
res
:=
client
.
SendMonitoringRequest
(
client
.
DefaultQueryType
,
params
)
formatedMetric
:=
ReformatJson
(
res
,
""
)
var
relationMap
=
make
(
map
[
string
]
string
)
if
formatedMetric
.
Status
==
MetricStatusSuccess
{
for
i
:=
0
;
i
<
len
(
formatedMetric
.
Data
.
Result
);
i
++
{
metricDesc
:=
formatedMetric
.
Data
.
Result
[
i
][
ResultItemMetric
]
metricDescMap
,
ensure
:=
metricDesc
.
(
map
[
string
]
interface
{})
if
ensure
{
if
ownerKind
,
exist
:=
metricDescMap
[
"owner_kind"
];
exist
&&
ownerKind
==
ReplicaSet
{
if
ownerName
,
exist
:=
metricDescMap
[
"owner_name"
];
exist
{
replicaName
,
sure
:=
ownerName
.
(
string
)
if
sure
{
deployName
:=
replicaName
[
:
strings
.
LastIndex
(
replicaName
,
"-"
)]
relationMap
[
replicaName
]
=
deployName
}
}
}
}
}
}
return
relationMap
}
func
getPodNameRegexInWorkload
(
res
string
)
string
{
data
:=
[]
byte
(
res
)
...
...
@@ -192,12 +237,12 @@ func unifyMetricHistoryTimeRange(fmtMetrics *FormatedMetric) {
}
}
func
AssembleWorkloadMetricRequestInfo
(
monitoringRequest
*
client
.
MonitoringRequestParams
,
metricName
string
)
(
string
,
string
)
{
func
Assemble
Specific
WorkloadMetricRequestInfo
(
monitoringRequest
*
client
.
MonitoringRequestParams
,
metricName
string
)
(
string
,
string
)
{
nsName
:=
monitoringRequest
.
NsName
wkName
:=
monitoringRequest
.
WorkloadName
rule
:=
MakeWorkloadRule
(
monitoringRequest
.
WorkloadKind
,
wkName
,
nsName
)
rule
:=
Make
Specific
WorkloadRule
(
monitoringRequest
.
WorkloadKind
,
wkName
,
nsName
)
paramValues
:=
monitoringRequest
.
Params
params
:=
makeRequestParamString
(
rule
,
paramValues
)
...
...
@@ -212,6 +257,16 @@ func AssembleWorkloadMetricRequestInfo(monitoringRequest *client.MonitoringReque
return
queryType
,
params
}
func
AssembleAllWorkloadMetricRequestInfo
(
monitoringRequest
*
client
.
MonitoringRequestParams
,
metricName
string
)
(
string
,
string
)
{
queryType
:=
monitoringRequest
.
QueryType
paramValues
:=
monitoringRequest
.
Params
rule
:=
MakeWorkloadPromQL
(
metricName
,
monitoringRequest
.
NsName
,
monitoringRequest
.
WlFilter
)
params
:=
makeRequestParamString
(
rule
,
paramValues
)
return
queryType
,
params
}
func
AssemblePodMetricRequestInfo
(
monitoringRequest
*
client
.
MonitoringRequestParams
,
metricName
string
)
(
string
,
string
,
bool
)
{
queryType
:=
monitoringRequest
.
QueryType
...
...
@@ -590,18 +645,39 @@ func MonitorAllMetrics(monitoringRequest *client.MonitoringRequestParams, resour
}
case
MetricLevelWorkload
:
{
for
_
,
metricName
:=
range
WorkloadMetricsNames
{
bol
,
err
:=
regexp
.
MatchString
(
metricsFilter
,
metricName
)
if
err
==
nil
&&
bol
{
wg
.
Add
(
1
)
go
func
(
metricName
string
)
{
metricName
=
strings
.
TrimLeft
(
metricName
,
"workload_"
)
queryType
,
params
:=
AssembleWorkloadMetricRequestInfo
(
monitoringRequest
,
metricName
)
fmtMetrics
:=
GetMetric
(
queryType
,
params
,
metricName
)
unifyMetricHistoryTimeRange
(
fmtMetrics
)
ch
<-
fmtMetrics
wg
.
Done
()
}(
metricName
)
if
monitoringRequest
.
Tp
==
"rank"
{
// get relationship between replicaset and deployment
relationMap
:=
getReplicaAndDeployRelation
(
monitoringRequest
.
NsName
)
for
_
,
metricName
:=
range
WorkloadMetricsNames
{
bol
,
err
:=
regexp
.
MatchString
(
metricsFilter
,
metricName
)
if
err
==
nil
&&
bol
{
wg
.
Add
(
1
)
go
func
(
metricName
string
)
{
queryType
,
params
:=
AssembleAllWorkloadMetricRequestInfo
(
monitoringRequest
,
metricName
)
fmtMetrics
:=
GetMetric
(
queryType
,
params
,
metricName
)
// rename replica workload name
renameWorkload
(
fmtMetrics
,
relationMap
)
ch
<-
fmtMetrics
wg
.
Done
()
}(
metricName
)
}
}
}
else
{
for
_
,
metricName
:=
range
WorkloadMetricsNames
{
bol
,
err
:=
regexp
.
MatchString
(
metricsFilter
,
metricName
)
if
err
==
nil
&&
bol
{
wg
.
Add
(
1
)
go
func
(
metricName
string
)
{
metricName
=
strings
.
TrimLeft
(
metricName
,
"workload_"
)
queryType
,
params
:=
AssembleSpecificWorkloadMetricRequestInfo
(
monitoringRequest
,
metricName
)
fmtMetrics
:=
GetMetric
(
queryType
,
params
,
metricName
)
unifyMetricHistoryTimeRange
(
fmtMetrics
)
ch
<-
fmtMetrics
wg
.
Done
()
}(
metricName
)
}
}
}
}
...
...
pkg/models/metrics/metricsrule.go
浏览文件 @
9a6880bc
...
...
@@ -17,7 +17,18 @@ import (
"strings"
)
func
MakeWorkloadRule
(
wkKind
,
wkName
,
namespace
string
)
string
{
func
MakeWorkloadPromQL
(
metricName
,
nsName
,
wlFilter
string
)
string
{
if
wlFilter
==
""
{
wlFilter
=
".*"
}
var
promql
=
RulePromQLTmplMap
[
metricName
]
promql
=
strings
.
Replace
(
promql
,
"$2"
,
nsName
,
-
1
)
promql
=
strings
.
Replace
(
promql
,
"$3"
,
wlFilter
,
-
1
)
return
promql
}
func
MakeSpecificWorkloadRule
(
wkKind
,
wkName
,
namespace
string
)
string
{
var
rule
=
PodInfoRule
if
namespace
==
""
{
namespace
=
".*"
...
...
pkg/models/metrics/metricsruleconst.go
浏览文件 @
9a6880bc
...
...
@@ -73,9 +73,10 @@ const (
)
const
(
NodeStatusRule
=
`kube_node_status_condition{condition="Ready"} > 0`
PodInfoRule
=
`kube_pod_info{created_by_kind="$1",created_by_name=$2,namespace="$3"}`
NamespaceLabelRule
=
`kube_namespace_labels`
NodeStatusRule
=
`kube_node_status_condition{condition="Ready"} > 0`
PodInfoRule
=
`kube_pod_info{created_by_kind="$1",created_by_name=$2,namespace="$3"}`
NamespaceLabelRule
=
`kube_namespace_labels`
WorkloadReplicaSetOwnerRule
=
`kube_pod_owner{namespace="$1", owner_name!="<none>", owner_kind="ReplicaSet"}`
)
const
(
...
...
@@ -472,21 +473,30 @@ var RulePromQLTmplMap = MetricMap{
"namespace_ingresses_extensions_count"
:
`sum(kube_ingress_labels{namespace!="", namespace=~"$1"}) by (namespace)`
,
// pod
"pod_cpu_usage"
:
`sum(irate(container_cpu_usage_seconds_total{job="kubelet", namespace="$1", pod_name="$2", image!=""}[5m])) by (namespace, pod_name)`
,
"pod_memory_usage"
:
`sum(container_memory_usage_bytes{job="kubelet", namespace="$1", pod_name="$2", image!=""}) by (namespace, pod_name)`
,
"pod_memory_usage_wo_cache"
:
`sum(container_memory_usage_bytes{job="kubelet", namespace="$1", pod_name
="$2", image!=""} - container_memory_cache{job="kubelet", namespace="$1
", pod_name="$2",image!=""}) by (namespace, pod_name)`
,
"pod_cpu_usage"
:
`sum(irate(container_cpu_usage_seconds_total{job="kubelet", namespace="$1", pod_name
!="", pod_name
="$2", image!=""}[5m])) by (namespace, pod_name)`
,
"pod_memory_usage"
:
`sum(container_memory_usage_bytes{job="kubelet", namespace="$1", pod_name
!="", pod_name
="$2", image!=""}) by (namespace, pod_name)`
,
"pod_memory_usage_wo_cache"
:
`sum(container_memory_usage_bytes{job="kubelet", namespace="$1", pod_name
!="", pod_name="$2", image!=""} - container_memory_cache{job="kubelet", namespace="$1", pod_name!="
", pod_name="$2",image!=""}) by (namespace, pod_name)`
,
"pod_net_bytes_transmitted"
:
`sum by (namespace, pod_name) (irate(container_network_transmit_bytes_total{namespace="$1", pod_name!="", pod_name="$2", interface="eth0", job="kubelet"}[5m]))`
,
"pod_net_bytes_received"
:
`sum by (namespace, pod_name) (irate(container_network_receive_bytes_total{namespace="$1", pod_name!="", pod_name="$2", interface="eth0", job="kubelet"}[5m]))`
,
"pod_cpu_usage_all"
:
`sum(irate(container_cpu_usage_seconds_total{job="kubelet", namespace="$1", pod_name=~"$2", image!=""}[5m])) by (namespace, pod_name)`
,
"pod_memory_usage_all"
:
`sum(container_memory_usage_bytes{job="kubelet", namespace="$1", pod_name=~"$2", image!=""}) by (namespace, pod_name)`
,
"pod_memory_usage_wo_cache_all"
:
`sum(container_memory_usage_bytes{job="kubelet", namespace="$1", pod_name
=~"$2", image!=""} - container_memory_cache{job="kubelet", namespace="$1
", pod_name=~"$2", image!=""}) by (namespace, pod_name)`
,
"pod_cpu_usage_all"
:
`sum(irate(container_cpu_usage_seconds_total{job="kubelet", namespace="$1", pod_name
!="", pod_name
=~"$2", image!=""}[5m])) by (namespace, pod_name)`
,
"pod_memory_usage_all"
:
`sum(container_memory_usage_bytes{job="kubelet", namespace="$1", pod_name
!="", pod_name
=~"$2", image!=""}) by (namespace, pod_name)`
,
"pod_memory_usage_wo_cache_all"
:
`sum(container_memory_usage_bytes{job="kubelet", namespace="$1", pod_name
!="", pod_name=~"$2", image!=""} - container_memory_cache{job="kubelet", namespace="$1", pod_name!="
", pod_name=~"$2", image!=""}) by (namespace, pod_name)`
,
"pod_net_bytes_transmitted_all"
:
`sum by (namespace, pod_name) (irate(container_network_transmit_bytes_total{namespace="$1", pod_name!="", pod_name=~"$2", interface="eth0", job="kubelet"}[5m]))`
,
"pod_net_bytes_received_all"
:
`sum by (namespace, pod_name) (irate(container_network_receive_bytes_total{namespace="$1", pod_name!="", pod_name=~"$2", interface="eth0", job="kubelet"}[5m]))`
,
"pod_cpu_usage_node"
:
`sum by (node, pod) (label_join(irate(container_cpu_usage_seconds_total{job="kubelet",pod_name=~"$2", image!=""}[5m]), "pod", " ", "pod_name") * on (namespace, pod) group_left(node) node_namespace_pod:kube_pod_info:{node=~"$3"})`
,
"pod_memory_usage_node"
:
`sum by (node, pod) (label_join(container_memory_usage_bytes{job="kubelet",pod_name=~"$2", image!=""}, "pod", " ", "pod_name") * on (namespace, pod) group_left(node) node_namespace_pod:kube_pod_info:{node=~"$3"})`
,
"pod_memory_usage_wo_cache_node"
:
`sum by (node, pod) ((label_join(container_memory_usage_bytes{job="kubelet",pod_name=~"$2", image!=""}, "pod", " ", "pod_name") - label_join(container_memory_cache{job="kubelet",pod_name=~"$2", image!=""}, "pod", " ", "pod_name")) * on (namespace, pod) group_left(node) node_namespace_pod:kube_pod_info:{node=~"$3"})`
,
"pod_cpu_usage_node"
:
`sum by (node, pod_name) (irate(container_cpu_usage_seconds_total{job="kubelet",pod_name!="", pod_name=~"$2", image!=""}[5m]) * on (namespace, pod_name) group_left(node) label_join(node_namespace_pod:kube_pod_info:{node=~"$3"}, "pod_name", "", "pod", "_name"))`
,
"pod_memory_usage_node"
:
`sum by (node, pod_name) (container_memory_usage_bytes{job="kubelet",pod_name!="", pod_name=~"$2", image!=""} * on (namespace, pod_name) group_left(node) label_join(node_namespace_pod:kube_pod_info:{node=~"$3"}, "pod_name", "", "pod", "_name"))`
,
"pod_memory_usage_wo_cache_node"
:
`sum by (node, pod_name) ((container_memory_usage_bytes{job="kubelet",pod_name!="", pod_name=~"$2", image!=""} - container_memory_cache{job="kubelet",pod_name!="", pod_name=~"$2", image!=""}) * on (namespace, pod_name) group_left(node) label_join(node_namespace_pod:kube_pod_info:{node=~"$3"}, "pod_name", "", "pod", "_name"))`
,
"pod_net_bytes_transmitted_node"
:
`sum by (node, pod_name) (irate(container_network_transmit_bytes_total{pod_name!="", pod_name=~"$2", interface="eth0", job="kubelet"}[5m]) * on (pod_name) group_left(node) label_join(node_namespace_pod:kube_pod_info:{node=~"$3"}, "pod_name", "", "pod", "_name"))`
,
"pod_net_bytes_received_node"
:
`sum by (node, pod_name) (irate(container_network_receive_bytes_total{pod_name!="", pod_name=~"$2", interface="eth0", job="kubelet"}[5m]) * on (pod_name) group_left(node) label_join(node_namespace_pod:kube_pod_info:{node=~"$3"}, "pod_name", "", "pod", "_name"))`
,
// workload
"workload_pod_cpu_usage"
:
`sum(label_replace(sum(irate(container_cpu_usage_seconds_total{job="kubelet", namespace="$2", pod_name!="", pod_name=~"$3", image!=""}[5m])) by (namespace, pod_name) and on (pod_name) label_join(kube_pod_owner{namespace="$2", owner_name!="<none>"}, "pod_name", "", "pod", "_name"), "workload", "$1", "pod_name", "(.+)-(.+)")) by (namespace, workload)`
,
"workload_pod_memory_usage"
:
`sum(label_replace(sum(container_memory_usage_bytes{job="kubelet", namespace="$2", pod_name!="", pod_name=~"$3", image!=""}) by (namespace, pod_name) and on (pod_name) label_join(kube_pod_owner{namespace="$2", owner_name!="<none>"}, "pod_name", "", "pod", "_name"), "workload", "$1", "pod_name", "(.+)-(.+)")) by (namespace, workload)`
,
"workload_pod_memory_usage_wo_cache"
:
`sum(label_replace(sum(container_memory_usage_bytes{job="kubelet", namespace="$2", pod_name!="", pod_name=~"$3", image!=""} - container_memory_cache{job="kubelet", namespace="$2", pod_name!="", pod_name=~"$3", image!=""}) by (namespace, pod_name) and on (pod_name) label_join(kube_pod_owner{namespace="$2", owner_name!="<none>"}, "pod_name", "", "pod", "_name"), "workload", "$1", "pod_name", "(.+)-(.+)")) by (namespace, workload)`
,
"workload_pod_net_bytes_transmitted"
:
`sum(label_replace(sum(irate(container_network_transmit_bytes_total{namespace="$2", pod_name!="", pod_name=~"$3", interface="eth0", job="kubelet"}[5m])) by (namespace, pod_name) and on (pod_name) label_join(kube_pod_owner{namespace="$2", owner_name!="<none>"}, "pod_name", "", "pod", "_name"), "workload", "$1", "pod_name", "(.+)-(.+)")) by (namespace, workload)`
,
"workload_pod_net_bytes_received"
:
`sum(label_replace(sum(irate(container_network_receive_bytes_total{namespace="$2", pod_name!="", pod_name=~"$3", interface="eth0", job="kubelet"}[5m])) by (namespace, pod_name) and on (pod_name) label_join(kube_pod_owner{namespace="$2", owner_name!="<none>"}, "pod_name", "", "pod", "_name"), "workload", "$1", "pod_name", "(.+)-(.+)")) by (namespace, workload)`
,
// container
"container_cpu_usage"
:
`sum(irate(container_cpu_usage_seconds_total{namespace="$1", pod_name="$2", container_name="$3"}[5m])) by (namespace, pod_name, container_name)`
,
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录