diskmanager

package
v0.3.4-rc.1 Latest Latest
Warning

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

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

Documentation

Index

Constants

View Source
const (
	ReservedPVCKey = "disk.hwameistor.io/pvc"
)

Variables

This section is empty.

Functions

This section is empty.

Types

type Disk

type Disk struct {
	// AttachNode represent where disk is attached
	AttachNode string `json:"attachNode,omitempty"`

	// Name unique identification for a disk
	Name string `json:"name,omitempty"`

	// DevPath
	DevPath string `json:"devPath,omitempty"`

	// Capacity
	Capacity int64 `json:"capacity,omitempty"`

	// DiskType SSD/HDD/NVME...
	DiskType string `json:"diskType,omitempty"`

	// Status
	Status DiskStatus `json:"status,omitempty"`
}

Disk all disk info about a disk

type DiskManager

type DiskManager interface {
	// GetClusterDisks list all disks by node
	GetClusterDisks() (map[string][]*Disk, error)

	// GetNodeDisks list all disk located on the node
	GetNodeDisks(node string) ([]*Disk, error)

	// ClaimDisk UpdateDiskStatus mark disk to TobeMount/Free/InUse... status
	ClaimDisk(name string) error

	// FilterFreeDisks filter matchable free disks
	FilterFreeDisks([]Disk) (bool, error)

	// ReserveDiskForVolume reserve a disk for the volume
	ReserveDiskForVolume(disk Disk, pvc string) error

	// UnReserveDiskForPVC update related disk to release status
	UnReserveDiskForPVC(pvc string) error

	// ReleaseDisk setup disk to release status
	ReleaseDisk(disk string) error

	// GetReservedDiskByPVC get disk reserved by the volume
	GetReservedDiskByPVC(pvc string) (*Disk, error)
}

DiskManager manage all disks in cluster The operation here needs to ensure thread safety

type DiskStatus

type DiskStatus = string
const (
	DiskStatusInUse     DiskStatus = "InUse"
	DiskStatusFree      DiskStatus = "Free"
	DiskStatusReserved  DiskStatus = "Reserved"
	DiskStatusUnclaimed DiskStatus = "Unclaimed"
	DiskStatusReleased  DiskStatus = "Released"
)

type LocalDiskNodesManager

type LocalDiskNodesManager struct {
	// GetClient for query LocalDiskNode resources from k8s
	GetClient func() (*localdisknode.Kubeclient, error)

	// DiskHandler manage LD resources in cluster
	DiskHandler *localdisk2.LocalDiskHandler
	// contains filtered or unexported fields
}

LocalDiskNodesManager manage all disks in the cluster by interacting with LocalDisk resources

func NewLocalDiskManager

func NewLocalDiskManager() *LocalDiskNodesManager

func (*LocalDiskNodesManager) ClaimDisk

func (ldn *LocalDiskNodesManager) ClaimDisk(name string) error

ClaimDisk claim a LocalDisk by update LocalDisk status to InUse

func (*LocalDiskNodesManager) FilterFreeDisks

func (ldn *LocalDiskNodesManager) FilterFreeDisks(reqDisks []Disk) (bool, error)

func (*LocalDiskNodesManager) GetClusterDisks

func (ldn *LocalDiskNodesManager) GetClusterDisks() (map[string][]*Disk, error)

GetClusterDisks Here is just a simple implementation

func (*LocalDiskNodesManager) GetNodeDisks

func (ldn *LocalDiskNodesManager) GetNodeDisks(node string) ([]*Disk, error)

GetNodeDisks get disks which attached on the node

func (*LocalDiskNodesManager) GetReservedDiskByPVC

func (ldn *LocalDiskNodesManager) GetReservedDiskByPVC(pvc string) (*Disk, error)

GetReservedDiskByPVC get disk by use pvc as a label selector Return err if reserved disk is more than 1

func (*LocalDiskNodesManager) ReleaseDisk

func (ldn *LocalDiskNodesManager) ReleaseDisk(disk string) error

func (*LocalDiskNodesManager) ReserveDiskForVolume

func (ldn *LocalDiskNodesManager) ReserveDiskForVolume(reqDisk Disk, pvc string) error

ReserveDiskForVolume reserve a LocalDisk by update LocalDisk status to Reserved and label this disk for the volume

func (*LocalDiskNodesManager) SelectDisk

func (ldn *LocalDiskNodesManager) SelectDisk(reqDisk Disk) (*Disk, error)

func (*LocalDiskNodesManager) UnReserveDiskForPVC

func (ldn *LocalDiskNodesManager) UnReserveDiskForPVC(pvc string) error

Jump to

Keyboard shortcuts

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