VictoriaMetrics/app/vlselect/logsql/logsql.go

70 lines
1.6 KiB
Go
Raw Normal View History

package logsql
import (
2024-04-26 21:47:50 +00:00
"context"
"net/http"
"github.com/VictoriaMetrics/VictoriaMetrics/app/vlstorage"
"github.com/VictoriaMetrics/VictoriaMetrics/lib/bytesutil"
"github.com/VictoriaMetrics/VictoriaMetrics/lib/httpserver"
"github.com/VictoriaMetrics/VictoriaMetrics/lib/httputils"
"github.com/VictoriaMetrics/VictoriaMetrics/lib/logstorage"
)
2024-04-26 21:47:50 +00:00
// ProcessQueryRequest handles /select/logsql/query request.
func ProcessQueryRequest(ctx context.Context, w http.ResponseWriter, r *http.Request) {
// Extract tenantID
tenantID, err := logstorage.GetTenantIDFromRequest(r)
if err != nil {
httpserver.Errorf(w, r, "%s", err)
return
}
limit, err := httputils.GetInt(r, "limit")
if err != nil {
httpserver.Errorf(w, r, "%s", err)
return
}
qStr := r.FormValue("query")
q, err := logstorage.ParseQuery(qStr)
if err != nil {
httpserver.Errorf(w, r, "cannot parse query [%s]: %s", qStr, err)
return
}
w.Header().Set("Content-Type", "application/stream+json; charset=utf-8")
2024-05-14 01:04:11 +00:00
if limit > 0 {
q.AddPipeLimit(uint64(limit))
}
2024-05-15 01:23:33 +00:00
q.Optimize()
2024-05-14 01:04:11 +00:00
tenantIDs := []logstorage.TenantID{tenantID}
2024-04-26 21:47:50 +00:00
2024-05-14 01:04:11 +00:00
bw := getBufferedWriter(w)
2024-04-26 21:47:50 +00:00
writeBlock := func(_ uint, timestamps []int64, columns []logstorage.BlockColumn) {
if len(columns) == 0 {
return
}
bb := blockResultPool.Get()
2024-04-26 21:47:50 +00:00
for i := range timestamps {
WriteJSONRow(bb, columns, i)
}
2024-05-14 01:04:11 +00:00
bw.WriteIgnoreErrors(bb.B)
blockResultPool.Put(bb)
2024-04-26 21:47:50 +00:00
}
2024-05-14 01:04:11 +00:00
err = vlstorage.RunQuery(ctx, tenantIDs, q, writeBlock)
2024-04-26 21:47:50 +00:00
2024-05-14 01:04:11 +00:00
bw.FlushIgnoreErrors()
putBufferedWriter(bw)
2024-04-27 20:08:03 +00:00
if err != nil {
2024-05-06 20:27:10 +00:00
httpserver.Errorf(w, r, "cannot execute query [%s]: %s", qStr, err)
2024-04-27 20:08:03 +00:00
}
}
var blockResultPool bytesutil.ByteBufferPool