migrationtarget

package
v0.0.0-...-3d086f3 Latest Latest
Warning

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

Go to latest
Published: Apr 18, 2024 License: AGPL-3.0 Imports: 20 Imported by: 1

Documentation

Overview

Package migrationtarget defines the API facade for use by the migration master worker when interacting with the target controller during a migration.

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func Register

func Register(requiredMigrationFacadeVersions facades.FacadeVersions) func(registry facade.FacadeRegistry)

Register is called to expose a package of facades onto a given registry.

Types

type API

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

API implements the API required for the model migration master worker when communicating with the target controller.

func NewAPI

func NewAPI(
	ctx facade.Context,
	getEnviron stateenvirons.NewEnvironFunc,
	getCAASBroker stateenvirons.NewCAASBrokerFunc,
	requiredMigrationFacadeVersions facades.FacadeVersions,
) (*API, error)

NewAPI returns a new APIV1. Accepts a NewEnvironFunc and context.ProviderCallContext for testing purposes.

func (*API) Abort

func (api *API) Abort(args params.ModelArgs) error

Abort removes the specified model from the database. It is an error to attempt to Abort a model that has a migration mode other than importing.

func (*API) Activate

func (api *API) Activate(args params.ActivateModelArgs) error

Activate sets the migration mode of the model to "none", meaning it is ready for use. It is an error to attempt to Abort a model that has a migration mode other than importing. It also adds any required external controller records for those controllers hosting offers used by the model.

func (*API) AdoptResources

func (api *API) AdoptResources(args params.AdoptResourcesArgs) error

AdoptResources asks the cloud provider to update the controller tags for a model's resources. This prevents the resources from being destroyed if the source controller is destroyed after the model is migrated away.

func (*API) CACert

func (api *API) CACert() (params.BytesResult, error)

CACert returns the certificate used to validate the state connection.

func (*API) CheckMachines

func (api *API) CheckMachines(args params.ModelArgs) (params.ErrorResults, error)

CheckMachines compares the machines in state with the ones reported by the provider and reports any discrepancies.

func (*API) Import

func (api *API) Import(serialized params.SerializedModel) error

Import takes a serialized Juju model, deserializes it, and recreates it in the receiving controller.

func (*API) LatestLogTime

func (api *API) LatestLogTime(args params.ModelArgs) (time.Time, error)

LatestLogTime returns the time of the most recent log record received by the logtransfer endpoint. This can be used as the start point for streaming logs from the source if the transfer was interrupted.

For performance reasons, not every time is tracked, so if the target controller died during the transfer the latest log time might be up to 2 minutes earlier. If the transfer was interrupted in some other way (like the source controller going away or a network partition) the time will be up-to-date.

Log messages are assumed to be sent in time order (which is how debug-log emits them). If that isn't the case then this mechanism can't be used to avoid duplicates when logtransfer is restarted.

Returns the zero time if no logs have been transferred.

func (*API) Prechecks

func (api *API) Prechecks(model params.MigrationModelInfo) error

Prechecks ensure that the target controller is ready to accept a model migration.

type APIV1

type APIV1 struct {
	*API
}

APIV1 implements the V1 version of the API facade.

func (*APIV1) Activate

func (api *APIV1) Activate(args params.ModelArgs) error

Activate sets the migration mode of the model to "none", meaning it is ready for use. It is an error to attempt to Abort a model that has a migration mode other than importing.

type APIV2

type APIV2 struct {
	*APIV1
}

APIV2 implements the V2 version of the API facade.

Jump to

Keyboard shortcuts

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