replication

package
v0.0.0-...-8388a8e Latest Latest
Warning

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

Go to latest
Published: Mar 15, 2024 License: MIT Imports: 11 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type Delta

type Delta struct {
	Kind    DeltaKind
	Replica Replica
}

func ComputeDelta

func ComputeDelta(before, after []Replica) []Delta

type DeltaKind

type DeltaKind uint8
const (
	Removed DeltaKind = iota + 1
	Added
)

type Manager

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

Manager is responsible for the runtime management of replicas. It maintains connections to replicas and periodically flushes new log entries to the tasks

func NewManager

func NewManager(seeker dbLog.SeekingLog) *Manager

func (*Manager) Reconcile

func (m *Manager) Reconcile(replicas []Replica) error

Reconcile - Every time we receive new metadata we need to reconcile them with the old version to see if our replica membership has changed, and then act accordingly

func (*Manager) Start

func (m *Manager) Start(ctx context.Context) <-chan struct{}

type Replica

type Replica struct {
	Start, End  uint128.Uint128
	PrivateAddr *net.TCPAddr
}

func FromMetadata

func FromMetadata(m protocol.Metadata, coordinator uuid.UUID) []Replica

FromMetadata - get tasks for a given coordinator

func (*Replica) String

func (r *Replica) String() string

Jump to

Keyboard shortcuts

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