Skip to content

Instantly share code, notes, and snippets.

@tomoyk
Created November 10, 2022 08:47
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save tomoyk/f2e235936596a8cc11108fe0d68e0b50 to your computer and use it in GitHub Desktop.
Save tomoyk/f2e235936596a8cc11108fe0d68e0b50 to your computer and use it in GitHub Desktop.
import re
match_pattern = (
# '[2022-05-12T00:57:09.548Z]'
r"\[(?P<DateTime>\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}.\d{3}Z)]"
r' "(?P<Method>\w+)' # 'GET'
r" (?P<Path>[^ ]+)" # '/author'
r' (?P<Protocol>[^ ]+)"' # 'HTTP/1.1'
r" (?P<Status>\d{,3})" # '200'
r' (?P<_Details>[^ ]+ [^ ]+ [^ ]+ "-")' # '- via_upstream - "-"'
r" (?P<_Sizes>[-\d]+ [-\d]+ [-\d]+ [-\d]+)" # '0 11462 7 7'
r' "(?P<XForwardFor>[\.,\-\w]+)"' # "192.168.200.1,10.42.0.0"
r' "(?P<UserAgent>[^"]+)"' # "Python/3.9 aiohttp/3.8.1"
r' "(?P<ReqId>[\-\w]+)"' # '"ef217580-7229-9d84-b9b2-8d7bd3dfcca4"'
r' "(?P<ReqAuthority>[\-\:\.\w]+)"' # '"paper-app.paper:4000"'
r' "(?P<UpstreamHost>[\-\:\.\d]+)"' # '"10.42.3.158:8000"'
# 'outbound|4000||paper-app.paper.svc.cluster.local'
r" (?P<UpstreamCluster>\w+\|\d+\|\w*\|[\-\.\w]*)"
r" (?P<UpstreamLocalAddr>[\-\:\.\w]+)" # '10.42.3.121:58312'
r" (?P<DownstreamLocalAddr>[\:\.\w-]+)" # '10.43.148.153:9200'
r" (?P<DownstreamRemoteAddr>[\:\.\w-]+)" # '10.42.3.163:47890'
# 'outbound_.8000_._.httpbin.foo.svc.cluster.local'
r" (?P<ReqServerName>[^ ]+)"
r" (?P<RouteName>[^ ]+)" # 'default'
# r' "(?P<EndpointMethod>\w+)'
# r' (?P<EndpointPath>[^ ]+)"'
# r" (?P<ServiceTracing>([_\w\d\-]+\(\d+\)\|)+)"
)
def parser(raw_text: str):
matched = re.match(match_pattern, raw_text)
if matched is None:
return None
return matched.groupdict()
def main():
import json
raw_txt = """[2022-05-25T06:38:13.956Z] "GET / HTTP/1.1" 200 - via_upstream - "-" 0 35430 6 6 "-" "Python/3.9 aiohttp/3.8.1" "e4c5583b-565c-9026-8e5d-974bdf8ab467" "service2.prod:4000" "10.42.2.204:4000" inbound|4000|| 127.0.0.6:56089 10.42.2.204:4000 10.42.3.252:54568 - default "GET /" service2(200)|"""
# raw_txt = """[2022-05-25T06:38:13.956Z] "GET / HTTP/1.1" 200 - via_upstream - "-" 0 35430 6 6 "-" "Python/3.9 aiohttp/3.8.1" "e4c5583b-565c-9026-8e5d-974bdf8ab467" "service2.prod:4000" "10.42.2.204:4000" inbound|4000|| 127.0.0.6:56089 10.42.2.204:4000 10.42.3.252:54568 - default "GET /" service2(200)|service3(200)|"""
print(raw_txt)
result = parser(raw_txt)
print(json.dumps(result, indent=2))
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment