Skip to content
This repository was archived by the owner on Jan 10, 2023. It is now read-only.

Commit 014097b

Browse files
authored
Merge pull request #3 from alicebob/master
pull master again
2 parents 550f8e9 + da60dd5 commit 014097b

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

85 files changed

+6789
-2450
lines changed

Makefile

+1-1
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,6 @@
11
.PHONY: all build test vendor release
22

3-
all: vendor build test
3+
all: build test
44

55
build:
66
go build -mod=vendor

go.mod

+3-6
Original file line numberDiff line numberDiff line change
@@ -4,14 +4,11 @@ go 1.12
44

55
require (
66
github.com/aerospike/aerospike-client-go v1.29.0
7-
github.com/beorn7/perks v0.0.0-20160804104726-4c0e84591b9a // indirect
8-
github.com/matttproud/golang_protobuf_extensions v1.0.1 // indirect
97
github.com/onsi/ginkgo v1.8.0 // indirect
108
github.com/onsi/gomega v1.5.0 // indirect
11-
github.com/prometheus/client_golang v0.0.0-20170907150625-671c87b04728
12-
github.com/prometheus/client_model v0.0.0-20170216185247-6f3806018612
13-
github.com/prometheus/common v0.0.0-20170908161822-2f17f4a9d485 // indirect
14-
github.com/prometheus/procfs v0.0.0-20170703101242-e645f4e5aaa8 // indirect
9+
github.com/prometheus/client_golang v0.9.3
10+
github.com/prometheus/client_model v0.0.0-20190129233127-fd36f4220a90
11+
github.com/prometheus/procfs v0.0.0-20190519111021-9935e8e0588d // indirect
1512
github.com/yuin/gopher-lua v0.0.0-20181214045814-db9ae37725ec // indirect
1613
golang.org/x/sync v0.0.0-20190227155943-e225da77a7e6 // indirect
1714
)

go.sum

+49
Original file line numberDiff line numberDiff line change
@@ -1,40 +1,89 @@
1+
github.com/OneOfOne/xxhash v1.2.2/go.mod h1:HSdplMjZKSmBqAxg5vPj2TmRDmfkzw+cTzAElWljhcU=
12
github.com/aerospike/aerospike-client-go v1.29.0 h1:XwrKzVw6CDXdHi1a4TDQDql3hx00YR6XjI5C9OcjUJ0=
23
github.com/aerospike/aerospike-client-go v1.29.0/go.mod h1:zj8LBEnWBDOVEIJt8LvaRvDG5ARAoa5dBeHaB472NRc=
4+
github.com/alecthomas/template v0.0.0-20160405071501-a0175ee3bccc/go.mod h1:LOuyumcjzFXgccqObfd/Ljyb9UuFJ6TxHnclSeseNhc=
5+
github.com/alecthomas/units v0.0.0-20151022065526-2efee857e7cf/go.mod h1:ybxpYRFXyAe+OPACYpWeL0wqObRcbAqCMya13uyzqw0=
36
github.com/beorn7/perks v0.0.0-20160804104726-4c0e84591b9a h1:BtpsbiV638WQZwhA98cEZw2BsbnQJrbd0BI7tsy0W1c=
47
github.com/beorn7/perks v0.0.0-20160804104726-4c0e84591b9a/go.mod h1:Dwedo/Wpr24TaqPxmxbtue+5NUziq4I4S80YR8gNf3Q=
8+
github.com/beorn7/perks v0.0.0-20180321164747-3a771d992973/go.mod h1:Dwedo/Wpr24TaqPxmxbtue+5NUziq4I4S80YR8gNf3Q=
9+
github.com/beorn7/perks v1.0.0 h1:HWo1m869IqiPhD389kmkxeTalrjNbbJTC8LXupb+sl0=
10+
github.com/beorn7/perks v1.0.0/go.mod h1:KWe93zE9D1o94FZ5RNwFwVgaQK1VOXiVxmqh+CedLV8=
11+
github.com/cespare/xxhash v1.1.0/go.mod h1:XrSqR1VqqWfGrhpAt58auRo0WTKS1nRRg3ghfAqPWnc=
512
github.com/chzyer/readline v0.0.0-20180603132655-2972be24d48e/go.mod h1:nSuG5e5PlCu98SY8svDHJxuZscDgtXS6KTTbou5AhLI=
13+
github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
14+
github.com/dgryski/go-sip13 v0.0.0-20181026042036-e10d5fee7954/go.mod h1:vAd38F8PWV+bWy6jNmig1y/TA+kYO4g3RSRF0IAv0no=
615
github.com/fsnotify/fsnotify v1.4.7 h1:IXs+QLmnXW2CcXuY+8Mzv/fWEsPGWxqefPtCP5CnV9I=
716
github.com/fsnotify/fsnotify v1.4.7/go.mod h1:jwhsz4b93w/PPRr/qN1Yymfu8t87LnFCMoQvtojpjFo=
17+
github.com/go-kit/kit v0.8.0/go.mod h1:xBxKIO96dXMWWy0MnWVtmwkA9/13aqxPnvrjFYMA2as=
18+
github.com/go-logfmt/logfmt v0.3.0/go.mod h1:Qt1PoO58o5twSAckw1HlFXLmHsOX5/0LbT9GBnD5lWE=
19+
github.com/go-logfmt/logfmt v0.4.0/go.mod h1:3RMwSq7FuexP4Kalkev3ejPJsZTpXXBr9+V4qmtdjCk=
20+
github.com/go-stack/stack v1.8.0/go.mod h1:v0f6uXyyMGvRgIKkXu+yp6POWl0qKG85gN/melR3HDY=
21+
github.com/gogo/protobuf v1.1.1/go.mod h1:r8qH/GZQm5c6nD/R0oafs1akxWv10x8SbQlK7atdtwQ=
822
github.com/golang/protobuf v1.2.0 h1:P3YflyNX/ehuJFLhxviNdFxQPkGK5cDcApsge1SqnvM=
923
github.com/golang/protobuf v1.2.0/go.mod h1:6lQm79b+lXiMfvg/cZm0SGofjICqVBUtrP5yJMmIC1U=
24+
github.com/golang/protobuf v1.3.1 h1:YF8+flBXS5eO826T4nzqPrxfhQThhXl0YzfuUPu4SBg=
25+
github.com/golang/protobuf v1.3.1/go.mod h1:6lQm79b+lXiMfvg/cZm0SGofjICqVBUtrP5yJMmIC1U=
1026
github.com/hpcloud/tail v1.0.0 h1:nfCOvKYfkgYP8hkirhJocXT2+zOD8yUNjXaWfTlyFKI=
1127
github.com/hpcloud/tail v1.0.0/go.mod h1:ab1qPbhIpdTxEkNHXyeSf5vhxWSCs/tWer42PpOxQnU=
28+
github.com/julienschmidt/httprouter v1.2.0/go.mod h1:SYymIcj16QtmaHHD7aYtjjsJG7VTCxuUUipMqKk8s4w=
29+
github.com/konsorten/go-windows-terminal-sequences v1.0.1/go.mod h1:T0+1ngSBFLxvqU3pZ+m/2kptfBszLMUkC4ZK/EgS/cQ=
30+
github.com/kr/logfmt v0.0.0-20140226030751-b84e30acd515/go.mod h1:+0opPa2QZZtGFBFZlji/RkVcI2GknAs/DXo4wKdlNEc=
1231
github.com/matttproud/golang_protobuf_extensions v1.0.1 h1:4hp9jkHxhMHkqkrB3Ix0jegS5sx/RkqARlsWZ6pIwiU=
1332
github.com/matttproud/golang_protobuf_extensions v1.0.1/go.mod h1:D8He9yQNgCq6Z5Ld7szi9bcBfOoFv/3dc6xSMkL2PC0=
33+
github.com/mwitkow/go-conntrack v0.0.0-20161129095857-cc309e4a2223/go.mod h1:qRWi+5nqEBWmkhHvq77mSJWrCKwh8bxhgT7d/eI7P4U=
34+
github.com/oklog/ulid v1.3.1/go.mod h1:CirwcVhetQ6Lv90oh/F+FBtV6XMibvdAFo93nm5qn4U=
1435
github.com/onsi/ginkgo v1.6.0/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+WWjE=
1536
github.com/onsi/ginkgo v1.8.0 h1:VkHVNpR4iVnU8XQR6DBm8BqYjN7CRzw+xKUbVVbbW9w=
1637
github.com/onsi/ginkgo v1.8.0/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+WWjE=
1738
github.com/onsi/gomega v1.5.0 h1:izbySO9zDPmjJ8rDjLvkA2zJHIo+HkYXHnf7eN7SSyo=
1839
github.com/onsi/gomega v1.5.0/go.mod h1:ex+gbHU/CVuBBDIJjb2X0qEXbFg53c61hWP/1CpauHY=
40+
github.com/pkg/errors v0.8.0/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0=
41+
github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4=
1942
github.com/prometheus/client_golang v0.0.0-20170907150625-671c87b04728 h1:yNp9yRYg4pzicwWfndinGmVpP9Ip8EI1U93MtZWCdwg=
2043
github.com/prometheus/client_golang v0.0.0-20170907150625-671c87b04728/go.mod h1:7SWBe2y4D6OKWSNQJUaRYU/AaXPKyh/dDVn+NZz0KFw=
44+
github.com/prometheus/client_golang v0.9.1/go.mod h1:7SWBe2y4D6OKWSNQJUaRYU/AaXPKyh/dDVn+NZz0KFw=
45+
github.com/prometheus/client_golang v0.9.3 h1:9iH4JKXLzFbOAdtqv/a+j8aewx2Y8lAjAydhbaScPF8=
46+
github.com/prometheus/client_golang v0.9.3/go.mod h1:/TN21ttK/J9q6uSwhBd54HahCDft0ttaMvbicHlPoso=
2147
github.com/prometheus/client_model v0.0.0-20170216185247-6f3806018612 h1:13pIdM2tpaDi4OVe24fgoIS7ZTqMt0QI+bwQsX5hq+g=
2248
github.com/prometheus/client_model v0.0.0-20170216185247-6f3806018612/go.mod h1:MbSGuTsp3dbXC40dX6PRTWyKYBIrTGTE9sqQNg2J8bo=
49+
github.com/prometheus/client_model v0.0.0-20180712105110-5c3871d89910/go.mod h1:MbSGuTsp3dbXC40dX6PRTWyKYBIrTGTE9sqQNg2J8bo=
50+
github.com/prometheus/client_model v0.0.0-20190129233127-fd36f4220a90 h1:S/YWwWx/RA8rT8tKFRuGUZhuA90OyIBpPCXkcbwU8DE=
51+
github.com/prometheus/client_model v0.0.0-20190129233127-fd36f4220a90/go.mod h1:xMI15A0UPsDsEKsMN9yxemIoYk6Tm2C1GtYGdfGttqA=
2352
github.com/prometheus/common v0.0.0-20170908161822-2f17f4a9d485 h1:ELypU1kBAPEzqcj8hphDyZWTJw5TIFgepXU983BEkD0=
2453
github.com/prometheus/common v0.0.0-20170908161822-2f17f4a9d485/go.mod h1:daVV7qP5qjZbuso7PdcryaAu0sAZbrN9i7WWcTMWvro=
54+
github.com/prometheus/common v0.0.0-20181113130724-41aa239b4cce/go.mod h1:daVV7qP5qjZbuso7PdcryaAu0sAZbrN9i7WWcTMWvro=
55+
github.com/prometheus/common v0.4.0 h1:7etb9YClo3a6HjLzfl6rIQaU+FDfi0VSX39io3aQ+DM=
56+
github.com/prometheus/common v0.4.0/go.mod h1:TNfzLD0ON7rHzMJeJkieUDPYmFC7Snx/y86RQel1bk4=
2557
github.com/prometheus/procfs v0.0.0-20170703101242-e645f4e5aaa8 h1:Kh7M6mzRpQ2de1rixoSQZr4BTINXFm8WDbeN5ttnwyE=
2658
github.com/prometheus/procfs v0.0.0-20170703101242-e645f4e5aaa8/go.mod h1:c3At6R/oaqEKCNdg8wHV1ftS6bRYblBhIjjI8uT2IGk=
59+
github.com/prometheus/procfs v0.0.0-20181005140218-185b4288413d/go.mod h1:c3At6R/oaqEKCNdg8wHV1ftS6bRYblBhIjjI8uT2IGk=
60+
github.com/prometheus/procfs v0.0.0-20190507164030-5867b95ac084/go.mod h1:TjEm7ze935MbeOT/UhFTIMYKhuLP4wbCsTZCD3I8kEA=
61+
github.com/prometheus/procfs v0.0.0-20190519111021-9935e8e0588d h1:Z5QMcUKnQw7ouB1wDuyZM6TL/rm+brJcNk6Ai8ut3zM=
62+
github.com/prometheus/procfs v0.0.0-20190519111021-9935e8e0588d/go.mod h1:TjEm7ze935MbeOT/UhFTIMYKhuLP4wbCsTZCD3I8kEA=
63+
github.com/prometheus/tsdb v0.7.1/go.mod h1:qhTCs0VvXwvX/y3TZrWD7rabWM+ijKTux40TwIPHuXU=
64+
github.com/sirupsen/logrus v1.2.0/go.mod h1:LxeOpSwHxABJmUn/MG1IvRgCAasNZTLOkJPxbbu5VWo=
65+
github.com/spaolacci/murmur3 v0.0.0-20180118202830-f09979ecbc72/go.mod h1:JwIasOWyU6f++ZhiEuf87xNszmSA2myDM2Kzu9HwQUA=
66+
github.com/stretchr/objx v0.1.1/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME=
67+
github.com/stretchr/testify v1.2.2/go.mod h1:a8OnRcib4nhh0OaRAV+Yts87kKdq0PP7pXfy6kDkUVs=
2768
github.com/yuin/gopher-lua v0.0.0-20181214045814-db9ae37725ec h1:vpF8Kxql6/3OvGH4y2SKtpN3WsB17mvJ8f8H1o2vucQ=
2869
github.com/yuin/gopher-lua v0.0.0-20181214045814-db9ae37725ec/go.mod h1:fFiAh+CowNFr0NK5VASokuwKwkbacRmHsVA7Yb1Tqac=
70+
golang.org/x/crypto v0.0.0-20180904163835-0709b304e793/go.mod h1:6SG95UA2DQfeDnfUPMdvaQW0Q7yPrPDi9nlGo2tz2b4=
2971
golang.org/x/net v0.0.0-20180906233101-161cd47e91fd h1:nTDtHvHSdCn1m6ITfMRqtOd/9+7a3s8RBNOZ3eYZzJA=
3072
golang.org/x/net v0.0.0-20180906233101-161cd47e91fd/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4=
73+
golang.org/x/net v0.0.0-20181114220301-adae6a3d119a/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4=
3174
golang.org/x/sync v0.0.0-20180314180146-1d60e4601c6f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
75+
golang.org/x/sync v0.0.0-20181108010431-42b317875d0f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
76+
golang.org/x/sync v0.0.0-20181221193216-37e7f081c4d4/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
3277
golang.org/x/sync v0.0.0-20190227155943-e225da77a7e6 h1:bjcUS9ztw9kFmmIxJInhon/0Is3p+EHBKNgquIzo1OI=
3378
golang.org/x/sync v0.0.0-20190227155943-e225da77a7e6/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
79+
golang.org/x/sys v0.0.0-20180905080454-ebe1bf3edb33/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
3480
golang.org/x/sys v0.0.0-20180909124046-d0be0721c37e h1:o3PsSEY8E4eXWkXrIP9YJALUkVZqzHJT5DOasTyn8Vs=
3581
golang.org/x/sys v0.0.0-20180909124046-d0be0721c37e/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
82+
golang.org/x/sys v0.0.0-20181107165924-66b7b1311ac8/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
83+
golang.org/x/sys v0.0.0-20181116152217-5ac8a444bdc5/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
3684
golang.org/x/text v0.3.0 h1:g61tztE5qeGQ89tm6NTjjM9VPIm088od1l6aSorWRWg=
3785
golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ=
86+
gopkg.in/alecthomas/kingpin.v2 v2.2.6/go.mod h1:FMv+mEhP44yOT+4EoQTLFTRgOQ1FBLkstjWtayDeSgw=
3887
gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405 h1:yhCVgyC4o1eVCa2tZl7eS0r+SDo693bJlVdllGtEeKM=
3988
gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
4089
gopkg.in/fsnotify.v1 v1.4.7 h1:xOHLXZwVvI9hhs+cLKq5+I5onOuwQLhQwiu63xxlHs4=

latency.go

+98-12
Original file line numberDiff line numberDiff line change
@@ -16,22 +16,48 @@ var (
1616
)
1717

1818
type latencyCollector struct {
19-
latency cmetrics
20-
ops cmetrics
19+
latency cmetrics
20+
latencyHistogram cmetrics
21+
ops cmetrics
22+
histOps cmetrics
23+
bucketSum cmetrics
2124
}
2225

2326
func newLatencyCollector() latencyCollector {
2427
lc := latencyCollector{
25-
latency: map[string]cmetric{},
26-
ops: map[string]cmetric{},
28+
latency: map[string]cmetric{},
29+
latencyHistogram: map[string]cmetric{},
30+
ops: map[string]cmetric{},
31+
histOps: map[string]cmetric{},
32+
bucketSum: map[string]cmetric{},
2733
}
2834
for _, m := range latencyMetrics {
2935
lc.latency[m] = cmetric{
3036
typ: prometheus.GaugeValue,
3137
desc: prometheus.NewDesc(
3238
promkey(systemLatency, m),
39+
m+" latency",
40+
[]string{"namespace", "threshold"}, // threshold to be printed as le for histogram
41+
nil,
42+
),
43+
}
44+
lc.latencyHistogram[m] = cmetric{
45+
typ: prometheus.GaugeValue,
46+
desc: prometheus.NewDesc(
47+
// for prom histogram latency buckets, metric must end in _bucket
48+
promkey(systemLatencyHist, m+"_bucket"),
3349
m+" latency histogram",
34-
[]string{"namespace", "threshold"},
50+
[]string{"namespace", "le"}, // threshold to be printed as le for histogram, le="1" means ops that completed in less than 1ms
51+
nil,
52+
),
53+
}
54+
lc.histOps[m] = cmetric{
55+
typ: prometheus.GaugeValue,
56+
desc: prometheus.NewDesc(
57+
// for prom histogram, must have a metric ending in _count which is equal to the sum of all observed events
58+
promkey(systemLatencyHist, m+"_count"),
59+
m+" ops per second for histogram",
60+
[]string{"namespace"},
3561
nil,
3662
),
3763
}
@@ -44,6 +70,16 @@ func newLatencyCollector() latencyCollector {
4470
nil,
4571
),
4672
}
73+
lc.bucketSum[m] = cmetric{
74+
typ: prometheus.GaugeValue,
75+
desc: prometheus.NewDesc(
76+
// for prom histogram, must have a metric ending in _sum which is equal to the sum of all observed events values
77+
promkey(systemLatencyHist, m+"_sum"),
78+
m+" sum of all buckets",
79+
[]string{"namespace"},
80+
nil,
81+
),
82+
}
4783
}
4884
return lc
4985
}
@@ -55,6 +91,15 @@ func (lc latencyCollector) describe(ch chan<- *prometheus.Desc) {
5591
for _, s := range lc.ops {
5692
ch <- s.desc
5793
}
94+
for _, s := range lc.histOps {
95+
ch <- s.desc
96+
}
97+
for _, s := range lc.bucketSum {
98+
ch <- s.desc
99+
}
100+
for _, s := range lc.latencyHistogram {
101+
ch <- s.desc
102+
}
58103
}
59104

60105
func (lc latencyCollector) collect(conn *as.Connection) ([]prometheus.Metric, error) {
@@ -67,6 +112,8 @@ func (lc latencyCollector) collect(conn *as.Connection) ([]prometheus.Metric, er
67112
return nil, err
68113
}
69114
var metrics []prometheus.Metric
115+
re := regexp.MustCompile("[0-9.]+") // regex to pull the number from the bucket name, >1ms -> 1, >8ms -> 8 etc.
116+
70117
for key, ms := range lat {
71118
if key == "batch-index" {
72119
continue // TODO: would be nice to do something with this key
@@ -75,21 +122,61 @@ func (lc latencyCollector) collect(conn *as.Connection) ([]prometheus.Metric, er
75122
if err != nil {
76123
return nil, fmt.Errorf("weird latency key %q: %s", key, err)
77124
}
125+
// need to grab ops outside of the latency loop
126+
// so that we can use it for estimatedBucketOps later
127+
// the latency map could be out of order, so OPS/S needs to be accessed first
128+
ops := ms["ops/sec"]
129+
var bucketSum float64
130+
histOpsMetric := lc.histOps[op]
131+
metrics = append(
132+
metrics,
133+
prometheus.MustNewConstMetric(histOpsMetric.desc, histOpsMetric.typ, ops, ns),
134+
)
135+
136+
opsMetric := lc.ops[op]
137+
metrics = append(
138+
metrics,
139+
prometheus.MustNewConstMetric(opsMetric.desc, opsMetric.typ, ops, ns),
140+
)
141+
78142
for threshold, data := range ms {
79143
if threshold == "ops/sec" {
80-
m := lc.ops[op]
81-
metrics = append(
82-
metrics,
83-
prometheus.MustNewConstMetric(m.desc, m.typ, data, ns),
84-
)
85144
continue
86145
}
87-
m := lc.latency[op]
146+
thresholdNum := re.FindString(threshold) // filter out >1ms to just the number 1, similarly >8ms becomes 8..
147+
bucketVal, _ := strconv.ParseFloat(thresholdNum, 64)
148+
m := lc.latencyHistogram[op]
149+
// latency is exported as % in certain buckets.
150+
// For histogram consumption, it would be nice to have the estimated number of
151+
// operations in each bucket instead. So this is just some simple math to figure out, given the total ops/s and % in each bucket
152+
// How many ops in each bucket.
153+
estimatedBucketOps := ops * data / 100.0
154+
bucketSum += (bucketVal * estimatedBucketOps) // to generate sum like aerospike_latency_hist_read_sum
155+
if bucketVal == 1.0 {
156+
below1msAssumption := ops - estimatedBucketOps
157+
bucketSum += 0.5 * below1msAssumption // for the blahblah_sum histogram metric, to calculate averages, assume the transactions <1ms are .5ms
158+
}
159+
leBucketOps := ops - estimatedBucketOps
160+
metrics = append(
161+
metrics,
162+
prometheus.MustNewConstMetric(m.desc, m.typ, leBucketOps, ns, thresholdNum),
163+
)
164+
m = lc.latency[op]
88165
metrics = append(
89166
metrics,
90167
prometheus.MustNewConstMetric(m.desc, m.typ, data, ns, threshold),
91168
)
92169
}
170+
m := lc.bucketSum[op]
171+
metrics = append(
172+
metrics,
173+
prometheus.MustNewConstMetric(m.desc, m.typ, bucketSum, ns),
174+
)
175+
m = lc.latencyHistogram[op]
176+
metrics = append(
177+
metrics,
178+
prometheus.MustNewConstMetric(m.desc, m.typ, ops, ns, "+Inf"),
179+
)
93180
}
94181
return metrics, nil
95182
}
@@ -109,7 +196,6 @@ func parseLatency(lat string) (map[string]map[string]float64, error) {
109196
vs := strings.Split(line, ",")
110197
key := strings.SplitN(vs[0], ":", 2)[0] // strips timestamp
111198
cols := vs[1:]
112-
113199
if i+1 >= len(lines) {
114200
return nil, fmt.Errorf("latency: missing measurements line")
115201
}

main.go

+7-6
Original file line numberDiff line numberDiff line change
@@ -26,12 +26,13 @@ import (
2626
)
2727

2828
const (
29-
namespace = "aerospike"
30-
systemNode = "node"
31-
systemNamespace = "ns"
32-
systemLatency = "latency"
33-
systemOps = "ops" // reported in latency
34-
systemSet = "set"
29+
namespace = "aerospike"
30+
systemNode = "node"
31+
systemNamespace = "ns"
32+
systemLatency = "latency"
33+
systemLatencyHist = "latency_hist" // total number of ops
34+
systemOps = "ops"
35+
systemSet = "set"
3536
)
3637

3738
var (

namespaces.go

+4
Original file line numberDiff line numberDiff line change
@@ -220,6 +220,10 @@ var (
220220
gauge("stop_writes", "stop writes"),
221221
gauge("stop-writes-pct", "stop writes pct"),
222222
gauge("tombstones", "tombstones"),
223+
// including additional key metrics as recommended by aerospike https://www.aerospike.com/docs/operations/monitor/key_metrics/index.html
224+
gauge("clock_skew_stop_writes", "clock skew stop writes"),
225+
gauge("dead_partitions", "dead partitions"),
226+
gauge("unavailable_partitions", "unavailable partitions"),
223227
// gauge("write_q", "write queue"),
224228
// device-level stats don't appear to work
225229
// and this plugin thinks "storage-engine.device[0].write_q" is malformed.

vendor/github.com/beorn7/perks/quantile/stream.go

+29-5
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

vendor/github.com/golang/protobuf/proto/decode.go

-1
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

0 commit comments

Comments
 (0)