mirror of
https://github.com/VictoriaMetrics/VictoriaMetrics.git
synced 2025-01-12 05:28:13 +01:00
70 lines
1.8 KiB
Go
70 lines
1.8 KiB
Go
|
package logstorage
|
||
|
|
||
|
import (
|
||
|
"fmt"
|
||
|
)
|
||
|
|
||
|
// streamID is an internal id of log stream.
|
||
|
//
|
||
|
// Blocks are ordered by streamID inside parts.
|
||
|
type streamID struct {
|
||
|
// tenantID is a tenant id for the given stream.
|
||
|
// It is located at the beginning of streamID in order
|
||
|
// to physically group blocks for the same tenants on the storage.
|
||
|
tenantID TenantID
|
||
|
|
||
|
// id is internal id, which uniquely identifies the stream in the tenant by its labels.
|
||
|
// It is calculated as a hash of canonically sorted stream labels.
|
||
|
//
|
||
|
// Streams with identical sets of labels, which belong to distinct tenants, have the same id.
|
||
|
id u128
|
||
|
}
|
||
|
|
||
|
// reset resets sid for subsequent re-use
|
||
|
func (sid *streamID) reset() {
|
||
|
*sid = streamID{}
|
||
|
}
|
||
|
|
||
|
// String returns human-readable representation for sid.
|
||
|
func (sid *streamID) String() string {
|
||
|
return fmt.Sprintf("(tenant_id=%s, id=%s)", &sid.tenantID, &sid.id)
|
||
|
}
|
||
|
|
||
|
// less returns true if a is less than sid.
|
||
|
func (sid *streamID) less(a *streamID) bool {
|
||
|
if !sid.tenantID.equal(&a.tenantID) {
|
||
|
return sid.tenantID.less(&a.tenantID)
|
||
|
}
|
||
|
return sid.id.less(&a.id)
|
||
|
}
|
||
|
|
||
|
// equal returns true if sid equalt to a.
|
||
|
func (sid *streamID) equal(a *streamID) bool {
|
||
|
if !sid.tenantID.equal(&a.tenantID) {
|
||
|
return false
|
||
|
}
|
||
|
return sid.id.equal(&a.id)
|
||
|
}
|
||
|
|
||
|
// marshal appends the marshaled sid to dst and returns the result
|
||
|
func (sid *streamID) marshal(dst []byte) []byte {
|
||
|
dst = sid.tenantID.marshal(dst)
|
||
|
dst = sid.id.marshal(dst)
|
||
|
return dst
|
||
|
}
|
||
|
|
||
|
// unmarshal unmarshals sid from src and returns the tail from src.
|
||
|
func (sid *streamID) unmarshal(src []byte) ([]byte, error) {
|
||
|
srcOrig := src
|
||
|
tail, err := sid.tenantID.unmarshal(src)
|
||
|
if err != nil {
|
||
|
return srcOrig, err
|
||
|
}
|
||
|
src = tail
|
||
|
tail, err = sid.id.unmarshal(src)
|
||
|
if err != nil {
|
||
|
return srcOrig, err
|
||
|
}
|
||
|
return tail, nil
|
||
|
}
|