Merge pull request #13372 from prometheus/v2-proto-lint

change enum names to fit buf build recommend enum naming and lint rules
This commit is contained in:
Bartlomiej Plotka 2024-01-04 12:28:23 +01:00 committed by GitHub
commit f9dc544691
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
7 changed files with 282 additions and 152 deletions

View file

@ -27,36 +27,36 @@ const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package
type Metadata_MetricType int32 type Metadata_MetricType int32
const ( const (
Metadata_UNKNOWN Metadata_MetricType = 0 Metadata_METRIC_TYPE_UNSPECIFIED Metadata_MetricType = 0
Metadata_COUNTER Metadata_MetricType = 1 Metadata_METRIC_TYPE_COUNTER Metadata_MetricType = 1
Metadata_GAUGE Metadata_MetricType = 2 Metadata_METRIC_TYPE_GAUGE Metadata_MetricType = 2
Metadata_HISTOGRAM Metadata_MetricType = 3 Metadata_METRIC_TYPE_HISTOGRAM Metadata_MetricType = 3
Metadata_GAUGEHISTOGRAM Metadata_MetricType = 4 Metadata_METRIC_TYPE_GAUGEHISTOGRAM Metadata_MetricType = 4
Metadata_SUMMARY Metadata_MetricType = 5 Metadata_METRIC_TYPE_SUMMARY Metadata_MetricType = 5
Metadata_INFO Metadata_MetricType = 6 Metadata_METRIC_TYPE_INFO Metadata_MetricType = 6
Metadata_STATESET Metadata_MetricType = 7 Metadata_METRIC_TYPE_STATESET Metadata_MetricType = 7
) )
var Metadata_MetricType_name = map[int32]string{ var Metadata_MetricType_name = map[int32]string{
0: "UNKNOWN", 0: "METRIC_TYPE_UNSPECIFIED",
1: "COUNTER", 1: "METRIC_TYPE_COUNTER",
2: "GAUGE", 2: "METRIC_TYPE_GAUGE",
3: "HISTOGRAM", 3: "METRIC_TYPE_HISTOGRAM",
4: "GAUGEHISTOGRAM", 4: "METRIC_TYPE_GAUGEHISTOGRAM",
5: "SUMMARY", 5: "METRIC_TYPE_SUMMARY",
6: "INFO", 6: "METRIC_TYPE_INFO",
7: "STATESET", 7: "METRIC_TYPE_STATESET",
} }
var Metadata_MetricType_value = map[string]int32{ var Metadata_MetricType_value = map[string]int32{
"UNKNOWN": 0, "METRIC_TYPE_UNSPECIFIED": 0,
"COUNTER": 1, "METRIC_TYPE_COUNTER": 1,
"GAUGE": 2, "METRIC_TYPE_GAUGE": 2,
"HISTOGRAM": 3, "METRIC_TYPE_HISTOGRAM": 3,
"GAUGEHISTOGRAM": 4, "METRIC_TYPE_GAUGEHISTOGRAM": 4,
"SUMMARY": 5, "METRIC_TYPE_SUMMARY": 5,
"INFO": 6, "METRIC_TYPE_INFO": 6,
"STATESET": 7, "METRIC_TYPE_STATESET": 7,
} }
func (x Metadata_MetricType) String() string { func (x Metadata_MetricType) String() string {
@ -70,24 +70,24 @@ func (Metadata_MetricType) EnumDescriptor() ([]byte, []int) {
type Histogram_ResetHint int32 type Histogram_ResetHint int32
const ( const (
Histogram_UNKNOWN Histogram_ResetHint = 0 Histogram_RESET_HINT_UNSPECIFIED Histogram_ResetHint = 0
Histogram_YES Histogram_ResetHint = 1 Histogram_RESET_HINT_YES Histogram_ResetHint = 1
Histogram_NO Histogram_ResetHint = 2 Histogram_RESET_HINT_NO Histogram_ResetHint = 2
Histogram_GAUGE Histogram_ResetHint = 3 Histogram_RESET_HINT_GAUGE Histogram_ResetHint = 3
) )
var Histogram_ResetHint_name = map[int32]string{ var Histogram_ResetHint_name = map[int32]string{
0: "UNKNOWN", 0: "RESET_HINT_UNSPECIFIED",
1: "YES", 1: "RESET_HINT_YES",
2: "NO", 2: "RESET_HINT_NO",
3: "GAUGE", 3: "RESET_HINT_GAUGE",
} }
var Histogram_ResetHint_value = map[string]int32{ var Histogram_ResetHint_value = map[string]int32{
"UNKNOWN": 0, "RESET_HINT_UNSPECIFIED": 0,
"YES": 1, "RESET_HINT_YES": 1,
"NO": 2, "RESET_HINT_NO": 2,
"GAUGE": 3, "RESET_HINT_GAUGE": 3,
} }
func (x Histogram_ResetHint) String() string { func (x Histogram_ResetHint) String() string {
@ -416,7 +416,7 @@ func (m *Metadata) GetType() Metadata_MetricType {
if m != nil { if m != nil {
return m.Type return m.Type
} }
return Metadata_UNKNOWN return Metadata_METRIC_TYPE_UNSPECIFIED
} }
func (m *Metadata) GetHelpRef() uint32 { func (m *Metadata) GetHelpRef() uint32 {
@ -653,7 +653,7 @@ func (m *Histogram) GetResetHint() Histogram_ResetHint {
if m != nil { if m != nil {
return m.ResetHint return m.ResetHint
} }
return Histogram_UNKNOWN return Histogram_RESET_HINT_UNSPECIFIED
} }
func (m *Histogram) GetTimestamp() int64 { func (m *Histogram) GetTimestamp() int64 {
@ -748,59 +748,62 @@ func init() {
func init() { proto.RegisterFile("write/v2/types.proto", fileDescriptor_4919b8b88a093366) } func init() { proto.RegisterFile("write/v2/types.proto", fileDescriptor_4919b8b88a093366) }
var fileDescriptor_4919b8b88a093366 = []byte{ var fileDescriptor_4919b8b88a093366 = []byte{
// 831 bytes of a gzipped FileDescriptorProto // 875 bytes of a gzipped FileDescriptorProto
0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x84, 0x55, 0xdd, 0x6e, 0xe3, 0x44, 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x84, 0x55, 0x5b, 0x6f, 0x1b, 0x45,
0x14, 0xee, 0xc4, 0x49, 0x6c, 0x9f, 0xfc, 0xac, 0x3b, 0x14, 0x64, 0x10, 0xdb, 0x0d, 0x91, 0x80, 0x14, 0xce, 0x78, 0x7d, 0x3d, 0x89, 0xdd, 0xf5, 0xd4, 0x69, 0xb7, 0x81, 0xa6, 0xc6, 0x12, 0x60,
0x08, 0xa4, 0x14, 0xc2, 0x0a, 0x09, 0xd4, 0x9b, 0x64, 0xc9, 0x36, 0x15, 0x6a, 0x22, 0x8d, 0x5d, 0x81, 0xe4, 0x80, 0x41, 0x48, 0xa0, 0xbc, 0xd8, 0xe9, 0x26, 0xf6, 0x83, 0x9d, 0x6a, 0x76, 0x23,
0xad, 0x96, 0x9b, 0x68, 0x9a, 0x4c, 0x12, 0x0b, 0xff, 0xe1, 0x99, 0x04, 0xca, 0x7b, 0xf1, 0x08, 0x14, 0x5e, 0x56, 0x1b, 0x7b, 0x6c, 0xaf, 0xd8, 0x1b, 0x3b, 0x63, 0x43, 0xf8, 0x5f, 0xfc, 0x87,
0x48, 0x7b, 0xc9, 0x13, 0x20, 0xd4, 0x07, 0xe0, 0x19, 0xd0, 0x8c, 0x7f, 0xa6, 0x2d, 0x5a, 0xed, 0x3e, 0x22, 0xf1, 0x0c, 0x42, 0xf9, 0x0f, 0xbc, 0xa3, 0x99, 0xbd, 0xc6, 0x55, 0xd5, 0xb7, 0x3d,
0xdd, 0x9c, 0xef, 0x7c, 0xdf, 0x9c, 0xef, 0x1c, 0x9f, 0x91, 0xe1, 0xe4, 0xd7, 0x2c, 0x10, 0xec, 0xdf, 0x65, 0xce, 0x37, 0x27, 0x67, 0x62, 0xe8, 0xfc, 0x1a, 0x39, 0x9c, 0x9e, 0xed, 0x86, 0x67,
0xec, 0x30, 0x3a, 0x13, 0xb7, 0x29, 0xe3, 0xc3, 0x34, 0x4b, 0x44, 0x82, 0x2d, 0x85, 0x0e, 0x0f, 0xfc, 0x3e, 0xa4, 0x6c, 0x10, 0x46, 0x01, 0x0f, 0x70, 0x5d, 0xa2, 0x83, 0xdd, 0xf0, 0xa4, 0xb3,
0xa3, 0x8f, 0x4e, 0xb6, 0xc9, 0x36, 0x51, 0xe0, 0x99, 0x3c, 0xe5, 0xf9, 0xfe, 0x1a, 0xda, 0xaf, 0x0e, 0xd6, 0x81, 0x04, 0xcf, 0xc4, 0x57, 0xcc, 0xf7, 0x96, 0x70, 0xf4, 0xa3, 0x50, 0x10, 0xfa,
0x24, 0x83, 0xb0, 0x5f, 0xf6, 0x8c, 0x0b, 0xec, 0x82, 0xc9, 0x6f, 0xa3, 0x9b, 0x24, 0xe4, 0x2e, 0xcb, 0x96, 0x32, 0x8e, 0x35, 0xa8, 0xb1, 0x7b, 0xef, 0x2e, 0x70, 0x99, 0x86, 0xba, 0x4a, 0xbf,
0xea, 0x19, 0x03, 0x9b, 0x94, 0x21, 0xfe, 0x1e, 0x40, 0x04, 0x11, 0xe3, 0x2c, 0x0b, 0x18, 0x77, 0x41, 0xd2, 0x12, 0xff, 0x00, 0xc0, 0x1d, 0x8f, 0x32, 0x1a, 0x39, 0x94, 0x69, 0xa5, 0xae, 0xd2,
0x6b, 0x3d, 0x63, 0xd0, 0x1a, 0x9d, 0x0c, 0xcb, 0xeb, 0x87, 0x7e, 0x10, 0x31, 0x4f, 0xe5, 0x26, 0x3f, 0x1c, 0x76, 0x06, 0xe9, 0xf1, 0x03, 0xd3, 0xf1, 0xa8, 0x21, 0xb9, 0x71, 0xf9, 0xed, 0x3f,
0xf5, 0x37, 0x7f, 0x3f, 0x3b, 0x22, 0xf7, 0xd8, 0xfd, 0x3f, 0x6a, 0x00, 0x9a, 0x80, 0x9f, 0x41, 0xaf, 0x0e, 0x48, 0x41, 0xdd, 0xfb, 0xa3, 0x04, 0x90, 0x0b, 0xf0, 0x2b, 0x38, 0x74, 0xed, 0x3b,
0x2b, 0xa4, 0x37, 0x2c, 0xe4, 0xcb, 0x8c, 0x6d, 0xf2, 0x42, 0x1d, 0x02, 0x39, 0x44, 0xd8, 0x86, 0xea, 0x32, 0x2b, 0xa2, 0xab, 0xb8, 0x51, 0x93, 0x40, 0x0c, 0x11, 0xba, 0x62, 0xf8, 0x2b, 0xa8,
0xe3, 0xaf, 0xc0, 0xe4, 0x34, 0x4a, 0xc3, 0xaa, 0x90, 0xa3, 0x0b, 0x79, 0x2a, 0x51, 0x14, 0x29, 0x31, 0xdb, 0x0b, 0xdd, 0xac, 0x91, 0x9a, 0x37, 0x32, 0x24, 0x91, 0x34, 0x49, 0x65, 0xf8, 0x3b,
0x69, 0xf8, 0x5b, 0xb0, 0xd9, 0x6f, 0x2c, 0x4a, 0x43, 0x9a, 0x71, 0xd7, 0x50, 0x1a, 0xac, 0x35, 0x68, 0xd0, 0xdf, 0xa8, 0x17, 0xba, 0x76, 0xc4, 0x34, 0x45, 0x7a, 0x70, 0xee, 0xd1, 0x13, 0x2a,
0xd3, 0x22, 0x55, 0xa8, 0x34, 0x15, 0x7f, 0x07, 0xb0, 0x0b, 0xb8, 0x48, 0xb6, 0x19, 0x8d, 0xb8, 0x71, 0xe5, 0x52, 0xfc, 0x3d, 0xc0, 0xc6, 0x61, 0x3c, 0x58, 0x47, 0xb6, 0xc7, 0xb4, 0xb2, 0x34,
0x5b, 0x57, 0xc2, 0xf7, 0xb4, 0x70, 0x56, 0xe6, 0xca, 0xa6, 0x34, 0x19, 0x3f, 0x07, 0x2b, 0x62, 0x3e, 0xcd, 0x8d, 0x93, 0x94, 0x4b, 0x2f, 0x95, 0x8b, 0xf1, 0xb7, 0x50, 0xf7, 0x28, 0xb7, 0x97,
0x82, 0xae, 0xa9, 0xa0, 0x6e, 0xa3, 0x87, 0x1e, 0x56, 0xbc, 0x2a, 0x32, 0x85, 0xae, 0x62, 0xe2, 0x36, 0xb7, 0xb5, 0x4a, 0x17, 0x3d, 0xee, 0x38, 0x4b, 0x98, 0xc4, 0x97, 0x29, 0xf1, 0x97, 0xd0,
0x2f, 0xe1, 0x78, 0x95, 0x31, 0x2a, 0xd8, 0x7a, 0xa9, 0x06, 0x24, 0x68, 0x94, 0xba, 0xcd, 0x1e, 0x5e, 0x44, 0xd4, 0xe6, 0x74, 0x69, 0xc9, 0x01, 0x71, 0xdb, 0x0b, 0xb5, 0x6a, 0x17, 0xf5, 0x15,
0x1a, 0x18, 0xc4, 0x29, 0x12, 0x7e, 0x89, 0xf7, 0x97, 0x60, 0x95, 0xd6, 0xdf, 0x3d, 0xb4, 0x13, 0xa2, 0x26, 0x84, 0x99, 0xe2, 0x3d, 0x0b, 0xea, 0x69, 0xf4, 0x0f, 0x0f, 0xad, 0x03, 0x95, 0x9d,
0x68, 0x1c, 0x68, 0xb8, 0x67, 0x6e, 0xad, 0x87, 0x06, 0x88, 0xe4, 0x01, 0xfe, 0x18, 0x6c, 0x5d, 0xed, 0x6e, 0xa9, 0x56, 0xea, 0xa2, 0x3e, 0x22, 0x71, 0x81, 0x3f, 0x86, 0x46, 0xde, 0x47, 0x91,
0xc7, 0x50, 0x75, 0x34, 0xd0, 0x3f, 0x87, 0x66, 0x3e, 0x4f, 0xad, 0x46, 0x6f, 0x55, 0xd7, 0x1e, 0x7d, 0x72, 0xa0, 0x77, 0x0e, 0xd5, 0x78, 0x9e, 0xb9, 0x1b, 0xbd, 0xd7, 0x5d, 0xda, 0x77, 0xff,
0xab, 0xff, 0x45, 0x60, 0x95, 0x8d, 0xe2, 0xaf, 0xa1, 0x2e, 0x17, 0x4f, 0xe9, 0xbb, 0xa3, 0xa7, 0x55, 0x82, 0x7a, 0x7a, 0x51, 0xfc, 0x35, 0x94, 0xc5, 0xe2, 0x49, 0x7f, 0x6b, 0xf8, 0xf2, 0xdd,
0xff, 0x1f, 0x85, 0x3c, 0x64, 0xc1, 0xca, 0xbf, 0x4d, 0x19, 0x51, 0x54, 0xfc, 0x21, 0x58, 0x3b, 0x51, 0x88, 0x8f, 0xc8, 0x59, 0x98, 0xf7, 0x21, 0x25, 0x52, 0x8a, 0x5f, 0x40, 0x7d, 0x43, 0xdd,
0x16, 0xa6, 0xb2, 0x21, 0x65, 0xad, 0x43, 0x4c, 0x19, 0x13, 0xb6, 0x91, 0xa9, 0x7d, 0x1c, 0x08, 0x50, 0x5c, 0x48, 0x46, 0x6b, 0x92, 0x9a, 0xa8, 0x09, 0x5d, 0x09, 0x6a, 0xeb, 0x3b, 0x5c, 0x52,
0x95, 0xaa, 0xe7, 0x29, 0x19, 0x13, 0xb6, 0xe9, 0xdf, 0x02, 0xe8, 0x9b, 0x70, 0x0b, 0xcc, 0xeb, 0xe5, 0x98, 0x12, 0x35, 0xa1, 0xab, 0xde, 0xdf, 0x08, 0x20, 0x3f, 0x0a, 0x7f, 0x04, 0xcf, 0x67,
0xf9, 0x8f, 0xf3, 0xc5, 0xab, 0xb9, 0x73, 0x24, 0x83, 0x17, 0x8b, 0xeb, 0xb9, 0x3f, 0x25, 0x0e, 0xba, 0x49, 0xa6, 0x17, 0x96, 0x79, 0xfb, 0x46, 0xb7, 0x6e, 0xe6, 0xc6, 0x1b, 0xfd, 0x62, 0x7a,
0xc2, 0x36, 0x34, 0x2e, 0xc6, 0xd7, 0x17, 0x53, 0xa7, 0x86, 0x3b, 0x60, 0xcf, 0x2e, 0x3d, 0x7f, 0x39, 0xd5, 0x5f, 0xab, 0x07, 0xf8, 0x39, 0x3c, 0x2d, 0x92, 0x17, 0xd7, 0x37, 0x73, 0x53, 0x27,
0x71, 0x41, 0xc6, 0x57, 0x8e, 0x81, 0x31, 0x74, 0x55, 0x46, 0x63, 0x75, 0x29, 0xf5, 0xae, 0xaf, 0x2a, 0xc2, 0xc7, 0xd0, 0x2e, 0x12, 0x57, 0xa3, 0x9b, 0x2b, 0x5d, 0x2d, 0xe1, 0x17, 0x70, 0x5c,
0xae, 0xc6, 0xe4, 0xb5, 0xd3, 0xc0, 0x16, 0xd4, 0x2f, 0xe7, 0x2f, 0x17, 0x4e, 0x13, 0xb7, 0xc1, 0x84, 0x27, 0x53, 0xc3, 0xbc, 0xbe, 0x22, 0xa3, 0x99, 0xaa, 0xe0, 0x53, 0x38, 0x79, 0xc7, 0x91,
0xf2, 0xfc, 0xb1, 0x3f, 0xf5, 0xa6, 0xbe, 0x63, 0xf6, 0xff, 0x6c, 0x80, 0x5d, 0xad, 0x04, 0x7e, 0xf3, 0xe5, 0xfd, 0x56, 0xc6, 0xcd, 0x6c, 0x36, 0x22, 0xb7, 0x6a, 0x05, 0x77, 0x40, 0x2d, 0x12,
0x0a, 0xf6, 0x2a, 0xd9, 0xc7, 0x62, 0x19, 0xc4, 0x42, 0xb5, 0x5d, 0x9f, 0x1d, 0x11, 0x4b, 0x41, 0xd3, 0xf9, 0xe5, 0xb5, 0x5a, 0xc5, 0x1a, 0x74, 0x1e, 0xc9, 0xcd, 0x91, 0xa9, 0x1b, 0xba, 0xa9,
0x97, 0xb1, 0xc0, 0x9f, 0x40, 0x2b, 0x4f, 0x6f, 0xc2, 0x84, 0x8a, 0xfc, 0xab, 0xcc, 0x8e, 0x08, 0xd6, 0x7a, 0xff, 0x55, 0xa0, 0x91, 0xed, 0x1d, 0x7e, 0x09, 0x8d, 0x45, 0xb0, 0xf5, 0xb9, 0xe5,
0x28, 0xf0, 0xa5, 0xc4, 0xb0, 0x03, 0x06, 0xdf, 0x47, 0xaa, 0x77, 0x44, 0xe4, 0x11, 0x7f, 0x00, 0xf8, 0x5c, 0xce, 0xb6, 0x3c, 0x39, 0x20, 0x75, 0x09, 0x4d, 0x7d, 0x8e, 0x3f, 0x81, 0xc3, 0x98,
0x4d, 0xbe, 0xda, 0xb1, 0x88, 0xaa, 0xae, 0x8f, 0x49, 0x11, 0xe1, 0x4f, 0xa1, 0xfb, 0x3b, 0xcb, 0x5e, 0xb9, 0x81, 0xcd, 0xe3, 0x3f, 0xfd, 0xe4, 0x80, 0x80, 0x04, 0x2f, 0x05, 0x86, 0x55, 0x50,
0x92, 0xa5, 0xd8, 0x65, 0x8c, 0xef, 0x92, 0x70, 0xad, 0x56, 0x0e, 0x91, 0x8e, 0x44, 0xfd, 0x12, 0xd8, 0xd6, 0x93, 0x03, 0x46, 0x44, 0x7c, 0xe2, 0x67, 0x50, 0x65, 0x8b, 0x0d, 0xf5, 0x6c, 0x39,
0xc4, 0x9f, 0x15, 0x34, 0xed, 0xab, 0xa9, 0x7c, 0x21, 0xd2, 0x96, 0xf8, 0x8b, 0xd2, 0xdb, 0x17, 0xda, 0x36, 0x49, 0x2a, 0xfc, 0x29, 0xb4, 0x7e, 0xa7, 0x51, 0x60, 0xf1, 0x4d, 0x44, 0xd9, 0x26,
0xe0, 0xdc, 0xe3, 0xe5, 0x06, 0x4d, 0x65, 0x10, 0x91, 0x6e, 0xc5, 0xcc, 0x4d, 0x8e, 0xa1, 0x1b, 0x70, 0x97, 0x72, 0xaf, 0x11, 0x69, 0x0a, 0xd4, 0x4c, 0x41, 0xfc, 0x59, 0x22, 0xcb, 0x73, 0x55,
0xb3, 0x2d, 0x15, 0xc1, 0x81, 0x2d, 0x79, 0x4a, 0x63, 0xee, 0x5a, 0x8f, 0x1f, 0xff, 0x64, 0xbf, 0x65, 0x2e, 0x44, 0x8e, 0x04, 0x7e, 0x91, 0x66, 0xfb, 0x02, 0xd4, 0x82, 0x2e, 0x0e, 0x58, 0x93,
0xfa, 0x99, 0x09, 0x2f, 0xa5, 0x71, 0xb1, 0xef, 0x9d, 0x52, 0x21, 0x31, 0x8e, 0x3f, 0x87, 0x27, 0x01, 0x11, 0x69, 0x65, 0xca, 0x38, 0xe4, 0x08, 0x5a, 0x3e, 0x5d, 0xdb, 0xdc, 0xd9, 0x51, 0x8b,
0xd5, 0x15, 0x6b, 0x16, 0x0a, 0xca, 0x5d, 0xbb, 0x67, 0x0c, 0x30, 0xa9, 0x6e, 0xfe, 0x41, 0xa1, 0x85, 0xb6, 0xcf, 0xb4, 0xfa, 0xfe, 0x7f, 0x98, 0xf1, 0x76, 0xf1, 0x33, 0xe5, 0x46, 0x68, 0xfb,
0x0f, 0x88, 0xca, 0x1b, 0x77, 0xa1, 0x67, 0x0c, 0x90, 0x26, 0x2a, 0x63, 0x5c, 0x9a, 0x4a, 0x13, 0xc9, 0xa3, 0x6a, 0xa6, 0x0e, 0x81, 0x31, 0xfc, 0x39, 0x3c, 0xc9, 0x8e, 0x58, 0x52, 0x97, 0xdb,
0x1e, 0xdc, 0x33, 0xd5, 0x7a, 0xb7, 0xa9, 0x52, 0x51, 0x99, 0xaa, 0xae, 0x28, 0x4c, 0xb5, 0x73, 0x4c, 0x6b, 0x74, 0x95, 0x3e, 0x26, 0xd9, 0xc9, 0xaf, 0x25, 0xfa, 0x48, 0x28, 0xb3, 0x31, 0x0d,
0x53, 0x25, 0xac, 0x4d, 0x55, 0xc4, 0xc2, 0x54, 0x27, 0x37, 0x55, 0xc2, 0x85, 0xa9, 0x73, 0x80, 0xba, 0x4a, 0x1f, 0xe5, 0x42, 0x19, 0x8c, 0x89, 0x50, 0x61, 0xc0, 0x9c, 0x42, 0xa8, 0xc3, 0x0f,
0x8c, 0x71, 0x26, 0x96, 0x3b, 0x39, 0xf9, 0xee, 0xe3, 0x87, 0x50, 0x6d, 0xce, 0x90, 0x48, 0xd6, 0x87, 0x4a, 0x1d, 0x59, 0xa8, 0xec, 0x88, 0x24, 0xd4, 0x51, 0x1c, 0x2a, 0x85, 0xf3, 0x50, 0x99,
0x2c, 0x88, 0x05, 0xb1, 0xb3, 0xf2, 0xf8, 0xf0, 0xad, 0x3d, 0x79, 0xfc, 0xd6, 0x9e, 0x83, 0x5d, 0x30, 0x09, 0xd5, 0x8c, 0x43, 0xa5, 0x70, 0x12, 0xea, 0x1c, 0x20, 0xa2, 0x8c, 0x72, 0x6b, 0x23,
0xa9, 0x1e, 0x2e, 0xbd, 0x09, 0xc6, 0xeb, 0xa9, 0xe7, 0x20, 0xdc, 0x84, 0xda, 0x7c, 0xe1, 0xd4, 0x26, 0xdf, 0xda, 0x7f, 0x6d, 0xd9, 0xe6, 0x0c, 0x88, 0x50, 0x4d, 0x1c, 0x9f, 0x93, 0x46, 0x94,
0xf4, 0xe2, 0x1b, 0x13, 0x13, 0x1a, 0xca, 0xf1, 0xa4, 0x0d, 0xa0, 0x3f, 0x78, 0xff, 0x1c, 0x40, 0x7e, 0x3e, 0x7e, 0xd0, 0x4f, 0xf6, 0x1f, 0xf4, 0x12, 0x1a, 0x99, 0x0b, 0x9f, 0xc0, 0x33, 0x22,
0x4f, 0x47, 0xee, 0x5c, 0xb2, 0xd9, 0x70, 0x96, 0x2f, 0xf1, 0x31, 0x29, 0x22, 0x89, 0x87, 0x2c, 0x56, 0xd2, 0x9a, 0x4c, 0xe7, 0xe6, 0xde, 0xbb, 0xc2, 0xd0, 0x2a, 0x70, 0xb7, 0xba, 0xa1, 0x22,
0xde, 0x8a, 0x9d, 0xda, 0xdd, 0x0e, 0x29, 0xa2, 0xc9, 0xfb, 0x6f, 0xee, 0x4e, 0xd1, 0x5f, 0x77, 0xdc, 0x86, 0x66, 0x01, 0x9b, 0x5f, 0xab, 0x25, 0xb1, 0xfa, 0x05, 0x28, 0x7e, 0x64, 0xca, 0xb8,
0xa7, 0xe8, 0x9f, 0xbb, 0x53, 0xf4, 0x93, 0xa9, 0xfa, 0x3b, 0x8c, 0x6e, 0x9a, 0xea, 0x8f, 0xf2, 0x06, 0x15, 0x79, 0xc3, 0xf1, 0x11, 0x40, 0xbe, 0x20, 0xbd, 0x73, 0x80, 0x7c, 0x9a, 0x62, 0x47,
0xcd, 0x7f, 0x01, 0x00, 0x00, 0xff, 0xff, 0x5f, 0x13, 0xc8, 0xac, 0x89, 0x06, 0x00, 0x00, 0x83, 0xd5, 0x8a, 0xd1, 0x78, 0xe9, 0xdb, 0x24, 0xa9, 0x04, 0xee, 0x52, 0x7f, 0xcd, 0x37, 0x72,
0xd7, 0x9b, 0x24, 0xa9, 0xc6, 0xc7, 0x6f, 0x1f, 0x4e, 0xd1, 0x9f, 0x0f, 0xa7, 0xe8, 0xdf, 0x87,
0x53, 0xf4, 0x53, 0x4d, 0xce, 0x63, 0x37, 0xbc, 0xab, 0xca, 0x9f, 0xb9, 0x6f, 0xfe, 0x0f, 0x00,
0x00, 0xff, 0xff, 0x68, 0x88, 0x14, 0xcb, 0x1e, 0x07, 0x00, 0x00,
} }
func (m *WriteRequest) Marshal() (dAtA []byte, err error) { func (m *WriteRequest) Marshal() (dAtA []byte, err error) {

View file

@ -61,14 +61,14 @@ message Sample {
message Metadata { message Metadata {
enum MetricType { enum MetricType {
UNKNOWN = 0; METRIC_TYPE_UNSPECIFIED = 0;
COUNTER = 1; METRIC_TYPE_COUNTER = 1;
GAUGE = 2; METRIC_TYPE_GAUGE = 2;
HISTOGRAM = 3; METRIC_TYPE_HISTOGRAM = 3;
GAUGEHISTOGRAM = 4; METRIC_TYPE_GAUGEHISTOGRAM = 4;
SUMMARY = 5; METRIC_TYPE_SUMMARY = 5;
INFO = 6; METRIC_TYPE_INFO = 6;
STATESET = 7; METRIC_TYPE_STATESET = 7;
} }
MetricType type = 1; MetricType type = 1;
uint32 help_ref = 3; uint32 help_ref = 3;
@ -83,10 +83,10 @@ message Metadata {
// integer histogram as well as a float histogram. // integer histogram as well as a float histogram.
message Histogram { message Histogram {
enum ResetHint { enum ResetHint {
UNKNOWN = 0; // Need to test for a counter reset explicitly. RESET_HINT_UNSPECIFIED = 0; // Need to test for a counter reset explicitly.
YES = 1; // This is the 1st histogram after a counter reset. RESET_HINT_YES = 1; // This is the 1st histogram after a counter reset.
NO = 2; // There was no counter reset between this and the previous Histogram. RESET_HINT_NO = 2; // There was no counter reset between this and the previous Histogram.
GAUGE = 3; // This is a gauge histogram where counter resets don't happen. RESET_HINT_GAUGE = 3; // This is a gauge histogram where counter resets don't happen.
} }
oneof count { // Count of observations in the histogram. oneof count { // Count of observations in the histogram.

View file

@ -18,6 +18,7 @@ import (
"errors" "errors"
"fmt" "fmt"
"math" "math"
"os"
"sort" "sort"
"testing" "testing"
"time" "time"
@ -46,7 +47,9 @@ func TestMain(m *testing.M) {
func TestQueryConcurrency(t *testing.T) { func TestQueryConcurrency(t *testing.T) {
maxConcurrency := 10 maxConcurrency := 10
dir := t.TempDir() dir, err := os.MkdirTemp("", "test_concurrency")
require.NoError(t, err)
defer os.RemoveAll(dir)
queryTracker := NewActiveQueryTracker(dir, maxConcurrency, nil) queryTracker := NewActiveQueryTracker(dir, maxConcurrency, nil)
t.Cleanup(queryTracker.Close) t.Cleanup(queryTracker.Close)

View file

@ -84,7 +84,7 @@ func TestDB_InvalidSeries(t *testing.T) {
}) })
} }
func createTestAgentDB(t *testing.T, reg prometheus.Registerer, opts *Options) *DB { func createTestAgentDB(t testing.TB, reg prometheus.Registerer, opts *Options) *DB {
t.Helper() t.Helper()
dbDir := t.TempDir() dbDir := t.TempDir()
@ -878,3 +878,21 @@ func TestDBAllowOOOSamples(t *testing.T) {
require.Equal(t, float64(80), m.Metric[1].Counter.GetValue(), "agent wal mismatch of total appended histograms") require.Equal(t, float64(80), m.Metric[1].Counter.GetValue(), "agent wal mismatch of total appended histograms")
require.NoError(t, db.Close()) require.NoError(t, db.Close())
} }
func BenchmarkCreateSeries(b *testing.B) {
s := createTestAgentDB(b, nil, DefaultOptions())
defer s.Close()
app := s.Appender(context.Background()).(*appender)
lbls := make([]labels.Labels, b.N)
for i, l := range labelsForTest("benchmark", b.N) {
lbls[i] = labels.New(l...)
}
b.ResetTimer()
for _, l := range lbls {
app.getOrCreate(l)
}
}

View file

@ -45,14 +45,23 @@ func (m *memSeries) updateTimestamp(newTs int64) bool {
return false return false
} }
// seriesHashmap is a simple hashmap for memSeries by their label set. // seriesHashmap lets agent find a memSeries by its label set, via a 64-bit hash.
// It is built on top of a regular hashmap and holds a slice of series to // There is one map for the common case where the hash value is unique, and a
// resolve hash collisions. Its methods require the hash to be submitted // second map for the case that two series have the same hash value.
// Each series is in only one of the maps. Its methods require the hash to be submitted
// with the label set to avoid re-computing hash throughout the code. // with the label set to avoid re-computing hash throughout the code.
type seriesHashmap map[uint64][]*memSeries type seriesHashmap struct {
unique map[uint64]*memSeries
conflicts map[uint64][]*memSeries
}
func (m seriesHashmap) Get(hash uint64, lset labels.Labels) *memSeries { func (m *seriesHashmap) Get(hash uint64, lset labels.Labels) *memSeries {
for _, s := range m[hash] { if s, found := m.unique[hash]; found {
if labels.Equal(s.lset, lset) {
return s
}
}
for _, s := range m.conflicts[hash] {
if labels.Equal(s.lset, lset) { if labels.Equal(s.lset, lset) {
return s return s
} }
@ -60,28 +69,49 @@ func (m seriesHashmap) Get(hash uint64, lset labels.Labels) *memSeries {
return nil return nil
} }
func (m seriesHashmap) Set(hash uint64, s *memSeries) { func (m *seriesHashmap) Set(hash uint64, s *memSeries) {
seriesSet := m[hash] if existing, found := m.unique[hash]; !found || labels.Equal(existing.lset, s.lset) {
m.unique[hash] = s
return
}
if m.conflicts == nil {
m.conflicts = make(map[uint64][]*memSeries)
}
seriesSet := m.conflicts[hash]
for i, prev := range seriesSet { for i, prev := range seriesSet {
if labels.Equal(prev.lset, s.lset) { if labels.Equal(prev.lset, s.lset) {
seriesSet[i] = s seriesSet[i] = s
return return
} }
} }
m[hash] = append(seriesSet, s) m.conflicts[hash] = append(seriesSet, s)
} }
func (m seriesHashmap) Delete(hash uint64, ref chunks.HeadSeriesRef) { func (m *seriesHashmap) Delete(hash uint64, ref chunks.HeadSeriesRef) {
var rem []*memSeries var rem []*memSeries
for _, s := range m[hash] { unique, found := m.unique[hash]
switch {
case !found: // Supplied hash is not stored.
return
case unique.ref == ref:
conflicts := m.conflicts[hash]
if len(conflicts) == 0 { // Exactly one series with this hash was stored
delete(m.unique, hash)
return
}
m.unique[hash] = conflicts[0] // First remaining series goes in 'unique'.
rem = conflicts[1:] // Keep the rest.
default: // The series to delete is somewhere in 'conflicts'. Keep all the ones that don't match.
for _, s := range m.conflicts[hash] {
if s.ref != ref { if s.ref != ref {
rem = append(rem, s) rem = append(rem, s)
} }
} }
}
if len(rem) == 0 { if len(rem) == 0 {
delete(m, hash) delete(m.conflicts, hash)
} else { } else {
m[hash] = rem m.conflicts[hash] = rem
} }
} }
@ -117,7 +147,10 @@ func newStripeSeries(stripeSize int) *stripeSeries {
s.series[i] = map[chunks.HeadSeriesRef]*memSeries{} s.series[i] = map[chunks.HeadSeriesRef]*memSeries{}
} }
for i := range s.hashes { for i := range s.hashes {
s.hashes[i] = seriesHashmap{} s.hashes[i] = seriesHashmap{
unique: map[uint64]*memSeries{},
conflicts: nil, // Initialized on demand in set().
}
} }
for i := range s.exemplars { for i := range s.exemplars {
s.exemplars[i] = map[chunks.HeadSeriesRef]*exemplar.Exemplar{} s.exemplars[i] = map[chunks.HeadSeriesRef]*exemplar.Exemplar{}
@ -136,17 +169,15 @@ func (s *stripeSeries) GC(mint int64) map[chunks.HeadSeriesRef]struct{} {
defer s.gcMut.Unlock() defer s.gcMut.Unlock()
deleted := map[chunks.HeadSeriesRef]struct{}{} deleted := map[chunks.HeadSeriesRef]struct{}{}
for hashLock := 0; hashLock < s.size; hashLock++ {
s.locks[hashLock].Lock()
for hash, all := range s.hashes[hashLock] { // For one series, truncate old chunks and check if any chunks left. If not, mark as deleted and collect the ID.
for _, series := range all { check := func(hashLock int, hash uint64, series *memSeries) {
series.Lock() series.Lock()
// Any series that has received a write since mint is still alive. // Any series that has received a write since mint is still alive.
if series.lastTs >= mint { if series.lastTs >= mint {
series.Unlock() series.Unlock()
continue return
} }
// The series is stale. We need to obtain a second lock for the // The series is stale. We need to obtain a second lock for the
@ -169,6 +200,17 @@ func (s *stripeSeries) GC(mint int64) map[chunks.HeadSeriesRef]struct{} {
} }
series.Unlock() series.Unlock()
} }
for hashLock := 0; hashLock < s.size; hashLock++ {
s.locks[hashLock].Lock()
for hash, all := range s.hashes[hashLock].conflicts {
for _, series := range all {
check(hashLock, hash, series)
}
}
for hash, series := range s.hashes[hashLock].unique {
check(hashLock, hash, series)
} }
s.locks[hashLock].Unlock() s.locks[hashLock].Unlock()

View file

@ -74,3 +74,63 @@ func TestNoDeadlock(t *testing.T) {
require.FailNow(t, "deadlock detected") require.FailNow(t, "deadlock detected")
} }
} }
func labelsWithHashCollision() (labels.Labels, labels.Labels) {
// These two series have the same XXHash; thanks to https://github.com/pstibrany/labels_hash_collisions
ls1 := labels.FromStrings("__name__", "metric", "lbl1", "value", "lbl2", "l6CQ5y")
ls2 := labels.FromStrings("__name__", "metric", "lbl1", "value", "lbl2", "v7uDlF")
if ls1.Hash() != ls2.Hash() {
// These ones are the same when using -tags stringlabels
ls1 = labels.FromStrings("__name__", "metric", "lbl", "HFnEaGl")
ls2 = labels.FromStrings("__name__", "metric", "lbl", "RqcXatm")
}
if ls1.Hash() != ls2.Hash() {
panic("This code needs to be updated: find new labels with colliding hash values.")
}
return ls1, ls2
}
// stripeSeriesWithCollidingSeries returns a stripeSeries with two memSeries having the same, colliding, hash.
func stripeSeriesWithCollidingSeries(_ *testing.T) (*stripeSeries, *memSeries, *memSeries) {
lbls1, lbls2 := labelsWithHashCollision()
ms1 := memSeries{
lset: lbls1,
}
ms2 := memSeries{
lset: lbls2,
}
hash := lbls1.Hash()
s := newStripeSeries(1)
s.Set(hash, &ms1)
s.Set(hash, &ms2)
return s, &ms1, &ms2
}
func TestStripeSeries_Get(t *testing.T) {
s, ms1, ms2 := stripeSeriesWithCollidingSeries(t)
hash := ms1.lset.Hash()
// Verify that we can get both of the series despite the hash collision
got := s.GetByHash(hash, ms1.lset)
require.Same(t, ms1, got)
got = s.GetByHash(hash, ms2.lset)
require.Same(t, ms2, got)
}
func TestStripeSeries_gc(t *testing.T) {
s, ms1, ms2 := stripeSeriesWithCollidingSeries(t)
hash := ms1.lset.Hash()
s.GC(1)
// Verify that we can get neither ms1 nor ms2 after gc-ing corresponding series
got := s.GetByHash(hash, ms1.lset)
require.Nil(t, got)
got = s.GetByHash(hash, ms2.lset)
require.Nil(t, got)
}

View file

@ -60,7 +60,11 @@ func TestDirLockerUsage(t *testing.T, open func(t *testing.T, data string, creat
for _, c := range cases { for _, c := range cases {
t.Run(fmt.Sprintf("%+v", c), func(t *testing.T) { t.Run(fmt.Sprintf("%+v", c), func(t *testing.T) {
tmpdir := t.TempDir() tmpdir, err := os.MkdirTemp("", "test")
require.NoError(t, err)
t.Cleanup(func() {
require.NoError(t, os.RemoveAll(tmpdir))
})
// Test preconditions (file already exists + lockfile option) // Test preconditions (file already exists + lockfile option)
if c.fileAlreadyExists { if c.fileAlreadyExists {
@ -78,7 +82,7 @@ func TestDirLockerUsage(t *testing.T, open func(t *testing.T, data string, creat
// Check that the lockfile is always deleted // Check that the lockfile is always deleted
if !c.lockFileDisabled { if !c.lockFileDisabled {
_, err := os.Stat(locker.path) _, err = os.Stat(locker.path)
require.True(t, os.IsNotExist(err), "lockfile was not deleted") require.True(t, os.IsNotExist(err), "lockfile was not deleted")
} }
}) })