mirror of
https://github.com/VictoriaMetrics/VictoriaMetrics.git
synced 2025-01-07 16:42:27 +01:00
lib/protoparser/opentsdb: follow-up after 8ee75ca45a
This commit is contained in:
parent
00dddfe02f
commit
18d7adf731
@ -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)
|
||||||
|
@ -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
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user