shardingmilkyway

package
v0.0.0-...-e70b4cf Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Aug 11, 2022 License: Apache-2.0 Imports: 7 Imported by: 0

Documentation

Index

Constants

View Source
const (
	Filepath = "sharding"
)

Variables

View Source
var (
	ErrAddsTimeout                      = errors.New("add multiple key timeout")
	ErrCannotModifyTheNestConfiguration = errors.New("when historical data exists, you cannot modify the nest " +
		"configuration")
)

Functions

func ChecksumKeyModulo

func ChecksumKeyModulo(key bn.Key, length int) int

ChecksumKeyModulo uint32 checksum

Types

type KeyModuloAlgorithm

type KeyModuloAlgorithm func(key bn.Key, length int) int

type ModuloShardingAlgorithm

type ModuloShardingAlgorithm struct {
	Length int
}

func NewModuloSA

func NewModuloSA(l int) *ModuloShardingAlgorithm

func (ModuloShardingAlgorithm) DoSharding

func (a ModuloShardingAlgorithm) DoSharding(shardingValues []bn.Key) [][]bn.Key

DoSharding 如果传入 shardingValues 小于 Length 则 最小设置为1

func (ModuloShardingAlgorithm) DoShardingOnce

func (a ModuloShardingAlgorithm) DoShardingOnce(key bn.Key) (index int)

type ShardingAlgorithm

type ShardingAlgorithm interface {
	DoSharding(shardingValues []bn.Key) [][]bn.Key
	DoShardingOnce(bn.Key) (index int)
}

type ShardingMilkyWay

type ShardingMilkyWay struct {
	// contains filtered or unexported fields
}

func NewShardingMilkyWay

func NewShardingMilkyWay(config *common.ShardingMilkyWayConfig, exitC chan struct{}, strategy bn.Strategy,
	alg ShardingAlgorithm, logger bn.Logger) (*ShardingMilkyWay, error)

func (*ShardingMilkyWay) Add

func (s *ShardingMilkyWay) Add(key bn.Key) error

func (*ShardingMilkyWay) Adds

func (s *ShardingMilkyWay) Adds(keys []bn.Key) (err error)

func (*ShardingMilkyWay) AddsAndSetHeight

func (s *ShardingMilkyWay) AddsAndSetHeight(keys []bn.Key, height uint64) (result error)

func (*ShardingMilkyWay) Contains

func (s *ShardingMilkyWay) Contains(key bn.Key, rules ...common.RuleType) (bool, error)

func (*ShardingMilkyWay) Deserialize

func (s *ShardingMilkyWay) Deserialize() error

func (*ShardingMilkyWay) GetHeight

func (s *ShardingMilkyWay) GetHeight() uint64

func (*ShardingMilkyWay) Info

func (s *ShardingMilkyWay) Info() []uint64

func (*ShardingMilkyWay) Infos

func (s *ShardingMilkyWay) Infos() [][]uint64

Infos index 0 sharding index index 0 height index 1 cuckoo size index 2 current index index 3 total cuckoo size index 4 total space occupied by cuckoo

func (*ShardingMilkyWay) Serialize

func (s *ShardingMilkyWay) Serialize() error

func (*ShardingMilkyWay) SetHeight

func (s *ShardingMilkyWay) SetHeight(height uint64)

func (*ShardingMilkyWay) Start

func (s *ShardingMilkyWay) Start()

Start TODO Goroutinue should be turned off using context.Context here

func (*ShardingMilkyWay) ValidateRule

func (s *ShardingMilkyWay) ValidateRule(key bn.Key, rules ...common.RuleType) error

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL