From 2b8a930a2e11326a98b2b49d9fe96adc05ff68a6 Mon Sep 17 00:00:00 2001 From: Adrien Aury <44274230+adrienaury@users.noreply.github.com> Date: Fri, 13 Sep 2024 16:02:07 +0200 Subject: [PATCH] perf: pgo and json serialisation optimizations (#325) * Add files via upload * perf: fast json serialization * style: lint * docs: CHANGELOG.md --- .devcontainer/Dockerfile | 2 +- CHANGELOG.md | 4 ++ cmd/pimo/default.pgo | Bin 0 -> 26295 bytes go.mod | 7 ++- go.sum | 15 ++++- pkg/model/ordered_dict.go | 124 +++++++++++++++++++++++--------------- pkg/model/process_mask.go | 2 +- pkg/timeline/timeline.go | 10 +-- 8 files changed, 101 insertions(+), 63 deletions(-) create mode 100644 cmd/pimo/default.pgo diff --git a/.devcontainer/Dockerfile b/.devcontainer/Dockerfile index 2f463835..157d0190 100755 --- a/.devcontainer/Dockerfile +++ b/.devcontainer/Dockerfile @@ -1,4 +1,4 @@ -FROM adrienaury/go-devcontainer:v2.0 +FROM adrienaury/go-devcontainer:v4.1 USER root diff --git a/CHANGELOG.md b/CHANGELOG.md index 6dcc128e..0cdafd2c 100755 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -14,6 +14,10 @@ Types of changes - `Fixed` for any bug fixes. - `Security` in case of vulnerabilities. +## [1.26.1] + +- `Fixed` performance issues on JSON serialization + ## [1.26.0] - `Added` property `preserve-list` to masking definition to be able to ignore masking specific values diff --git a/cmd/pimo/default.pgo b/cmd/pimo/default.pgo new file mode 100644 index 0000000000000000000000000000000000000000..5e2f2e1b16604fb66f80a8df41e1e1bdf706f556 GIT binary patch literal 26295 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 literal 0 HcmV?d00001 diff --git a/go.mod b/go.mod index 4772b0d5..c1e6ed66 100644 --- a/go.mod +++ b/go.mod @@ -1,13 +1,17 @@ module github.com/cgi-fr/pimo -go 1.20 +go 1.21 + +toolchain go1.22.2 require ( github.com/CGI-FR/xixo v0.1.8 github.com/Masterminds/sprig/v3 v3.3.0 github.com/adrienaury/zeromdc v0.1.1 github.com/capitalone/fpe v1.2.1 + github.com/goccy/go-json v0.10.3 github.com/goccy/go-yaml v1.12.0 + github.com/iancoleman/orderedmap v0.3.0 github.com/invopop/jsonschema v0.12.0 github.com/kenshaw/baseconv v0.1.1 github.com/labstack/echo/v4 v4.12.0 @@ -19,7 +23,6 @@ require ( github.com/spf13/cobra v1.8.1 github.com/stretchr/testify v1.9.0 github.com/zach-klippenstein/goregen v0.0.0-20160303162051-795b5e3961ea - gitlab.com/c0b/go-ordered-json v0.0.0-20201030195603-febf46534d5a golang.org/x/crypto v0.27.0 golang.org/x/exp v0.0.0-20240707233637-46b078467d37 golang.org/x/text v0.18.0 diff --git a/go.sum b/go.sum index 208af9f8..f4638093 100644 --- a/go.sum +++ b/go.sum @@ -29,15 +29,22 @@ github.com/fatih/color v1.13.0/go.mod h1:kLAiJbzzSOZDVNGyDpeOxJ47H46qBXwg5ILebYF github.com/felixge/fgprof v0.9.3 h1:VvyZxILNuCiUCSXtPtYmmtGvb65nqXh2QFWc0Wpf2/g= github.com/felixge/fgprof v0.9.3/go.mod h1:RdbpDgzqYVh/T9fPELJyV7EYJuHB55UTEULNun8eiPw= github.com/frankban/quicktest v1.14.6 h1:7Xjx+VpznH+oBnejlPUj8oUpdxnVs4f8XU8WnHkI4W8= +github.com/frankban/quicktest v1.14.6/go.mod h1:4ptaffx2x8+WTWXmUCuVU6aPUX1/Mz7zb5vbUoiM6w0= github.com/go-playground/locales v0.13.0 h1:HyWk6mgj5qFqCT5fjGBuRArbVDfE4hi8+e8ceBS/t7Q= +github.com/go-playground/locales v0.13.0/go.mod h1:taPMhCMXrRLJO55olJkUXHZBHCxTMfnGwq/HNwmWNS8= github.com/go-playground/universal-translator v0.17.0 h1:icxd5fm+REJzpZx7ZfpaD876Lmtgy7VtROAbHHXk8no= +github.com/go-playground/universal-translator v0.17.0/go.mod h1:UkSxE5sNxxRwHyU+Scu5vgOQjsIJAF8j9muTVoKLVtA= github.com/go-playground/validator/v10 v10.4.1 h1:pH2c5ADXtd66mxoE0Zm9SUhxE20r7aM3F26W0hOn+GE= +github.com/go-playground/validator/v10 v10.4.1/go.mod h1:nlOn6nFhuKACm19sB/8EGNn9GlaMV7XkbRSipzJ0Ii4= +github.com/goccy/go-json v0.10.3 h1:KZ5WoDbxAIgm2HNbYckL0se1fHD6rz5j4ywS6ebzDqA= +github.com/goccy/go-json v0.10.3/go.mod h1:oq7eo15ShAhp70Anwd5lgX2pLfOS3QCiwU/PULtXL6M= github.com/goccy/go-yaml v1.12.0 h1:/1WHjnMsI1dlIBQutrvSMGZRQufVO3asrHfTwfACoPM= github.com/goccy/go-yaml v1.12.0/go.mod h1:wKnAMd44+9JAAnGQpWVEgBzGt3YuTaQ4uXoHvE4m7WU= github.com/godbus/dbus/v5 v5.0.4/go.mod h1:xhWf0FNVPg57R7Z0UbKHbJfkEywrmjJnf7w5xrFpKfA= github.com/golang-jwt/jwt v3.2.2+incompatible h1:IfV12K8xAKAnZqdXVzCZ+TOjboZ2keLg81eXfW3O+oY= github.com/golang-jwt/jwt v3.2.2+incompatible/go.mod h1:8pz2t5EyA70fFQQSrl6XZXzqecmYZeUEB8OUGHkxJ+I= github.com/google/go-cmp v0.6.0 h1:ofyhxvXcZhMsU5ulbFiLKl/XBFqE1GSq7atu8tAmTRI= +github.com/google/go-cmp v0.6.0/go.mod h1:17dUlkBOakJ0+DkrSSNjCkIjxS6bF9zb3elmeNGIjoY= github.com/google/gxui v0.0.0-20151028112939-f85e0a97b3a4 h1:OL2d27ueTKnlQJoqLW2fc9pWYulFnJYLWzomGV7HqZo= github.com/google/gxui v0.0.0-20151028112939-f85e0a97b3a4/go.mod h1:Pw1H1OjSNHiqeuxAduB1BKYXIwFtsyrY47nEqSgEiCM= github.com/google/pprof v0.0.0-20211214055906-6f57359322fd h1:1FjCyPC+syAzJ5/2S8fqdZK1R22vvA0J7JZKcuOIQ7Y= @@ -48,6 +55,8 @@ github.com/gopherjs/gopherjs v0.0.0-20181017120253-0766667cb4d1 h1:EGx4pi6eqNxGa github.com/gopherjs/gopherjs v0.0.0-20181017120253-0766667cb4d1/go.mod h1:wJfORRmW1u3UXTncJ5qlYoELFm8eSnnEO6hX4iZ3EWY= github.com/huandu/xstrings v1.5.0 h1:2ag3IFq9ZDANvthTwTiqSSZLjDc+BedvHPAp5tJy2TI= github.com/huandu/xstrings v1.5.0/go.mod h1:y5/lhBue+AyNmUVz9RLU9xbLR0o4KIIExikq4ovT0aE= +github.com/iancoleman/orderedmap v0.3.0 h1:5cbR2grmZR/DiVt+VJopEhtVs9YGInGIxAoMJn+Ichc= +github.com/iancoleman/orderedmap v0.3.0/go.mod h1:XuLcCUkdL5owUCQeF2Ue9uuw1EptkJDkXXS7VoV7XGE= github.com/ianlancetaylor/demangle v0.0.0-20210905161508-09a460cdf81d/go.mod h1:aYm2/VgdVmcIU8iMfdMvDMsRAQjcfZSKFby6HOFvi/w= github.com/inconshreveable/mousetrap v1.1.0 h1:wN+x4NVGpMsO7ErUn/mUI3vEoE6Jt13X2s0bqwp9tc8= github.com/inconshreveable/mousetrap v1.1.0/go.mod h1:vpF70FUmC8bwa3OWnCshd2FqLfsEA9PFc4w1p2J65bw= @@ -59,12 +68,15 @@ github.com/jtolds/gls v4.20.0+incompatible/go.mod h1:QJZ7F/aHp+rZTRtaJ1ow/lLfFfV github.com/kenshaw/baseconv v0.1.1 h1:oAu/C7ipUT2PqT9DT0mZDGDg4URIglizZMjPv9oCu0E= github.com/kenshaw/baseconv v0.1.1/go.mod h1:yy9zGmnnR6vgOxOQb702nVdAG30JhyYZpj/5/m0siRI= github.com/kr/pretty v0.3.1 h1:flRD4NNwYAUpkphVc1HcthR4KEIFJ65n8Mw5qdRn3LE= +github.com/kr/pretty v0.3.1/go.mod h1:hoEshYVHaxMs3cyo3Yncou5ZscifuDolrwPKZanG3xk= github.com/kr/text v0.2.0 h1:5Nx0Ya0ZqY2ygV366QzturHI13Jq95ApcVaJBhpS+AY= +github.com/kr/text v0.2.0/go.mod h1:eLer722TekiGuMkidMxC/pM04lWEeraHUUmBw8l2grE= github.com/labstack/echo/v4 v4.12.0 h1:IKpw49IMryVB2p1a4dzwlhP1O2Tf2E0Ir/450lH+kI0= github.com/labstack/echo/v4 v4.12.0/go.mod h1:UP9Cr2DJXbOK3Kr9ONYzNowSh7HP0aG0ShAyycHSJvM= github.com/labstack/gommon v0.4.2 h1:F8qTUNXgG1+6WQmqoUWnz8WiEU60mXVVw0P4ht1WRA0= github.com/labstack/gommon v0.4.2/go.mod h1:QlUFxVM+SNXhDL/Z7YhocGIBYOiwB0mXm1+1bAPHPyU= github.com/leodido/go-urn v1.2.0 h1:hpXL4XnriNwQ/ABnpepYM/1vCLWNDfUNts8dX3xTG6Y= +github.com/leodido/go-urn v1.2.0/go.mod h1:+8+nEpDfqqsY+g338gtMEUOtuK+4dEMhiQEgxpxOKII= github.com/mailru/easyjson v0.7.7 h1:UGYAvKxe3sBsEDzO8ZeWOSlIQfWFlxbzLZe7hwFURr0= github.com/mailru/easyjson v0.7.7/go.mod h1:xzfreul335JAWq5oZzymOObrkdz5UnU4kGfJJLY9Nlc= github.com/mattn/anko v0.1.9 h1:OpdRDvjOY/FQXoGXkN0n7b0br4a4fHB5hhsaq0Cd3ds= @@ -88,6 +100,7 @@ github.com/pkg/profile v1.7.0/go.mod h1:8Uer0jas47ZQMJ7VD+OHknK4YDY07LPUC6dEvqDj github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM= github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4= github.com/rogpeppe/go-internal v1.9.0 h1:73kH8U+JUqXU8lRuOHeVHaa/SZPifC7BkcraZVejAe8= +github.com/rogpeppe/go-internal v1.9.0/go.mod h1:WtVeX8xhTBvf0smdhujwtBcq4Qrzq/fJaraNFVN+nFs= github.com/rs/xid v1.5.0/go.mod h1:trrq9SKmegXys3aeAKXMUTdJsYXVwGY3RLcfgqegfbg= github.com/rs/zerolog v1.33.0 h1:1cU2KZkvPxNyfgEmhHAz/1A9Bz+llsdYzklWFzgp0r8= github.com/rs/zerolog v1.33.0/go.mod h1:/7mN4D5sKwJLZQ2b/znpjC3/GQWY/xaDXUM0kKWRHss= @@ -118,8 +131,6 @@ github.com/wk8/go-ordered-map/v2 v2.1.8 h1:5h/BUHu93oj4gIdvHHHGsScSTMijfx5PeYkE/ github.com/wk8/go-ordered-map/v2 v2.1.8/go.mod h1:5nJHM5DyteebpVlHnWMV0rPz6Zp7+xBAnxjb1X5vnTw= github.com/zach-klippenstein/goregen v0.0.0-20160303162051-795b5e3961ea h1:CyhwejzVGvZ3Q2PSbQ4NRRYn+ZWv5eS1vlaEusT+bAI= github.com/zach-klippenstein/goregen v0.0.0-20160303162051-795b5e3961ea/go.mod h1:eNr558nEUjP8acGw8FFjTeWvSgU1stO7FAO6eknhHe4= -gitlab.com/c0b/go-ordered-json v0.0.0-20201030195603-febf46534d5a h1:DxppxFKRqJ8WD6oJ3+ZXKDY0iMONQDl5UTg2aTyHh8k= -gitlab.com/c0b/go-ordered-json v0.0.0-20201030195603-febf46534d5a/go.mod h1:NREvu3a57BaK0R1+ztrEzHWiZAihohNLQ6trPxlIqZI= golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w= golang.org/x/crypto v0.27.0 h1:GXm2NjJrPaiv/h1tb2UH8QfgC/hOf/+z0p6PT8o1w7A= golang.org/x/crypto v0.27.0/go.mod h1:1Xngt8kV6Dvbssa53Ziq6Eqn0HqbZi5Z6R0ZpwQzt70= diff --git a/pkg/model/ordered_dict.go b/pkg/model/ordered_dict.go index d19eef79..e9412566 100644 --- a/pkg/model/ordered_dict.go +++ b/pkg/model/ordered_dict.go @@ -1,11 +1,14 @@ package model import ( + "bytes" "encoding/json" "fmt" "github.com/rs/zerolog/log" - "gitlab.com/c0b/go-ordered-json" + + goccy "github.com/goccy/go-json" + ordered "github.com/iancoleman/orderedmap" ) type Dictionary struct { @@ -17,7 +20,7 @@ func NewPackedDictionary() Dictionary { } func NewDictionary() Dictionary { - return Dictionary{ordered.NewOrderedMap()} + return Dictionary{ordered.New()} } func Copy(other Entry) Entry { @@ -37,19 +40,15 @@ func CopyDictionary(other Dictionary) Dictionary { return NewDictionary() } - om := ordered.NewOrderedMap() - iter := other.EntriesIter() + om := ordered.New() - for { - pair, ok := iter() - if !ok { - break - } - switch typedVal := pair.Value.(type) { + for _, key := range other.Keys() { + value := other.Get(key) + switch typedVal := value.(type) { case Dictionary: - om.Set(pair.Key, CopyDictionary(typedVal)) + om.Set(key, CopyDictionary(typedVal)) default: - om.Set(pair.Key, pair.Value) + om.Set(key, value) } } return Dictionary{om} @@ -72,31 +71,29 @@ func CleanTypes(inter interface{}) interface{} { } return dict case *Dictionary: - iter := typedInter.EntriesIter() dict := NewDictionary() - for pair, ok := iter(); ok; pair, ok = iter() { - dict.Set(pair.Key, CleanTypes(pair.Value)) + for _, key := range typedInter.Keys() { + dict.Set(key, CleanTypes(typedInter.Get(key))) } return dict case Dictionary: - iter := typedInter.EntriesIter() dict := NewDictionary() - for pair, ok := iter(); ok; pair, ok = iter() { - dict.Set(pair.Key, CleanTypes(pair.Value)) + for _, key := range typedInter.Keys() { + dict.Set(key, CleanTypes(typedInter.Get(key))) } return dict case *ordered.OrderedMap: - iter := typedInter.EntriesIter() dict := NewDictionary() - for pair, ok := iter(); ok; pair, ok = iter() { - dict.Set(pair.Key, CleanTypes(pair.Value)) + for _, key := range typedInter.Keys() { + value, _ := typedInter.Get(key) + dict.Set(key, CleanTypes(value)) } return dict case ordered.OrderedMap: - iter := typedInter.EntriesIter() dict := NewDictionary() - for pair, ok := iter(); ok; pair, ok = iter() { - dict.Set(pair.Key, CleanTypes(pair.Value)) + for _, key := range typedInter.Keys() { + value, _ := typedInter.Get(key) + dict.Set(key, CleanTypes(value)) } return dict case []interface{}: @@ -165,31 +162,29 @@ func Untyped(inter interface{}) interface{} { } return cleanmap case *Dictionary: - iter := typedInter.EntriesIter() cleanmap := map[string]interface{}{} - for pair, ok := iter(); ok; pair, ok = iter() { - cleanmap[pair.Key] = Untyped(pair.Value) + for _, key := range typedInter.Keys() { + cleanmap[key] = Untyped(typedInter.Get(key)) } return cleanmap case Dictionary: - iter := typedInter.EntriesIter() cleanmap := map[string]interface{}{} - for pair, ok := iter(); ok; pair, ok = iter() { - cleanmap[pair.Key] = Untyped(pair.Value) + for _, key := range typedInter.Keys() { + cleanmap[key] = Untyped(typedInter.Get(key)) } return cleanmap case *ordered.OrderedMap: - iter := typedInter.EntriesIter() cleanmap := map[string]interface{}{} - for pair, ok := iter(); ok; pair, ok = iter() { - cleanmap[pair.Key] = Untyped(pair.Value) + for _, key := range typedInter.Keys() { + value, _ := typedInter.Get(key) + cleanmap[key] = Untyped(value) } return cleanmap case ordered.OrderedMap: - iter := typedInter.EntriesIter() cleanmap := map[string]interface{}{} - for pair, ok := iter(); ok; pair, ok = iter() { - cleanmap[pair.Key] = Untyped(pair.Value) + for _, key := range typedInter.Keys() { + value, _ := typedInter.Get(key) + cleanmap[key] = Untyped(value) } return cleanmap case []interface{}: @@ -234,31 +229,29 @@ func UnorderedTypes(inter interface{}) interface{} { } return cleanmap case *Dictionary: - iter := typedInter.EntriesIter() cleanmap := map[string]Entry{} - for pair, ok := iter(); ok; pair, ok = iter() { - cleanmap[pair.Key] = UnorderedTypes(pair.Value) + for _, key := range typedInter.Keys() { + cleanmap[key] = UnorderedTypes(typedInter.Get(key)) } return cleanmap case Dictionary: - iter := typedInter.EntriesIter() cleanmap := map[string]Entry{} - for pair, ok := iter(); ok; pair, ok = iter() { - cleanmap[pair.Key] = UnorderedTypes(pair.Value) + for _, key := range typedInter.Keys() { + cleanmap[key] = UnorderedTypes(typedInter.Get(key)) } return cleanmap case *ordered.OrderedMap: - iter := typedInter.EntriesIter() cleanmap := map[string]Entry{} - for pair, ok := iter(); ok; pair, ok = iter() { - cleanmap[pair.Key] = UnorderedTypes(pair.Value) + for _, key := range typedInter.Keys() { + value, _ := typedInter.Get(key) + cleanmap[key] = UnorderedTypes(value) } return cleanmap case ordered.OrderedMap: - iter := typedInter.EntriesIter() cleanmap := map[string]Entry{} - for pair, ok := iter(); ok; pair, ok = iter() { - cleanmap[pair.Key] = UnorderedTypes(pair.Value) + for _, key := range typedInter.Keys() { + value, _ := typedInter.Get(key) + cleanmap[key] = UnorderedTypes(value) } return cleanmap case []interface{}: @@ -294,7 +287,7 @@ func UnorderedTypes(inter interface{}) interface{} { } func (d Dictionary) IsPacked() bool { - _, packed := d.GetValue(".") + _, packed := d.OrderedMap.Get(".") return packed } @@ -353,3 +346,36 @@ func (d Dictionary) With(key string, value interface{}) Dictionary { result.Set(key, CleanTypes(value)) return result } + +func (d Dictionary) GetValue(key string) (Entry, bool) { + return d.OrderedMap.Get(key) +} + +func (d Dictionary) Get(key string) Entry { + entry, _ := d.OrderedMap.Get(key) + return entry +} + +func (d Dictionary) MarshalJSON() ([]byte, error) { + var buf bytes.Buffer + buf.WriteByte('{') + encoder := goccy.NewEncoder(&buf) + for i, k := range d.Keys() { + if i > 0 { + buf.WriteByte(',') + } + // add key + if err := encoder.Encode(k); err != nil { + return nil, err + } + buf.Truncate(buf.Len() - 1) // remove last new line + buf.WriteByte(':') + // add value + if err := encoder.Encode(d.Get(k)); err != nil { + return nil, err + } + buf.Truncate(buf.Len() - 1) // remove last new line + } + buf.WriteByte('}') + return buf.Bytes(), nil +} diff --git a/pkg/model/process_mask.go b/pkg/model/process_mask.go index fd073293..723759bf 100644 --- a/pkg/model/process_mask.go +++ b/pkg/model/process_mask.go @@ -77,7 +77,7 @@ func (mep *MaskEngineProcess) ProcessDictionary(dictionary Dictionary, out Colle if ret == nil { out.Collect(result) - return + return nil } if ret != nil && skipLineOnError { diff --git a/pkg/timeline/timeline.go b/pkg/timeline/timeline.go index 2b34fe92..5d261dda 100644 --- a/pkg/timeline/timeline.go +++ b/pkg/timeline/timeline.go @@ -131,14 +131,8 @@ func (me MaskEngine) Mask(e model.Entry, context ...model.Dictionary) (model.Ent initialState := map[string]*int64{} if dict, ok := e.(model.Dictionary); ok { - iter := dict.EntriesIter() - for { - pair, ok := iter() - if !ok { - break - } - - initialState[pair.Key] = me.formatTimestamp(pair.Value) + for _, key := range dict.Keys() { + initialState[key] = me.formatTimestamp(dict.Get(key)) } }