mirror of
https://github.com/VictoriaMetrics/VictoriaMetrics.git
synced 2024-11-21 14:44:00 +00:00
refactor(vmstorage): Refactor the code to reduce the time complexity of MustAddRows
and improve readability (#6629)
### Describe Your Changes The original logic is not only highly complex but also poorly readable, so it can be modified to increase readability and reduce time complexity. --------- Co-authored-by: Zhu Jiekun <jiekun@victoriametrics.com>
This commit is contained in:
parent
0593310e89
commit
e280d90e9a
3 changed files with 13 additions and 9 deletions
|
@ -33,6 +33,7 @@ See also [LTS releases](./LTS-releases.md).
|
|||
|
||||
* SECURITY: upgrade base docker image (Alpine) from 3.20.1 to 3.20.2. See [alpine 3.20.2 release notes](https://alpinelinux.org/posts/Alpine-3.20.2-released.html).
|
||||
|
||||
* FEATURE: [VictoriaMetrics Single-Node](https://docs.victoriametrics.com/) and [VictoriaMetrics Cluster](https://docs.victoriametrics.com/cluster-victoriametrics/): Refactor the code located in the `MustAddRows` function of `vmstorage` to improve performance and readability.
|
||||
* FEATURE: [vmauth](./vmauth.md): add `keep_original_host` option, which can be used for proxying the original `Host` header from client request to the backend. By default the backend host is used as `Host` header when proxying requests to the configured backends. See [these docs](./vmauth.md#host-http-header).
|
||||
* FEATURE: [vmauth](./vmauth.md) now returns HTTP 502 status code when all upstream backends are not available. Previously, it returned HTTP 503 status code. This change aligns vmauth behavior with other well-known reverse-proxies behavior.
|
||||
|
||||
|
|
|
@ -849,6 +849,11 @@ func (pt *partition) HasTimestamp(timestamp int64) bool {
|
|||
return timestamp >= pt.tr.MinTimestamp && timestamp <= pt.tr.MaxTimestamp
|
||||
}
|
||||
|
||||
// TimeRangeInPartition returns true if the pt contains the given time range.
|
||||
func (pt *partition) TimeRangeInPartition(minTimestamp, MaxTimestamp int64) bool {
|
||||
return minTimestamp >= pt.tr.MinTimestamp && MaxTimestamp <= pt.tr.MaxTimestamp
|
||||
}
|
||||
|
||||
// GetParts appends parts snapshot to dst and returns it.
|
||||
//
|
||||
// The appended parts must be released with PutParts.
|
||||
|
|
|
@ -267,7 +267,12 @@ func (tb *table) MustAddRows(rows []rawRow) {
|
|||
if len(rows) == 0 {
|
||||
return
|
||||
}
|
||||
|
||||
// Get the maximum and minimum timestamps in the rows
|
||||
maxTsInRows, minTsInRows := rows[0].Timestamp, rows[0].Timestamp
|
||||
for i := range rows {
|
||||
maxTsInRows = max(maxTsInRows, rows[i].Timestamp)
|
||||
minTsInRows = min(minTsInRows, rows[i].Timestamp)
|
||||
}
|
||||
// Verify whether all the rows may be added to a single partition.
|
||||
ptwsX := getPartitionWrappers()
|
||||
defer putPartitionWrappers(ptwsX)
|
||||
|
@ -275,14 +280,7 @@ func (tb *table) MustAddRows(rows []rawRow) {
|
|||
ptwsX.a = tb.GetPartitions(ptwsX.a[:0])
|
||||
ptws := ptwsX.a
|
||||
for i, ptw := range ptws {
|
||||
singlePt := true
|
||||
for j := range rows {
|
||||
if !ptw.pt.HasTimestamp(rows[j].Timestamp) {
|
||||
singlePt = false
|
||||
break
|
||||
}
|
||||
}
|
||||
if !singlePt {
|
||||
if !ptw.pt.TimeRangeInPartition(minTsInRows, maxTsInRows) {
|
||||
continue
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue