regex:如何查找所有匹配的组(值:特定服务的时间和值)



我想通过这个正则表达式为特定行选择时间和值时间:美国东部时间2021年6月22日星期二11:05:01k8s_POD_eventing-kafka-cp-kafka示例30KiB 的使用内存

((?<time>(.*?)EDT 2021)((.|n)*)(?<memoryblock>(?<=(eventing-kafka-cp-kafka)).*%(s)*(?<memory>.*)s(?=/).*(?=15.51GiB)))

文本:

=======================
Tue 22 Jun 11:05:01 EDT 2021

====================
=== DOCKER STATS ===
====================
CONTAINER ID        NAME                                                                                                                                       CPU %               MEM USAGE / LIMIT     MEM %               NET I/O             BLOCK I/O           PIDS
0c3f02131388        k8s_istio-proxy_istio-ingressgateway-759f7bff9f-l894p_istio-system_81979eee-1d7c-4eae-af8d-18d67dee1838_0                                  0.27%               80.34MiB / 200MiB     40.17%              0B / 0B             0B / 0B             47
4d06eb9f902f        k8s_POD_istio-ingressgateway-759f7bff9f-l894p_istio-system_81979eee-1d7c-4eae-af8d-18d67dee1838_0                                          0.00%               40KiB / 15.51GiB      -system_a9af3319-421a-492b-a8d2-5ed450509c31_0                                             0.37%               42.81MiB / 100MiB     42.81%              0B / 0B             0B / 0B             25
139321b972fa        k8s_POD_istio-pilot-854fd575d9-tjgb5_istio-system_a9af3319-421a-492b-a8d2-5ed450509c31_0                                                   0.00%               44KiB / 15.51GiB      0.00%               0B / 0B             0B / 0B             1
8045a70d159c        k8s_istio-proxy_istio-policy-54b6cdfd7c-hjbp2_istio-system_590ce59c-0fc9-462a-976c-7bf79dd20d6d_0                                          0.22%               25.97MiB / 200MiB     12.99%              0B / 0B             0B / 0B             42
60be0e4ab808        k8s_mixer_istio-policy-54b6cdfd7c-hjbp2_istio-system_590ce59c-0fc9-462a-976c-7bf79dd20d6d_0                                                0.02%               24.12MiB / 100MiB     24.12%              0B / 0B             0B / 0B             16
f0f5c7bdf247        k8s_POD_istio-policy-54b6cdfd7c-hjbp2_istio-system_590ce59c-0fc9-462a-976c-7bf79dd20d6d_0                                                  0.00%               44KiB / 15.51GiB  
d72a5583d634        k8s_POD_eventing-kafka-cp-kafka-2_default_7c6d5663-02a0-4013-923c-2b56d1e54ed4_0                                                           0.00%               30KiB / 15.51GiB     
====================
=== MEMORY USAGE ===
====================
top - 11:10:04 up 96 days, 18:31,  0 users,  load average: 0.76, 0.78, 0.77
=======================
Tue 22 Jun 11:10:01 EDT 2021

====================
=== DOCKER STATS ===
====================
CONTAINER ID        NAME                                                                                                                                       CPU %               MEM USAGE / LIMIT     MEM %               NET I/O             BLOCK I/O           PIDS
0c3f02131388        k8s_istio-proxy_istio-ingressgateway-759f7bff9f-l894p_istio-system_81979eee-1d7c-4eae-af8d-18d67dee1838_0                                  0.22%               80.34MiB / 200MiB     40.17%              0B / 0B             0B / 0B             47
4d06eb9f902f        k8s_POD_istio-ingressgateway-759f7bff9f-l894p_istio-system_81979eee-1d7c-4eae-af8d-18d67dee1838_0                                          0.00%               40KiB / 15.51GiB      0.00%               0B / 0B             0B / 0B             1
b92036f42af2        k8s_cp-kafka-broker_eventing-kafka-cp-kafka-2_default_7c6d5663-02a0-4013-923c-2b56d1e54ed4_0                                               14.67%              643.3MiB / 10GiB      6.28%               0B / 0B             0B / 0B             76
d72a5583d634        k8s_POD_eventing-kafka-cp-kafka-2_default_7c6d5663-02a0-4013-923c-2b56d1e54ed4_0                                                           0.00%               40KiB / 15.51GiB

但是,它选择第一个时间值和最后一个内存值

预期:

时间:美国东部时间2021年6月22日星期二11:05:01

内存:30KiB

时间:美国东部时间2021年6月22日星期二11:10:01

内存:40KiB

实际:

时间:美国东部时间2021年6月22日星期二11:05:01

内存:40KiB

从开始日期开始,您可以将尽可能少的行与EDT匹配,直到您将一行与事件kafka cp kafka匹配,并且在匹配内存部分后具有值15.51GiB

^(?<time>.* EDT 2021)(?:n.*)*?n.*eventing-kafka-cp-kafka.* (?<memory>d+[^n/]*) / 15.51GiB
  • ^字符串开始
  • (?<time>.* EDT 2021)命名组time
  • (?:n.*)*?尽可能少地匹配行
  • n.*eventing-kafka-cp-kafka将换行符与文本匹配
  • .* (?<memory>d+ [^n/]*)命名组memory,匹配1+个数字,直到第一个/
  • / 15.51GiB按字面匹配

Regex演示

最新更新