Documentation ¶
Index ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type MetricsCollector ¶
type MetricsCollector interface {
CollectDualStackMigrationMetrics(key types.NegSyncerKey, committedEndpoints map[negtypes.EndpointGroupInfo]types.NetworkEndpointSet, migrationCount int)
}
type Migrator ¶
type Migrator struct {
// contains filtered or unexported fields
}
Migrator exposes functions to control the migration of single-stack NEG endpoints to dual-stack NEG endpoints (and vice versa)
Single-stack vs Dual-stack ¶
A NEG endpoint is said to be single-stack if it just has an IPv4 or IPv6 address (but not both.)
A NEG endpoint is said to be dual-stack if it has both IPv4 and IPv6 address.
Migration endpoint ¶
An endpoint is said to be a migration-endpoint if its current state is single-stack but desired state is dual-stack (and vice versa.)
func NewMigrator ¶
func NewMigrator(enableDualStackNEG bool, syncer syncable, syncerKey types.NegSyncerKey, metricsCollector MetricsCollector, errorStateChecker errorStateChecker, logger klog.Logger) *Migrator
func (*Migrator) Continue ¶
Continue will unpause the migration. It expects an error as input which specifies the result of the NEG-endpoint detach operation. Depending on whether the detach operation passed or failed, the effect of unpause could be delayed:
- If the NEG detach operation failed, the migration will be unpaused immediately before Continue returns. This would allow any resyncs to reattempt the migration. The migrator itself doesn't trigger any sync in this case.
- If the NEG detach operation succeeded, a migrationWaitDuration timer will be started, which upon completion will unpause the migration and also trigger another sync. Continue will not keep the caller blocked for the completion of the timer. If Continue is invoked multiple times, only the first continue will trigger a resync.
func (*Migrator) Filter ¶
func (d *Migrator) Filter(addEndpoints, removeEndpoints, committedEndpoints map[negtypes.EndpointGroupInfo]types.NetworkEndpointSet) negtypes.EndpointGroupInfo
Filter will modify the `addEndpoints` and `removeEndpoints` in TWO DISTINCT ways:
- Remove all migration-endpoints, irrespective of whether the migrator is paused or not.
- If the migrator is not currently paused, it will also start the detachment of a subset of migration-endpoints from a single zone.
The returned EndpointGroup represents the zone and subnet of NEG for which detachment was started on. An empty subnet and zone value signifies that detachment was not started (which is the case when there were no migration-endpoints to begin with, or the migrator was paused.)
func (*Migrator) Pause ¶
func (d *Migrator) Pause()
Pause will prevent any subsequent Filter() invocations from starting detachment of migration-endpoints. Pause should be invoked before starting any NEG-endpoint detach operations that include migration-endpoints.
Invoking Pause on a migrator which is already paused will be a no-op.
Pause is usually paired with a Continue() invocation once the NEG-endpoint detach operation completes.