sharding

package
v0.0.27 Latest Latest
Warning

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

Go to latest
Published: Feb 20, 2021 License: Apache-2.0 Imports: 8 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type Shard

type Shard interface {
	// ID is the shard ID. The shard ID is calculated through a shard function
	// which will map an identifier to a particular shard.
	ID() int

	// NodeID returns the node responsible for the shard.
	NodeID() string

	// SetNodeID sets the node ID for the shard
	SetNodeID(nodeID string)
}

Shard represents a partition that a single node is responsible for.

func NewShard

func NewShard(id int) Shard

NewShard creates a new shard with a weight

type ShardFunc

type ShardFunc func(interface{}) int

ShardFunc is a sharding function

func NewIntSharder

func NewIntSharder(max int64) ShardFunc

NewIntSharder shards on integers using a simple mod operation. The returned integer is the shard.

func NewStringSharder

func NewStringSharder(max int) ShardFunc

NewStringSharder hashes a string and calculates a shard based on the hash value. The returned integer is the shard id.

type ShardMap

type ShardMap interface {
	// Init reinitializes the (shard) manager. This can be called one and only
	// once. Performance critical since this is part of the node
	// onboarding process. Shard IDs are assigned from 0...maxShards-1
	Init(maxShards int) error

	// UpdateNodes syncs the nodes internally in the cluster and reshards if
	// necessary.
	UpdateNodes(nodeID ...string)

	// GetNode returns the node (ID) responsible for the shards. Performance
	// critical since this will be used in every single call to determine
	// the home location for mutations.
	// TBD: Panic if the shard ID is > maxShards?
	MapToNode(shardID int) Shard

	// Shards returns a copy of all of the shards. Not performance critical. This
	// is typically used for diagnostics.
	Shards() []Shard

	// ShardCount returns the number of shards
	ShardCount() int

	// NodeList returns a list of nodes in the shard map
	NodeList() []string

	// ShardCountForNode returns the number of shards allocated to a particular node.
	ShardCountForNode(nodeid string) int

	// WorkerID returns the worker ID for the node
	WorkerID(nodeID string) int

	// NewShards lists the new shards in this map compared to the old one. This
	// node is now responsible for these shards.
	NewShards(nodeID string, oldMap ShardMap) []Shard

	// DeletedShards lists the deleted shards in this map compared to the old
	// one. These shards can be dropped by the node when there's a reshard.
	DeletedShards(nodeID string, oldMap ShardMap) []Shard

	encoding.BinaryMarshaler
	encoding.BinaryUnmarshaler
}

ShardMap is a type that manages shards. The number of shards are immutable, ie no new shards will be added for the lifetime. (shards can be added or removed between invocations of the leader)

func NewShardMap

func NewShardMap() ShardMap

NewShardMap creates a new shard mapper instance.

Directories

Path Synopsis
Package shardpb contains the protobuf-generated code for the internal cluster communication
Package shardpb contains the protobuf-generated code for the internal cluster communication

Jump to

Keyboard shortcuts

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