Go언어 golang
golang grok / go언어 grok 패턴
미래의 고
2023. 3. 27. 21:18
Grok 패턴은 로그 파싱을 편하게 하기 위해 나왔습니다.
아래 patterns.go를 봐보면, 정규식들의 집합체입니다.
그래서 정규식을 직접 쓰는 것보다 간편하게 string을 파싱하는데 유용합니다.
동시에 매칭 시 Key, Value를 사용할 수 있어 깔끔한 코딩을 하는 데 도움이 됩니다. (어느정도는... 만능은 아닙니다.)이번 포스팅에는 간단하게 오픈소스 검증만 하고, 다음 포스팅에 예전에 만들었던 syslog파싱에 적용해 봐야겠습니다.
정의되어있는 grok 패턴들...

package main
import (
"fmt"
"github.com/vjeantet/grok"
)
func main() {
g, _ := grok.New()
// 예전 포스팅에 Syslog 샘플.
rfc3164 := "<34>Oct 11 22:14:15 mymachine su: 'su root' failed for lonvick on /dev/pts/8"
values, _ := g.Parse("<%{NUMBER:facility}>%{DATA:date} %{TIME:time} %{WORD:process} %{GREEDYDATA:msg} ", rfc3164)
for k, v := range values {
fmt.Printf("%+20s: %s\n", k, v)
}
}