clusteraffinity

package
v0.6.6 Latest Latest
Warning

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

Go to latest
Published: Jul 31, 2023 License: MIT Imports: 7 Imported by: 0

Documentation

Overview

Package clusteraffinity features a scheduler plugin that enforces cluster affinity (if any) defined on a CRP.

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type AffinityTerms

type AffinityTerms []affinityTerm

AffinityTerms is a "processed" representation of []ClusterSelectorTerms. The terms are `ORed`.

func NewAffinityTerms

func NewAffinityTerms(terms []fleetv1beta1.ClusterSelectorTerm) (AffinityTerms, error)

NewAffinityTerms returns the list of processed affinity terms.

func (AffinityTerms) Matches

func (at AffinityTerms) Matches(cluster *fleetv1beta1.MemberCluster) bool

Matches returns true if the cluster matches one of the terms.

type Option

type Option func(*clusterAffinityPluginOptions)

func WithName

func WithName(name string) Option

WithName sets the name of the plugin.

type Plugin

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

Plugin is the scheduler plugin that enforces the cluster affinity (if any) defined on a CRP.

func New

func New(opts ...Option) Plugin

New returns a new Plugin.

func (*Plugin) Filter

Filter allows the plugin to connect to the Filter extension point in the scheduling framework.

func (*Plugin) Name

func (p *Plugin) Name() string

Name returns the name of the plugin.

func (*Plugin) PreFilter

PreFilter allows the plugin to connect to the PreFilter extension point in the scheduling framework.

Note that the scheduler will not run this extension point in parallel.

func (*Plugin) PreScore

PreScore allows the plugin to connect to the PreScore extension point in the scheduling framework.

func (*Plugin) Score

Score allows the plugin to connect to the Score extension point in the scheduling framework.

func (*Plugin) SetUpWithFramework

func (p *Plugin) SetUpWithFramework(handle framework.Handle)

SetUpWithFramework sets up this plugin with a scheduler framework.

type PreferredAffinityTerms

type PreferredAffinityTerms []preferredAffinityTerm

PreferredAffinityTerms is a "processed" representation of []PreferredClusterSelector.

func NewPreferredAffinityTerms

func NewPreferredAffinityTerms(terms []fleetv1beta1.PreferredClusterSelector) (PreferredAffinityTerms, error)

NewPreferredAffinityTerms returns the list of processed preferred affinity terms.

func (PreferredAffinityTerms) Score

Score returns a score for a cluster: the sum of the weights of the terms that match the cluster.

Jump to

Keyboard shortcuts

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