Skip to content

Commit f61c5c6

Browse files
authored
mvp parquet (#80)
1 parent 63fdcaf commit f61c5c6

File tree

7 files changed

+487
-85
lines changed

7 files changed

+487
-85
lines changed

cmd/dnsmonster/main.go

Lines changed: 3 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -52,7 +52,7 @@ func handleInterrupt(ctx context.Context) {
5252
log.Infof("SIGINT Received. Stopping capture...")
5353
go util.GlobalCancel()
5454
go ctx.Done()
55-
<-time.After(2 * time.Second)
55+
<-time.After(4 * time.Second)
5656
log.Fatal("emergency exit")
5757
os.Exit(1)
5858
}()
@@ -106,9 +106,10 @@ func main() {
106106

107107
// block until capture and output finish their loop, in order to exit cleanly
108108
g.Wait()
109-
// <-time.After(2 * time.Second)
109+
<-time.After(4 * time.Second)
110110
// print metrics for one last time before exiting the program
111111
metricsJSON, _ := json.Marshal(metrics.DefaultRegistry.GetAll())
112112
os.Stderr.WriteString(fmt.Sprintf("metrics: %s\n", metricsJSON))
113113
}
114+
114115
// vim: foldmethod=marker

go.mod

Lines changed: 64 additions & 26 deletions
Original file line numberDiff line numberDiff line change
@@ -3,46 +3,61 @@ module github.com/mosajjal/dnsmonster
33
go 1.20
44

55
require (
6-
github.com/ClickHouse/clickhouse-go/v2 v2.10.1
6+
github.com/ClickHouse/clickhouse-go/v2 v2.14.2
77
github.com/arthurkiller/rollingwriter v1.1.3
88
github.com/deathowl/go-metrics-prometheus v0.0.0-20221009205350-f2a1482ba35b
99
github.com/golang-collections/collections v0.0.0-20130729185459-604e922904d3
10-
github.com/gopacket/gopacket v1.1.0
10+
github.com/gopacket/gopacket v1.1.1
1111
github.com/hashicorp/go-syslog v1.0.0
1212
github.com/influxdata/influxdb-client-go/v2 v2.12.3
1313
github.com/jackc/pgx/v4 v4.18.1
14-
github.com/prometheus/client_golang v1.16.0
14+
github.com/parquet-go/parquet-go v0.18.0
15+
github.com/prometheus/client_golang v1.17.0
1516
github.com/rcrowley/go-metrics v0.0.0-20201227073835-cf1acfcdf475
1617
github.com/syntaqx/go-metrics-datadog v0.1.1
17-
golang.org/x/sync v0.3.0
18+
golang.org/x/sync v0.4.0
1819
)
1920

2021
require (
21-
github.com/ClickHouse/ch-go v0.57.0 // indirect
22+
github.com/BurntSushi/toml v1.3.2 // indirect
23+
github.com/ClickHouse/ch-go v0.58.2 // indirect
24+
github.com/CloudyKit/fastprinter v0.0.0-20200109182630-33d98a066a53 // indirect
25+
github.com/CloudyKit/jet/v6 v6.2.0 // indirect
2226
github.com/DataDog/datadog-go v4.8.3+incompatible // indirect
27+
github.com/Joker/jade v1.1.3 // indirect
2328
github.com/Microsoft/go-winio v0.6.1 // indirect
29+
github.com/Shopify/goreferrer v0.0.0-20220729165902-8cddb4f5de06 // indirect
2430
github.com/andybalholm/brotli v1.0.5 // indirect
2531
github.com/apapsch/go-jsonmerge/v2 v2.0.0 // indirect
32+
github.com/aymerick/douceur v0.2.0 // indirect
2633
github.com/beorn7/perks v1.0.1 // indirect
2734
github.com/cespare/xxhash/v2 v2.2.0 // indirect
28-
github.com/deepmap/oapi-codegen v1.13.0 // indirect
35+
github.com/chenzhuoyu/iasm v0.9.0 // indirect
36+
github.com/deepmap/oapi-codegen v1.15.0 // indirect
2937
github.com/farsightsec/golang-framestream v0.3.0 // indirect
38+
github.com/fatih/structs v1.1.0 // indirect
3039
github.com/felixge/fgprof v0.9.3 // indirect
40+
github.com/flosch/pongo2/v4 v4.0.2 // indirect
41+
github.com/fortytw2/leaktest v1.3.0 // indirect
3142
github.com/gabriel-vasile/mimetype v1.4.2 // indirect
3243
github.com/gin-contrib/sse v0.1.0 // indirect
3344
github.com/gin-gonic/gin v1.9.1 // indirect
3445
github.com/go-faster/city v1.0.1 // indirect
3546
github.com/go-faster/errors v0.6.1 // indirect
3647
github.com/go-playground/locales v0.14.1 // indirect
3748
github.com/go-playground/universal-translator v0.18.1 // indirect
38-
github.com/go-playground/validator/v10 v10.14.1 // indirect
49+
github.com/go-playground/validator/v10 v10.15.5 // indirect
3950
github.com/goccy/go-json v0.10.2 // indirect
4051
github.com/golang/protobuf v1.5.3 // indirect
41-
github.com/google/pprof v0.0.0-20230602150820-91b7bce49751 // indirect
42-
github.com/google/uuid v1.3.0 // indirect
52+
github.com/golang/snappy v0.0.4 // indirect
53+
github.com/gomarkdown/markdown v0.0.0-20230922112808-5421fefb8386 // indirect
54+
github.com/google/pprof v0.0.0-20230926050212-f7f687d19a98 // indirect
55+
github.com/google/uuid v1.3.1 // indirect
56+
github.com/gorilla/css v1.0.0 // indirect
4357
github.com/influxdata/line-protocol v0.0.0-20210922203350-b1ad95c89adf // indirect
58+
github.com/iris-contrib/schema v0.0.6 // indirect
4459
github.com/jackc/chunkreader/v2 v2.0.1 // indirect
45-
github.com/jackc/pgconn v1.14.0 // indirect
60+
github.com/jackc/pgconn v1.14.1 // indirect
4661
github.com/jackc/pgio v1.0.0 // indirect
4762
github.com/jackc/pgpassfile v1.0.0 // indirect
4863
github.com/jackc/pgproto3/v2 v2.3.2 // indirect
@@ -51,52 +66,75 @@ require (
5166
github.com/jackc/puddle v1.3.0 // indirect
5267
github.com/josharian/intern v1.0.0 // indirect
5368
github.com/json-iterator/go v1.1.12 // indirect
69+
github.com/kataras/blocks v0.0.8 // indirect
70+
github.com/kataras/golog v0.1.9 // indirect
71+
github.com/kataras/iris/v12 v12.2.7 // indirect
72+
github.com/kataras/pio v0.0.12 // indirect
73+
github.com/kataras/sitemap v0.0.6 // indirect
74+
github.com/kataras/tunnel v0.0.4 // indirect
5475
github.com/klauspost/cpuid/v2 v2.2.5 // indirect
55-
github.com/labstack/echo/v4 v4.10.2 // indirect
76+
github.com/kr/text v0.2.0 // indirect
77+
github.com/labstack/echo/v4 v4.11.1 // indirect
5678
github.com/labstack/gommon v0.4.0 // indirect
5779
github.com/leodido/go-urn v1.2.4 // indirect
80+
github.com/lib/pq v1.10.4 // indirect
81+
github.com/mailgun/raymond/v2 v2.0.48 // indirect
5882
github.com/mattn/go-colorable v0.1.13 // indirect
5983
github.com/mattn/go-isatty v0.0.19 // indirect
84+
github.com/mattn/go-runewidth v0.0.15 // indirect
6085
github.com/matttproud/golang_protobuf_extensions v1.0.4 // indirect
86+
github.com/microcosm-cc/bluemonday v1.0.25 // indirect
6187
github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd // indirect
6288
github.com/modern-go/reflect2 v1.0.2 // indirect
63-
github.com/paulmach/orb v0.9.2 // indirect
64-
github.com/pelletier/go-toml/v2 v2.0.8 // indirect
89+
github.com/olekukonko/tablewriter v0.0.5 // indirect
90+
github.com/paulmach/orb v0.10.0 // indirect
91+
github.com/pelletier/go-toml/v2 v2.1.0 // indirect
6592
github.com/pierrec/lz4/v4 v4.1.18 // indirect
66-
github.com/prometheus/client_model v0.4.0 // indirect
93+
github.com/prometheus/client_model v0.5.0 // indirect
6794
github.com/prometheus/common v0.44.0 // indirect
68-
github.com/prometheus/procfs v0.11.0 // indirect
95+
github.com/prometheus/procfs v0.12.0 // indirect
96+
github.com/rivo/uniseg v0.4.4 // indirect
6997
github.com/robfig/cron v1.2.0 // indirect
98+
github.com/russross/blackfriday/v2 v2.1.0 // indirect
99+
github.com/schollz/closestmatch v2.1.0+incompatible // indirect
70100
github.com/segmentio/asm v1.2.0 // indirect
101+
github.com/segmentio/encoding v0.3.6 // indirect
71102
github.com/shopspring/decimal v1.3.1 // indirect
103+
github.com/tdewolff/minify/v2 v2.12.9 // indirect
104+
github.com/tdewolff/parse/v2 v2.6.8 // indirect
72105
github.com/twitchyliquid64/golang-asm v0.15.1 // indirect
73106
github.com/ugorji/go/codec v1.2.11 // indirect
74107
github.com/valyala/bytebufferpool v1.0.0 // indirect
75108
github.com/valyala/fasttemplate v1.2.2 // indirect
76-
go.opentelemetry.io/otel v1.16.0 // indirect
77-
go.opentelemetry.io/otel/trace v1.16.0 // indirect
78-
golang.org/x/arch v0.3.0 // indirect
79-
golang.org/x/mod v0.11.0 // indirect
109+
github.com/vmihailenco/msgpack/v5 v5.4.0 // indirect
110+
github.com/vmihailenco/tagparser/v2 v2.0.0 // indirect
111+
github.com/yosssi/ace v0.0.5 // indirect
112+
go.opentelemetry.io/otel v1.19.0 // indirect
113+
go.opentelemetry.io/otel/trace v1.19.0 // indirect
114+
golang.org/x/arch v0.5.0 // indirect
115+
golang.org/x/exp v0.0.0-20231006140011-7918f672742d // indirect
116+
golang.org/x/mod v0.13.0 // indirect
80117
golang.org/x/text v0.13.0 // indirect
81-
golang.org/x/tools v0.10.0 // indirect
118+
golang.org/x/time v0.3.0 // indirect
119+
golang.org/x/tools v0.14.0 // indirect
120+
gopkg.in/ini.v1 v1.67.0 // indirect
82121
gopkg.in/yaml.v3 v3.0.1 // indirect
83122
)
84123

85124
require (
86-
github.com/bytedance/sonic v1.9.1
87-
github.com/chenzhuoyu/base64x v0.0.0-20221115062448-fe3a3abad311 // indirect
125+
github.com/bytedance/sonic v1.10.2
126+
github.com/chenzhuoyu/base64x v0.0.0-20230717121745-296ad89f973d // indirect
88127
github.com/dnstap/golang-dnstap v0.4.0
89-
github.com/fortytw2/leaktest v1.3.0 // indirect
90128
github.com/jessevdk/go-flags v1.5.1-0.20210607101731-3927b71304df
91-
github.com/klauspost/compress v1.16.6 // indirect
129+
github.com/klauspost/compress v1.17.0 // indirect
92130
github.com/mailru/easyjson v0.7.7 // indirect
93-
github.com/miekg/dns v1.1.55
131+
github.com/miekg/dns v1.1.56
94132
github.com/mosajjal/Go-Splunk-HTTP/splunk/v2 v2.0.7
95133
github.com/olivere/elastic v6.2.37+incompatible
96134
github.com/pkg/errors v0.9.1 // indirect
97135
github.com/pkg/profile v1.7.0
98136
github.com/rogpeppe/fastuuid v1.2.0
99-
github.com/segmentio/kafka-go v0.4.40
137+
github.com/segmentio/kafka-go v0.4.43
100138
github.com/sirupsen/logrus v1.9.3
101139
golang.org/x/crypto v0.14.0 // indirect
102140
golang.org/x/net v0.17.0

0 commit comments

Comments
 (0)