cluster

package
v0.27.2 Latest Latest
Warning

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

Go to latest
Published: Jun 30, 2023 License: Apache-2.0 Imports: 53 Imported by: 0

Documentation

Index

Constants

View Source
const (
	RookCephNS                        = "rook-ceph"
	CephClusterName                   = "rook-ceph"
	RookCephSharedFSMetadataPool      = "rook-shared-fs-metadata"
	RookCephSharedFSDataPool          = "rook-shared-fs-data0"
	CephDeviceHealthMetricsPool       = "device_health_metrics"
	CephDeviceHealthMetricsPoolQuincy = ".mgr"

	RookCephObjectStoreRootPool = ".rgw.root"

	RotateCertsLabel         = "kurl.sh/task"
	RotateCertsValue         = "rotate-certs"
	RotateCertsLastAttempted = "rotate-certs-last-attempted"

	TaskLabel                = "kurl.sh/task"
	UpdateInternalLBValue    = "update-internallb"
	SetKubeconfigServerValue = "set-kubeconfig-server"
)
View Source
const (
	DefaultContourNamespace          = "projectcontour"
	DefaultEnvoyPodsNotReadyDuration = 5 * time.Minute
)
View Source
const (
	DefaultEtcKubernetesDir = "/etc/kubernetes"
)
View Source
const (
	KotsadmRqliteHAReplicaCount = 3
)

Variables

View Source
var (
	RookCephObjectStoreMetadataPools = []string{

		"rgw.control",
		"rgw.meta",
		"rgw.log",
		"rgw.buckets.index",
		"rgw.buckets.non-ec",
	}
	RookCephObjectStoreMetadataPoolsQuincy = []string{

		"rgw.control",
		"rgw.meta",
		"rgw.log",
		"rgw.buckets.index",
		"rgw.buckets.non-ec",
		"rgw.otp",
	}
	RookCephObjectStoreDataPools = []string{
		"rgw.buckets.data",
	}
)
View Source
var CephPacific = semver.MustParse("16.2.0")
View Source
var CephQuincy = semver.MustParse("17.2.0")
View Source
var Rookv14 = semver.MustParse("1.4.0")
View Source
var Rookv19 = semver.MustParse("1.9.0")

Functions

This section is empty.

Types

type Controller

type Controller struct {
	Config       types.ControllerConfig
	SyncExecutor k8s.SyncExecutorInterface
	Log          *zap.SugaredLogger

	sync.Mutex
}

func NewController

func NewController(config types.ControllerConfig, log *zap.SugaredLogger) *Controller

func (*Controller) CephFilesystemOK

func (c *Controller) CephFilesystemOK(rookVersion semver.Version, name string) (bool, error)

func (*Controller) CheckRotateCertsDue added in v0.5.0

func (c *Controller) CheckRotateCertsDue(reset bool) (bool, error)

Any time this returns true it updates the last attempted timestamp

func (*Controller) ClearNode added in v0.3.0

func (c *Controller) ClearNode(ctx context.Context, nodeName string) error

ClearNode force deletes pods stuck in Terminating state on a single node.

func (*Controller) DoesHAMinioExist added in v0.26.0

func (c *Controller) DoesHAMinioExist(ctx context.Context, ns string) (bool, error)

func (*Controller) EnableHAKotsadm added in v0.25.0

func (c *Controller) EnableHAKotsadm(ctx context.Context, ns string) error

func (*Controller) EnsureCephCluster added in v0.27.2

func (c *Controller) EnsureCephCluster(ctx context.Context, rookStorageClassName string) error

func (*Controller) GetBlockPoolReplicationLevel added in v0.27.2

func (c *Controller) GetBlockPoolReplicationLevel(name string) (int, error)

getBlockPoolReplicationLevel returns ceph block pool replication size

func (*Controller) GetCephCluster added in v0.20.0

func (c *Controller) GetCephCluster(ctx context.Context) (*cephv1.CephCluster, error)

func (*Controller) GetRookVersion added in v0.23.1

func (c *Controller) GetRookVersion(ctx context.Context) (*semver.Version, error)

GetRookVersion gets the Rook version from the container image tag of the rook-ceph-operator deployment in the rook-ceph namespace.

func (*Controller) JSONPatchCephCluster added in v0.26.0

func (c *Controller) JSONPatchCephCluster(ctx context.Context, patches []k8s.JSONPatchOperation) (*cephv1.CephCluster, error)

JSONPatchCephCluster patches the "rook-ceph" CephCluster with the given JSON patches.

func (*Controller) MaybeRebalanceMinioServers added in v0.24.0

func (c *Controller) MaybeRebalanceMinioServers(ctx context.Context, ns string) error

MaybeRebalanceMinioServers first, check if minio is healthy. If it is not healthy, don't do anything. (this may require manual intervention, or may be resolved when nodes come back online) Then, check for pods that have been unschedulable for more than 5 minutes and delete the underlying volume + pod. This will allow the pod to be scheduled on a node that still exists and for data to be rebalanced there. After ensuring that there are as many running replicas as possible, we can rearrange replicas to maximize the number of nodes that can be lost before losing data. To do this, first check if more than ceil(replicas/nodes) replicas exist on one node. If it does, see if we can reschedule one of those replicas safely. If such a node does not exist, instead look for nodes with less than floor(replicas/nodes) replicas, and if it exists reschedule a replica from a node with ceil(replicas/nodes).

func (*Controller) MigrateMinioData added in v0.24.0

func (c *Controller) MigrateMinioData(ctx context.Context, utilImage string, ns string) error

MigrateMinioData moves data from the un-replicated minio deployment to the HA minio statefulset, using kurl's sync-object-store.

func (*Controller) PatchFilesystemMDSPlacementMultinode added in v0.20.0

func (c *Controller) PatchFilesystemMDSPlacementMultinode(name string, numNodes int) error

PatchFilesystemMDSPlacementMultinode will change the patched preferredDuringSchedulingIgnoredDuringExecution podAntiAffinity rule back to the more correct requiredDuringSchedulingIgnoredDuringExecution equivalent if the number of nodes is greater than one.

func (*Controller) PrioritizeRook added in v0.9.0

func (c *Controller) PrioritizeRook() error

func (*Controller) PurgeNode

func (c *Controller) PurgeNode(ctx context.Context, name string, rook bool, rookVersion *semver.Version) error

PurgeNode cleans up a lost node.

func (*Controller) ReconcileInternalLB added in v0.11.0

func (c *Controller) ReconcileInternalLB(ctx context.Context, nodes []corev1.Node) error

func (*Controller) ReconcileMgrCount added in v0.23.0

func (c *Controller) ReconcileMgrCount(ctx context.Context, rookVersion semver.Version, nodeCount int) error

ReconcileMgrCount ensures the CephCluster has the desired number of mgrs. A single mgr for clusters with 1 node, and 2 mgrs for all other clusters.

func (*Controller) ReconcileMonCount added in v0.4.0

func (c *Controller) ReconcileMonCount(ctx context.Context, nodeCount int) error

ReconcileMonCount ensures the CephCluster has the desired number of mons. A single mon for clusters with 1 or 2 nodes, and 3 mons for all other clusters.

func (*Controller) RestartFailedEnvoyPods added in v0.21.0

func (c *Controller) RestartFailedEnvoyPods(ctx context.Context) error

RestartFailedEnvoyPods will forcefully delete envoy pods that have fallen into an unrecoverable state for at least EnvoyPodsNotReadyDuration.

func (*Controller) RotateAllCerts added in v0.5.0

func (c *Controller) RotateAllCerts(ctx context.Context) error

This launches a pod on each primary to mount /etc/kubernetes and rotate the certs. It leaves the pods up if any fail.

func (*Controller) RotateContourCerts added in v0.15.0

func (c *Controller) RotateContourCerts() error

func (*Controller) RotateKurlProxyCert added in v0.7.0

func (c *Controller) RotateKurlProxyCert() error

func (*Controller) RotateRegistryCert added in v0.5.0

func (c *Controller) RotateRegistryCert() error

func (*Controller) ScaleKotsadmRqlite added in v0.25.0

func (c *Controller) ScaleKotsadmRqlite(ctx context.Context, ns string, desiredScale int32) error

func (*Controller) ScaleMinioStatefulset added in v0.24.0

func (c *Controller) ScaleMinioStatefulset(ctx context.Context, ns string) error

func (*Controller) SetBlockPoolReplication added in v0.2.4

func (c *Controller) SetBlockPoolReplication(rookVersion semver.Version, cephVersion *semver.Version, name string, level int, doFullReconcile bool) (bool, error)

SetBlockPoolReplicationLevel ignores NotFound errors.

func (*Controller) SetCephCSIResources added in v0.23.0

func (c *Controller) SetCephCSIResources(ctx context.Context, rookVersion semver.Version, nodeCount int) (bool, error)

SetCephCSIResources will set CSI provisioner and plugin resources to their recommendations once the cluster has enough capacity at 3 nodes.

func (*Controller) SetDeviceHealthMetricsReplication added in v0.4.0

func (c *Controller) SetDeviceHealthMetricsReplication(rookVersion semver.Version, cephVersion *semver.Version, cephBlockPoolName string, level int, doFullReconcile bool) (bool, error)

func (*Controller) SetFilesystemReplication

func (c *Controller) SetFilesystemReplication(rookVersion semver.Version, cephVersion *semver.Version, name string, level int, doFullReconcile bool) (bool, error)

SetSharedFilesystemReplication will set the shared filesystem replication to the number of OSDs in the cluster. Returns true if the resource was updated.

func (*Controller) SetKubeconfigServer added in v0.11.0

func (c *Controller) SetKubeconfigServer(ctx context.Context, node corev1.Node, server string) error

func (*Controller) SetObjectStoreReplication

func (c *Controller) SetObjectStoreReplication(rookVersion semver.Version, cephVersion *semver.Version, name string, level int, doFullReconcile bool) (bool, error)

SetObjectStoreReplication will set the object store pool replication to the number of OSDs in the cluster. Returns true if the resource was updated.

func (*Controller) UpdateInternalLB added in v0.11.0

func (c *Controller) UpdateInternalLB(ctx context.Context, nodes []corev1.Node) error

Update /etc/haproxy/haproxy.cfg and /etc/kubernetes/manifests/haproxy.yaml on all nodes.

func (*Controller) UpdateKubeletClientCertSecret added in v0.7.0

func (c *Controller) UpdateKubeletClientCertSecret() error

Copies apiserver-kubelet-client.crt into secret used by kotsadm to collect metrics

func (*Controller) UseNodesForStorage

func (c *Controller) UseNodesForStorage(ctx context.Context, rookVersion semver.Version, cluster *cephv1.CephCluster, names []string, manageNodes bool) (int, error)

returns the number of nodes used for storage, which may be higher than the number of names passed in if a node is currently not ready but has not been purged

func (*Controller) WaitCephFilesystem

func (c *Controller) WaitCephFilesystem(ctx context.Context, rookVersion semver.Version, name string) error

Directories

Path Synopsis

Jump to

Keyboard shortcuts

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