mirror of
https://github.com/VictoriaMetrics/VictoriaMetrics.git
synced 2025-01-07 08:32:18 +01:00
lib/protoparser/promremotewrite: forward errors, which can occur during data ingestion, to the caller of ParseStream, so it could properly return HTTP 503 status code on non-nil error
Updates https://github.com/VictoriaMetrics/VictoriaMetrics/issues/896
This commit is contained in:
parent
13b547f218
commit
739b88c1e4
@ -15,6 +15,7 @@
|
|||||||
|
|
||||||
* BUGFIX: do not return data points in the end of the selected time range for time series ending in the middle of the selected time range.
|
* BUGFIX: do not return data points in the end of the selected time range for time series ending in the middle of the selected time range.
|
||||||
See https://github.com/VictoriaMetrics/VictoriaMetrics/issues/887 and https://github.com/VictoriaMetrics/VictoriaMetrics/issues/845
|
See https://github.com/VictoriaMetrics/VictoriaMetrics/issues/887 and https://github.com/VictoriaMetrics/VictoriaMetrics/issues/845
|
||||||
|
* BUGFIX: vminsert: properly return HTTP 503 status code when all the vmstorage nodes are unavailable. See https://github.com/VictoriaMetrics/VictoriaMetrics/issues/896
|
||||||
|
|
||||||
|
|
||||||
# [v1.46.0](https://github.com/VictoriaMetrics/VictoriaMetrics/releases/tag/v1.46.0)
|
# [v1.46.0](https://github.com/VictoriaMetrics/VictoriaMetrics/releases/tag/v1.46.0)
|
||||||
|
@ -32,20 +32,33 @@ func ParseStream(req *http.Request, callback func(tss []prompb.TimeSeries) error
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
uw := getUnmarshalWork()
|
uw := getUnmarshalWork()
|
||||||
uw.callback = callback
|
ctx.wg.Add(1)
|
||||||
|
uw.callback = func(tss []prompb.TimeSeries) error {
|
||||||
|
// Propagate the error to the caller of ParseStream, so it could properly return HTTP 503 status code on error.
|
||||||
|
// See https://github.com/VictoriaMetrics/VictoriaMetrics/issues/896
|
||||||
|
ctx.err = callback(tss)
|
||||||
|
ctx.wg.Done()
|
||||||
|
// Do not return the error from callback in order to prevent from double logging.
|
||||||
|
return nil
|
||||||
|
}
|
||||||
uw.reqBuf, ctx.reqBuf.B = ctx.reqBuf.B, uw.reqBuf
|
uw.reqBuf, ctx.reqBuf.B = ctx.reqBuf.B, uw.reqBuf
|
||||||
common.ScheduleUnmarshalWork(uw)
|
common.ScheduleUnmarshalWork(uw)
|
||||||
return nil
|
ctx.wg.Wait()
|
||||||
|
return ctx.err
|
||||||
}
|
}
|
||||||
|
|
||||||
type pushCtx struct {
|
type pushCtx struct {
|
||||||
br *bufio.Reader
|
br *bufio.Reader
|
||||||
reqBuf bytesutil.ByteBuffer
|
reqBuf bytesutil.ByteBuffer
|
||||||
|
|
||||||
|
wg sync.WaitGroup
|
||||||
|
err error
|
||||||
}
|
}
|
||||||
|
|
||||||
func (ctx *pushCtx) reset() {
|
func (ctx *pushCtx) reset() {
|
||||||
ctx.br.Reset(nil)
|
ctx.br.Reset(nil)
|
||||||
ctx.reqBuf.Reset()
|
ctx.reqBuf.Reset()
|
||||||
|
ctx.err = nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (ctx *pushCtx) Read() error {
|
func (ctx *pushCtx) Read() error {
|
||||||
|
Loading…
Reference in New Issue
Block a user