Documentation ¶
Index ¶
- Constants
- type CapacityTargetSpecPatch
- type Controller
- type Extra
- type Pipeline
- type PipelineContinuation
- type PipelineStep
- type ReleaseStrategyStateTransition
- type ReleaseStrategyStatusPatch
- type Scheduler
- func (s *Scheduler) ChooseClusters(rel *shipper.Release) (*shipper.Release, error)
- func (s *Scheduler) CreateOrUpdateCapacityTarget(rel *shipper.Release, totalReplicaCount int32) (*shipper.CapacityTarget, error)
- func (s *Scheduler) CreateOrUpdateInstallationTarget(rel *shipper.Release) (*shipper.InstallationTarget, error)
- func (s *Scheduler) CreateOrUpdateTrafficTarget(rel *shipper.Release) (*shipper.TrafficTarget, error)
- func (s *Scheduler) ScheduleRelease(rel *shipper.Release) (*releaseInfo, error)
- type StrategyExecutor
- type StrategyPatch
- type TrafficTargetSpecPatch
Constants ¶
View Source
const (
AgentName = "release-controller"
)
View Source
const (
ClustersNotReady = "ClustersNotReady"
)
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type CapacityTargetSpecPatch ¶ added in v0.8.0
type CapacityTargetSpecPatch struct { Name string NewSpec *shipper.CapacityTargetSpec }
func (*CapacityTargetSpecPatch) Alters ¶ added in v0.8.0
func (p *CapacityTargetSpecPatch) Alters(o interface{}) bool
func (*CapacityTargetSpecPatch) IsEmpty ¶ added in v0.8.0
func (p *CapacityTargetSpecPatch) IsEmpty() bool
func (*CapacityTargetSpecPatch) PatchSpec ¶ added in v0.8.0
func (p *CapacityTargetSpecPatch) PatchSpec() (string, schema.GroupVersionKind, []byte)
type Controller ¶
type Controller struct {
// contains filtered or unexported fields
}
Controller is a Kubernetes controller whose role is to pick up a newly created release and progress it forward by scheduling the release on a set of selected clusters, creating a set of associated objects and executing the strategy.
func NewController ¶
func NewController( clientset shipperclient.Interface, informerFactory shipperinformers.SharedInformerFactory, chartFetcher shipperrepo.ChartFetcher, recorder record.EventRecorder, ) *Controller
func (*Controller) Run ¶
func (c *Controller) Run(threadiness int, stopCh <-chan struct{})
Run starts Release Controller workers and waits until stopCh is closed.
type Pipeline ¶ added in v0.8.0
type Pipeline []PipelineStep
func NewPipeline ¶ added in v0.8.0
func NewPipeline() *Pipeline
func (*Pipeline) Enqueue ¶ added in v0.8.0
func (p *Pipeline) Enqueue(step PipelineStep)
func (*Pipeline) Process ¶ added in v0.8.0
func (p *Pipeline) Process(strategy *shipper.RolloutStrategy, step int32, extra Extra, cond conditions.StrategyConditionsMap) (bool, []StrategyPatch, []ReleaseStrategyStateTransition)
type PipelineContinuation ¶ added in v0.8.0
type PipelineContinuation bool
const ( PipelineBreak PipelineContinuation = false PipelineContinue = true )
type PipelineStep ¶ added in v0.8.0
type PipelineStep func(*shipper.RolloutStrategy, int32, Extra, conditions.StrategyConditionsMap) (PipelineContinuation, []StrategyPatch, []ReleaseStrategyStateTransition)
type ReleaseStrategyStateTransition ¶
type ReleaseStrategyStateTransition struct { State string Previous shipper.StrategyState New shipper.StrategyState }
type ReleaseStrategyStatusPatch ¶ added in v0.8.0
type ReleaseStrategyStatusPatch struct { Name string NewStrategyStatus *shipper.ReleaseStrategyStatus }
func (*ReleaseStrategyStatusPatch) Alters ¶ added in v0.8.0
func (p *ReleaseStrategyStatusPatch) Alters(o interface{}) bool
func (*ReleaseStrategyStatusPatch) IsEmpty ¶ added in v0.8.0
func (p *ReleaseStrategyStatusPatch) IsEmpty() bool
func (*ReleaseStrategyStatusPatch) PatchSpec ¶ added in v0.8.0
func (p *ReleaseStrategyStatusPatch) PatchSpec() (string, schema.GroupVersionKind, []byte)
type Scheduler ¶
type Scheduler struct {
// contains filtered or unexported fields
}
func NewScheduler ¶
func NewScheduler( clientset shipperclientset.Interface, clusterLister listers.ClusterLister, installationTargerLister listers.InstallationTargetLister, capacityTargetLister listers.CapacityTargetLister, trafficTargetLister listers.TrafficTargetLister, rolloutBlockLister listers.RolloutBlockLister, chartFetcher shipperrepo.ChartFetcher, recorder record.EventRecorder, ) *Scheduler
func (*Scheduler) ChooseClusters ¶
func (*Scheduler) CreateOrUpdateCapacityTarget ¶
func (*Scheduler) CreateOrUpdateInstallationTarget ¶
func (*Scheduler) CreateOrUpdateTrafficTarget ¶
type StrategyExecutor ¶ added in v0.8.0
type StrategyExecutor struct {
// contains filtered or unexported fields
}
func NewStrategyExecutor ¶ added in v0.8.0
func NewStrategyExecutor(strategy *shipper.RolloutStrategy, step int32) *StrategyExecutor
func (*StrategyExecutor) Execute ¶ added in v0.8.0
func (e *StrategyExecutor) Execute(prev, curr, succ *releaseInfo) (bool, []StrategyPatch, []ReleaseStrategyStateTransition)
type StrategyPatch ¶ added in v0.8.0
type TrafficTargetSpecPatch ¶ added in v0.8.0
type TrafficTargetSpecPatch struct { Name string NewSpec *shipper.TrafficTargetSpec }
func (*TrafficTargetSpecPatch) Alters ¶ added in v0.8.0
func (p *TrafficTargetSpecPatch) Alters(o interface{}) bool
func (*TrafficTargetSpecPatch) IsEmpty ¶ added in v0.8.0
func (p *TrafficTargetSpecPatch) IsEmpty() bool
func (*TrafficTargetSpecPatch) PatchSpec ¶ added in v0.8.0
func (p *TrafficTargetSpecPatch) PatchSpec() (string, schema.GroupVersionKind, []byte)
Click to show internal directories.
Click to hide internal directories.