meta

package
v1.3.25 Latest Latest
Warning

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

Go to latest
Published: Oct 6, 2024 License: MIT Imports: 18 Imported by: 2

Documentation

Overview

Package meta: cluster-level metadata

  • Copyright (c) 2018-2024, NVIDIA CORPORATION. All rights reserved.

Package meta: cluster-level metadata

  • Copyright (c) 2024, NVIDIA CORPORATION. All rights reserved.

Package meta: cluster-level metadata

  • Copyright (c) 2018-2023, NVIDIA CORPORATION. All rights reserved.

Package meta: cluster-level metadata

  • Copyright (c) 2018-2024, NVIDIA CORPORATION. All rights reserved.

Package meta: cluster-level metadata

  • Copyright (c) 2018-2023, NVIDIA CORPORATION. All rights reserved.

Package meta: cluster-level metadata

  • Copyright (c) 2024, NVIDIA CORPORATION. All rights reserved.

Package meta: cluster-level metadata

  • Copyright (c) 2018-2023, NVIDIA CORPORATION. All rights reserved.

Package meta: cluster-level metadata

  • Copyright (c) 2018-2024, NVIDIA CORPORATION. All rights reserved.

Package meta: cluster-level metadata

  • Copyright (c) 2018-2024, NVIDIA CORPORATION. All rights reserved.

Index

Constants

View Source
const (
	SnodeNonElectable cos.BitFlags = 1 << iota
	SnodeIC
	SnodeMaint
	SnodeDecomm
	SnodeMaintPostReb
)

enum Snode.Flags

View Source
const (
	PnamePrefix = "p["
	TnamePrefix = "t["
	SnameSuffix = "]"
)
View Source
const AisBID = uint64(1 << 63)
View Source
const DfltCountIC = 3

desirable gateway count in the Information Center (IC)

View Source
const SnodeMaintDecomm = SnodeMaint | SnodeDecomm

Variables

This section is empty.

Functions

func FreeNodes

func FreeNodes(nodes Nodes)

func N2ID

func N2ID(name string) string

func NewBID added in v1.3.24

func NewBID(serial int64, isAis bool) uint64

func Pname

func Pname(pid string) string

func Tname

func Tname(tid string) string

Types

type BID added in v1.3.24

type BID uint64

type BMD

type BMD struct {
	Ext       any       `json:"ext,omitempty"`  // within meta-version extensions
	Providers Providers `json:"providers"`      // (provider, namespace, bucket) hierarchy
	UUID      string    `json:"uuid"`           // unique & immutable
	Version   int64     `json:"version,string"` // gets incremented on every update
}

- BMD is the root of the (providers, namespaces, buckets) hierarchy - BMD (instance) can be obtained via Bowner.Get() - BMD is immutable and versioned - BMD versioning is monotonic and incremental

func (*BMD) Add

func (m *BMD) Add(bck *Bck)

func (*BMD) Del

func (m *BMD) Del(bck *Bck) (deleted bool)

func (*BMD) Exists

func (m *BMD) Exists(bck *Bck, bckID uint64) (exists bool)

func (*BMD) Get

func (m *BMD) Get(bck *Bck) (p *cmn.Bprops, present bool)

func (*BMD) IsECUsed

func (m *BMD) IsECUsed() (yes bool)

func (*BMD) IsEmpty

func (m *BMD) IsEmpty() bool

func (*BMD) JspOpts

func (*BMD) JspOpts() jsp.Options

func (*BMD) Range

func (m *BMD) Range(providerQuery *string, nsQuery *cmn.Ns, callback func(*Bck) bool)

providerQuery == nil: all providers; nsQuery == nil: all namespaces

func (*BMD) Select

func (m *BMD) Select(qbck *cmn.QueryBcks) cmn.Bcks

func (*BMD) Set

func (m *BMD) Set(bck *Bck, p *cmn.Bprops)

func (*BMD) String

func (m *BMD) String() string

func (*BMD) StringEx

func (m *BMD) StringEx() string

type Bck

type Bck cmn.Bck

func CloneBck

func CloneBck(bck *cmn.Bck) *Bck

func InitByNameOnly

func InitByNameOnly(bckName string, bowner Bowner) (bck *Bck, err error, ecode int)

to support s3 clients: find an already existing bucket by name (and nothing else) returns an error when name cannot be unambiguously resolved to a single bucket

func NewBck

func NewBck(name, provider string, ns cmn.Ns, optProps ...*cmn.Bprops) *Bck

func (*Bck) AddToQuery

func (b *Bck) AddToQuery(q url.Values) url.Values

func (*Bck) AddUnameToQuery

func (b *Bck) AddUnameToQuery(q url.Values, uparam string) url.Values

func (*Bck) Allow

func (b *Bck) Allow(bit apc.AccessAttrs) error

func (*Bck) Backend

func (b *Bck) Backend() *Bck

func (*Bck) Bucket

func (b *Bck) Bucket() *cmn.Bck

cast *meta.Bck => *cmn.Bck

func (*Bck) CksumConf

func (b *Bck) CksumConf() (conf *cmn.CksumConf)

func (*Bck) Clone

func (b *Bck) Clone() cmn.Bck

clone (*meta.Bck | *cmn.Bck) <=> (cmn.Bck | meta.Bck) respectively

func (*Bck) Cname

func (b *Bck) Cname(name string) string

func (*Bck) Equal

func (b *Bck) Equal(other *Bck, sameID, sameBackend bool) bool

func (*Bck) HasProvider

func (b *Bck) HasProvider() bool

func (*Bck) HasVersioningMD

func (b *Bck) HasVersioningMD() bool

func (*Bck) Init

func (b *Bck) Init(bowner Bowner) (err error)

when the bucket is not present in the BMD: - always returns the corresponding *DoesNotExist error - Cloud bucket: fills in the props with defaults from config - AIS bucket: sets the props to nil - Remote (Cloud or Remote AIS) bucket: caller can type-cast err.(*cmn.ErrRemoteBckNotFound) and proceed

func (*Bck) InitFast

func (b *Bck) InitFast(bowner Bowner) (err error)

part of lom.init (compare with the above)

func (*Bck) InitNoBackend

func (b *Bck) InitNoBackend(bowner Bowner) error

func (*Bck) IsAIS

func (b *Bck) IsAIS() bool

func (*Bck) IsCloud

func (b *Bck) IsCloud() bool

func (*Bck) IsEmpty

func (b *Bck) IsEmpty() bool

func (*Bck) IsHT added in v1.3.24

func (b *Bck) IsHT() bool

func (*Bck) IsQuery

func (b *Bck) IsQuery() bool

func (*Bck) IsRemote

func (b *Bck) IsRemote() bool

func (*Bck) IsRemoteAIS

func (b *Bck) IsRemoteAIS() bool

func (*Bck) IsRemoteS3

func (b *Bck) IsRemoteS3() bool

func (*Bck) MakeUname

func (b *Bck) MakeUname(name string) []byte

func (*Bck) MaxPageSize

func (b *Bck) MaxPageSize() int64

func (*Bck) NewQuery

func (b *Bck) NewQuery() url.Values

func (*Bck) RemoteBck

func (b *Bck) RemoteBck() *cmn.Bck

func (*Bck) String

func (b *Bck) String() string

func (*Bck) Validate

func (b *Bck) Validate() error

func (*Bck) VersionConf

func (b *Bck) VersionConf() cmn.VersionConf

type Bowner

type Bowner interface {
	Get() (bmd *BMD)
}

interface to Get current (versioned, immutable) BMD instance (for implementation, see ais/bucketmeta.go)

type Buckets

type Buckets map[string]*cmn.Bprops

type Namespaces

type Namespaces map[string]Buckets

type NetInfo

type NetInfo struct {
	Hostname string `json:"node_ip_addr"`
	Port     string `json:"daemon_port"`
	URL      string `json:"direct_url"`
	// contains filtered or unexported fields
}

Snode's networking info

func (*NetInfo) Init

func (ni *NetInfo) Init(proto, hostname, port string)

func (*NetInfo) IsEmpty

func (ni *NetInfo) IsEmpty() bool

func (*NetInfo) String

func (ni *NetInfo) String() string

func (*NetInfo) TCPEndpoint

func (ni *NetInfo) TCPEndpoint() string

type NetNamer added in v1.3.24

type NetNamer interface {
	// contains filtered or unexported methods
}

type NodeMap

type NodeMap map[string]*Snode // map of Snodes indexed by node ID (Pmap & Tmap below)

func (NodeMap) ActiveMap

func (m NodeMap) ActiveMap() (clone NodeMap)

func (NodeMap) ActiveNodes

func (m NodeMap) ActiveNodes() []*Snode

func (NodeMap) Add

func (m NodeMap) Add(snode *Snode)

func (NodeMap) Contains

func (m NodeMap) Contains(daeID string) (exists bool)

type Nodes

type Nodes []*Snode // slice of Snodes

func AllocNodes

func AllocNodes(capacity int) (nodes Nodes)

type Providers

type Providers map[string]Namespaces

type RMD

type RMD struct {
	Ext       any      `json:"ext,omitempty"` // within meta-version extensions
	CluID     string   `json:"cluster_id"`    // effectively, Smap.UUID
	Resilver  string   `json:"resilver,omitempty"`
	TargetIDs []string `json:"target_ids,omitempty"`
	Version   int64    `json:"version"`
}

Rebalance MetaData

func (*RMD) JspOpts

func (*RMD) JspOpts() jsp.Options

type RemAis

type RemAis struct {
	URL   string `json:"url"`
	Alias string `json:"alias"`
	UUID  string `json:"uuid"` // Smap.UUID
	Smap  *Smap  `json:"smap"`
}

type RemAisVec

type RemAisVec struct {
	A   []*RemAis `json:"a"`
	Ver int64     `json:"ver"`
}

type Slistener

type Slistener interface {
	String() string
	ListenSmapChanged()
}

Smap On-change listeners (see ais/clustermap.go for impl-s)

type Smap

type Smap struct {
	Ext          any     `json:"ext,omitempty"`
	Pmap         NodeMap `json:"pmap"` // [pid => Snode]
	Primary      *Snode  `json:"proxy_si"`
	Tmap         NodeMap `json:"tmap"`          // [tid => Snode]
	UUID         string  `json:"uuid"`          // is assigned once at creation time, never changes
	CreationTime string  `json:"creation_time"` // creation timestamp
	Version      int64   `json:"version,string"`
}

cluster map

func (*Smap) Compare

func (m *Smap) Compare(other *Smap) (uuid string, sameOrigin, sameVersion, eq bool)

func (*Smap) CompareTargets

func (m *Smap) CompareTargets(other *Smap) (equal bool)

func (*Smap) Count

func (m *Smap) Count() int

func (*Smap) CountActivePs

func (m *Smap) CountActivePs() (count int)

func (*Smap) CountActiveTs

func (m *Smap) CountActiveTs() (count int)

func (*Smap) CountNonElectable

func (m *Smap) CountNonElectable() (count int)

func (*Smap) CountProxies

func (m *Smap) CountProxies() int

func (*Smap) CountTargets

func (m *Smap) CountTargets() int

func (*Smap) GetActiveNode

func (m *Smap) GetActiveNode(sid string) (si *Snode)

(convenient, slightly redundant)

func (*Smap) GetNode

func (m *Smap) GetNode(id string) *Snode

func (*Smap) GetProxy

func (m *Smap) GetProxy(pid string) *Snode

func (*Smap) GetRandProxy

func (m *Smap) GetRandProxy(excludePrimary bool) (si *Snode, err error)

func (*Smap) GetRandTarget

func (m *Smap) GetRandTarget() (tsi *Snode, err error)

(random active)

func (*Smap) GetTarget

func (m *Smap) GetTarget(sid string) *Snode

func (*Smap) HasActiveTs

func (m *Smap) HasActiveTs(except string) bool

whether this target has active peers

func (*Smap) HasPeersToRebalance added in v1.3.24

func (m *Smap) HasPeersToRebalance(except string) bool

func (*Smap) HrwHash2T

func (smap *Smap) HrwHash2T(digest uint64) (si *Snode, err error)

func (*Smap) HrwHash2Tall

func (smap *Smap) HrwHash2Tall(digest uint64) (si *Snode, err error)

NOTE: including targets 'in maintenance mode', if any

func (*Smap) HrwIC

func (smap *Smap) HrwIC(uuid string) (pi *Snode, err error)

func (*Smap) HrwMultiHome

func (smap *Smap) HrwMultiHome(uname []byte) (si *Snode, netName string, err error)

func (*Smap) HrwName2T

func (smap *Smap) HrwName2T(uname []byte) (*Snode, error)

func (*Smap) HrwProxy

func (smap *Smap) HrwProxy(idToSkip string) (pi *Snode, err error)

func (*Smap) HrwTargetList

func (smap *Smap) HrwTargetList(uname *string, count int) (sis Nodes, err error)

func (*Smap) HrwTargetTask

func (smap *Smap) HrwTargetTask(uuid string) (si *Snode, err error)

Returns a target for a given task. E.g. usage: list objects in a cloud bucket (we want only one target to do it).

func (*Smap) ICCount

func (m *Smap) ICCount() (count int)

func (*Smap) InMaint

func (m *Smap) InMaint(si *Snode) bool

func (*Smap) InMaintOrDecomm

func (m *Smap) InMaintOrDecomm(si *Snode) bool

given Snode, check (usually, the current) Smap that it is present _and_ InMaintOrDecomm (see also GetActiveNode)

func (*Smap) InitDigests

func (m *Smap) InitDigests()

func (*Smap) IsDupNet

func (m *Smap) IsDupNet(nsi *Snode) (osi *Snode, err error)

whether IP is in use by a different node

func (*Smap) IsIC

func (m *Smap) IsIC(psi *Snode) (ok bool)

func (*Smap) IsPrimary

func (m *Smap) IsPrimary(si *Snode) bool

func (*Smap) JspOpts

func (*Smap) JspOpts() jsp.Options

func (*Smap) NewTmap

func (m *Smap) NewTmap(tids []string) (tmap NodeMap, err error)

func (*Smap) NonElectable

func (m *Smap) NonElectable(psi *Snode) (ok bool)

func (*Smap) PubNet2Node

func (m *Smap) PubNet2Node(hostport string) *Snode

checking pub net only

func (*Smap) StrIC

func (m *Smap) StrIC(node *Snode) string

func (*Smap) String

func (m *Smap) String() string

func (*Smap) StringEx

func (m *Smap) StringEx() string

type SmapListeners

type SmapListeners interface {
	Reg(sl Slistener)
	Unreg(sl Slistener)
}

type Snode

type Snode struct {
	LocalNet   *net.IPNet `json:"-"`
	PubNet     NetInfo    `json:"public_net"` // cmn.NetPublic
	PubExtra   []NetInfo  `json:"pub_extra,omitempty"`
	DataNet    NetInfo    `json:"intra_data_net"`    // cmn.NetIntraData
	ControlNet NetInfo    `json:"intra_control_net"` // cmn.NetIntraControl
	DaeType    string     `json:"daemon_type"`       // "target" or "proxy"
	DaeID      string     `json:"daemon_id"`

	Flags cos.BitFlags `json:"flags"` // enum { SnodeNonElectable, SnodeIC, ... }
	// contains filtered or unexported fields
}

Snode - a node (gateway or target) in a cluster

func (*Snode) Clone

func (d *Snode) Clone() *Snode

func (*Snode) Digest

func (d *Snode) Digest() uint64

func (*Snode) Eq

func (d *Snode) Eq(o *Snode) (eq bool)

func (*Snode) Fl2S

func (d *Snode) Fl2S() string

func (*Snode) HasURL added in v1.3.23

func (d *Snode) HasURL(rawURL string) bool

NOTE: used only for starting-up proxies and assumes that proxy's listening on a single NIC (no multihoming)

func (*Snode) ID

func (d *Snode) ID() string

func (*Snode) InMaint

func (d *Snode) InMaint() bool

func (*Snode) InMaintOrDecomm

func (d *Snode) InMaintOrDecomm() bool

node flags

func (*Snode) InMaintPostReb

func (d *Snode) InMaintPostReb() bool

func (*Snode) Init

func (d *Snode) Init(id, daeType string)

init self

func (*Snode) InitNetNamer added in v1.3.24

func (d *Snode) InitNetNamer()

func (*Snode) IsIC

func (d *Snode) IsIC() bool

func (*Snode) IsProxy

func (d *Snode) IsProxy() bool

func (*Snode) IsTarget

func (d *Snode) IsTarget() bool

func (*Snode) Name

func (d *Snode) Name() string

func (*Snode) NetEq added in v1.3.23

func (d *Snode) NetEq(o *Snode) error

func (*Snode) SetName

func (d *Snode) SetName()

func (*Snode) StrURLs added in v1.3.23

func (d *Snode) StrURLs() string

func (*Snode) String

func (d *Snode) String() string

func (*Snode) StringEx

func (d *Snode) StringEx() string

func (*Snode) Type

func (d *Snode) Type() string

func (*Snode) URL

func (d *Snode) URL(network string) (u string)

func (*Snode) Validate

func (d *Snode) Validate() error

type Sowner

type Sowner interface {
	Get() (smap *Smap)
	Listeners() SmapListeners
}

interface to Get current (immutable, versioned) cluster map (Smap) instance

Jump to

Keyboard shortcuts

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