lib/protoparser/opentsdb: follow-up after 8ee75ca45a

This commit is contained in:
Aliaksandr Valialkin 2021-08-29 11:49:21 +03:00
parent 00dddfe02f
commit 18d7adf731
2 changed files with 17 additions and 5 deletions

View File

@ -21,6 +21,7 @@ sort: 15
* BUGFIX: improve the detection of the needed free space for background merge operation. This should prevent from possible out of disk space crashes during big merges. See [this issue](https://github.com/VictoriaMetrics/VictoriaMetrics/issues/1560). * BUGFIX: improve the detection of the needed free space for background merge operation. This should prevent from possible out of disk space crashes during big merges. See [this issue](https://github.com/VictoriaMetrics/VictoriaMetrics/issues/1560).
* BUGFIX: vmauth: remove trailing slash from the full url before requesting it from the backend. See [this pull request](https://github.com/VictoriaMetrics/VictoriaMetrics/pull/1554). * BUGFIX: vmauth: remove trailing slash from the full url before requesting it from the backend. See [this pull request](https://github.com/VictoriaMetrics/VictoriaMetrics/pull/1554).
* BUGFIX: [vmbackupmanager](https://docs.victoriametrics.com/vmbackupmanager.html): fix timeout error when snapshot takes longer than 10 seconds. See [this issue](https://github.com/VictoriaMetrics/VictoriaMetrics/issues/1571). * BUGFIX: [vmbackupmanager](https://docs.victoriametrics.com/vmbackupmanager.html): fix timeout error when snapshot takes longer than 10 seconds. See [this issue](https://github.com/VictoriaMetrics/VictoriaMetrics/issues/1571).
* BUGFIX: properly parse OpenTSDB `put` messages with multiple spaces between message elements. See [this issue](https://github.com/VictoriaMetrics/VictoriaMetrics/issues/1574). Thanks to @envzhu for the fix.
## [v1.64.1](https://github.com/VictoriaMetrics/VictoriaMetrics/releases/tag/v1.64.1) ## [v1.64.1](https://github.com/VictoriaMetrics/VictoriaMetrics/releases/tag/v1.64.1)

View File

@ -57,11 +57,12 @@ func (r *Row) reset() {
func (r *Row) unmarshal(s string, tagsPool []Tag) ([]Tag, error) { func (r *Row) unmarshal(s string, tagsPool []Tag) ([]Tag, error) {
r.reset() r.reset()
s = strings.TrimSpace(s) s = trimLeadingSpaces(s)
if !strings.HasPrefix(s, "put ") { if !strings.HasPrefix(s, "put ") {
return tagsPool, fmt.Errorf("missing `put ` prefix in %q", s) return tagsPool, fmt.Errorf("missing `put ` prefix in %q", s)
} }
s = strings.TrimSpace(s[len("put "):]) s = s[len("put "):]
s = trimLeadingSpaces(s)
n := strings.IndexByte(s, ' ') n := strings.IndexByte(s, ' ')
if n < 0 { if n < 0 {
return tagsPool, fmt.Errorf("cannot find whitespace between metric and timestamp in %q", s) return tagsPool, fmt.Errorf("cannot find whitespace between metric and timestamp in %q", s)
@ -70,7 +71,7 @@ func (r *Row) unmarshal(s string, tagsPool []Tag) ([]Tag, error) {
if len(r.Metric) == 0 { if len(r.Metric) == 0 {
return tagsPool, fmt.Errorf("metric cannot be empty") return tagsPool, fmt.Errorf("metric cannot be empty")
} }
tail := strings.TrimSpace(s[n+1:]) tail := trimLeadingSpaces(s[n+1:])
n = strings.IndexByte(tail, ' ') n = strings.IndexByte(tail, ' ')
if n < 0 { if n < 0 {
return tagsPool, fmt.Errorf("cannot find whitespace between timestamp and value in %q", s) return tagsPool, fmt.Errorf("cannot find whitespace between timestamp and value in %q", s)
@ -80,7 +81,7 @@ func (r *Row) unmarshal(s string, tagsPool []Tag) ([]Tag, error) {
return tagsPool, fmt.Errorf("cannot parse timestamp from %q: %w", tail[:n], err) return tagsPool, fmt.Errorf("cannot parse timestamp from %q: %w", tail[:n], err)
} }
r.Timestamp = int64(timestamp) r.Timestamp = int64(timestamp)
tail = strings.TrimSpace(tail[n+1:]) tail = trimLeadingSpaces(tail[n+1:])
n = strings.IndexByte(tail, ' ') n = strings.IndexByte(tail, ' ')
if n < 0 { if n < 0 {
return tagsPool, fmt.Errorf("cannot find whitespace between value and the first tag in %q", s) return tagsPool, fmt.Errorf("cannot find whitespace between value and the first tag in %q", s)
@ -142,6 +143,10 @@ var invalidLines = metrics.NewCounter(`vm_rows_invalid_total{type="opentsdb"}`)
func unmarshalTags(dst []Tag, s string) ([]Tag, error) { func unmarshalTags(dst []Tag, s string) ([]Tag, error) {
for { for {
s = trimLeadingSpaces(s)
if len(s) == 0 {
return dst, nil
}
if cap(dst) > len(dst) { if cap(dst) > len(dst) {
dst = dst[:len(dst)+1] dst = dst[:len(dst)+1]
} else { } else {
@ -149,7 +154,6 @@ func unmarshalTags(dst []Tag, s string) ([]Tag, error) {
} }
tag := &dst[len(dst)-1] tag := &dst[len(dst)-1]
s = strings.TrimSpace(s)
n := strings.IndexByte(s, ' ') n := strings.IndexByte(s, ' ')
if n < 0 { if n < 0 {
// The last tag found // The last tag found
@ -194,3 +198,10 @@ func (t *Tag) unmarshal(s string) error {
t.Value = s[n+1:] t.Value = s[n+1:]
return nil return nil
} }
func trimLeadingSpaces(s string) string {
for len(s) > 0 && s[0] == ' ' {
s = s[1:]
}
return s
}