mirror of
https://gitee.com/milvus-io/milvus.git
synced 2024-12-05 05:18:52 +08:00
6bc7e6d372
Signed-off-by: rain <boyan.wang@zilliz.com>
75 lines
1.6 KiB
Go
75 lines
1.6 KiB
Go
package mock
|
|
|
|
import (
|
|
"bytes"
|
|
"encoding/gob"
|
|
"time"
|
|
)
|
|
|
|
type SegmentStats struct {
|
|
SegementID uint64
|
|
MemorySize uint64
|
|
MemoryRate float64
|
|
}
|
|
|
|
func SegmentMarshal(s SegmentStats) ([]byte, error) {
|
|
var nb bytes.Buffer
|
|
enc := gob.NewEncoder(&nb)
|
|
err := enc.Encode(s)
|
|
if err != nil {
|
|
return []byte{}, err
|
|
}
|
|
return nb.Bytes(), nil
|
|
}
|
|
|
|
func SegmentUnMarshal(data []byte) (SegmentStats, error) {
|
|
var ss SegmentStats
|
|
dec := gob.NewDecoder(bytes.NewBuffer(data))
|
|
err := dec.Decode(&ss)
|
|
if err != nil {
|
|
return SegmentStats{}, err
|
|
}
|
|
return ss, nil
|
|
}
|
|
|
|
type Segment struct {
|
|
SegmentID uint64 `json:"segment_id"`
|
|
CollectionID uint64 `json:"collection_id"`
|
|
PartitionTag string `json:"partition_tag"`
|
|
ChannelStart int `json:"channel_start"`
|
|
ChannelEnd int `json:"channel_end"`
|
|
OpenTimeStamp uint64 `json:"open_timestamp"`
|
|
CloseTimeStamp uint64 `json:"close_timestamp"`
|
|
CollectionName string `json:"collection_name"`
|
|
}
|
|
|
|
func NewSegment(id uint64, collectioID uint64, cName string, ptag string, chStart int, chEnd int, openTime time.Time, closeTime time.Time) Segment {
|
|
return Segment{
|
|
SegmentID: id,
|
|
CollectionID: collectioID,
|
|
CollectionName: cName,
|
|
PartitionTag: ptag,
|
|
ChannelStart: chStart,
|
|
ChannelEnd: chEnd,
|
|
OpenTimeStamp: uint64(openTime.Unix()),
|
|
CloseTimeStamp: uint64(closeTime.Unix()),
|
|
}
|
|
}
|
|
func Segment2JSON(s Segment) (string, error) {
|
|
b, err := json.Marshal(&s)
|
|
if err != nil {
|
|
return "", err
|
|
}
|
|
|
|
return string(b), nil
|
|
}
|
|
|
|
func JSON2Segment(s string) (*Segment, error) {
|
|
var c Segment
|
|
err := json.Unmarshal([]byte(s), &c)
|
|
if err != nil {
|
|
return &Segment{}, err
|
|
}
|
|
return &c, nil
|
|
}
|