Documentation ¶
Index ¶
- Constants
- func CheckVacateFailures(failures *models.MoveClustersDetails, filter []string, allocatorID string) error
- func ComputeVacateRequest(pr *models.MoveClustersDetails, resources, to []string, ...) *models.MoveClustersRequest
- func DeleteAllocatorMetadataItem(params MetadataDeleteParams) error
- func FilterByTag(tags map[string]string, allocators []*models.AllocatorInfo) []*models.AllocatorInfo
- func FilterConnectedOrWithInstances(allocators []*models.AllocatorInfo) []*models.AllocatorInfo
- func Get(params GetParams) (*models.AllocatorInfo, error)
- func GetAllocatorMetadata(params MetadataGetParams) ([]*models.MetadataItem, error)
- func List(params ListParams) (*models.AllocatorOverview, error)
- func Search(params SearchParams) (*models.AllocatorOverview, error)
- func SetAllocatorMetadataItem(params MetadataSetParams) error
- func StartMaintenance(params MaintenanceParams) error
- func StopMaintenance(params MaintenanceParams) error
- func Vacate(params *VacateParams) error
- func VacateCluster(params *VacateClusterParams) error
- func VacateClusterInPool(p pool.Validator) error
- type GetParams
- type ListParams
- type MaintenanceParams
- type MetadataDeleteParams
- type MetadataGetParams
- type MetadataSetParams
- type PlanOverrides
- type SearchParams
- type VacateClusterParams
- type VacateError
- type VacateParams
Constants ¶
const (
// PlanPendingMessage is used to discard
PlanPendingMessage = "There is a plan still pending, cancel that or wait for it to complete before restarting"
)
const (
// UnhealthyQuery is used to obtain the list of unhealthy allocators.
UnhealthyQuery = "status.connected:false AND _exists_:instances"
)
Variables ¶
This section is empty.
Functions ¶
func CheckVacateFailures ¶
func CheckVacateFailures(failures *models.MoveClustersDetails, filter []string, allocatorID string) error
CheckVacateFailures iterates over the list of failures returning a multierror of VacateError if any of failures are found.
nolint because of the complexity score here
func ComputeVacateRequest ¶
func ComputeVacateRequest(pr *models.MoveClustersDetails, resources, to []string, overrides PlanOverrides) *models.MoveClustersRequest
ComputeVacateRequest filters the tentative resources that would be moved and filters those by ID if it's specified, also setting any preferred allocators if that is sent. Any resource plan overrides will be set in this function. nolint due to complexity
func DeleteAllocatorMetadataItem ¶
func DeleteAllocatorMetadataItem(params MetadataDeleteParams) error
DeleteAllocatorMetadataItem delete a single metadata item to a given allocators metadata
func FilterByTag ¶
func FilterByTag(tags map[string]string, allocators []*models.AllocatorInfo) []*models.AllocatorInfo
FilterByTag filters a list of allocators based on metadata tags and returns a new matched list
func FilterConnectedOrWithInstances ¶
func FilterConnectedOrWithInstances(allocators []*models.AllocatorInfo) []*models.AllocatorInfo
FilterConnectedOrWithInstances filters a list of allocators and returns only the connected ones or those who have more than one instance
func Get ¶
func Get(params GetParams) (*models.AllocatorInfo, error)
Get obtains an allocator from an ID
func GetAllocatorMetadata ¶
func GetAllocatorMetadata(params MetadataGetParams) ([]*models.MetadataItem, error)
GetAllocatorMetadata Retrieves the metadata for a given allocator
func List ¶
func List(params ListParams) (*models.AllocatorOverview, error)
List obtains the full list of allocators
func Search ¶
func Search(params SearchParams) (*models.AllocatorOverview, error)
Search searches all the allocators using Query DSL
func SetAllocatorMetadataItem ¶
func SetAllocatorMetadataItem(params MetadataSetParams) error
SetAllocatorMetadataItem sets a single metadata item to a given allocators metadata
func StartMaintenance ¶
func StartMaintenance(params MaintenanceParams) error
StartMaintenance sets an allocator to maintenance mode
func StopMaintenance ¶
func StopMaintenance(params MaintenanceParams) error
StopMaintenance unsets an allocator to maintenance mode
func Vacate ¶
func Vacate(params *VacateParams) error
Vacate drains allocated resource instances away from the allocator list either to a specific allocator list or we let the constructor decide if that is empty. If resources is set, it will only move the instances that are part of those IDs. If kind is specified, it will only move the resources that match that kind. If none is specified it will add all of the resources in the allocator. The maximum concurrent moves is controlled by the Concurrency parameter.
func VacateCluster ¶
func VacateCluster(params *VacateClusterParams) error
VacateCluster moves a resource node off an allocator.
func VacateClusterInPool ¶
VacateClusterInPool vacates a resource from an allocator, complying with the pool.RunFunc signature.
Types ¶
type ListParams ¶
type ListParams struct { // Required API instance. *api.API // Required region on which to perform the allocator list. Region string // Optional Elasticsearch search query. Query string // Optional filter tags with expected format: key:value slice. i.e. // [key:val, key:value]. FilterTags string // Optional toggle to show all allocators (By default connected:false) are // omitted. ShowAll bool // Optional number of allocators to return (Defaults to 100). Size int64 }
ListParams is used to list allocators
func (ListParams) Validate ¶
func (params ListParams) Validate() error
Validate ensures that the parameters are correct
type MaintenanceParams ¶
MaintenanceParams is used to set / unset maintenance mode
func (MaintenanceParams) Validate ¶
func (params MaintenanceParams) Validate() error
Validate ensures that the parameters are correct
type MetadataDeleteParams ¶
MetadataDeleteParams is used to delete a single metadata key
func (MetadataDeleteParams) Validate ¶
func (params MetadataDeleteParams) Validate() error
Validate ensures that the parameters are correct
type MetadataGetParams ¶
MetadataGetParams is used to retrieve allocator metadata
func (MetadataGetParams) Validate ¶
func (params MetadataGetParams) Validate() error
Validate ensures that the parameters are correct
type MetadataSetParams ¶
MetadataSetParams is is used to set a single allocator metadata key
func (MetadataSetParams) Validate ¶
func (params MetadataSetParams) Validate() error
Validate ensures that the parameters are correct
type PlanOverrides ¶
type PlanOverrides struct { // SkipSnapshot overwrites the Transient part of an Elastisearch vacate. SkipSnapshot *bool SkipDataMigration *bool OverrideFailsafe *bool }
PlanOverrides is used to override any API value that is returned by default with the specified value.
type SearchParams ¶
type SearchParams struct { Request models.SearchRequest *api.API Region string }
SearchParams contains parameters used to search allocator's data using Query DSL
func (SearchParams) Validate ¶
func (params SearchParams) Validate() error
Validate validates SearchParams
type VacateClusterParams ¶
type VacateClusterParams struct { PreferredAllocators []string ClusterFilter []string // Plan body overrides to place in all of the vacate clusters. PlanOverrides Region string ID string // allocatorID ClusterID string Kind string *api.API TrackFrequency time.Duration AllocatorDown *bool MoveOnly *bool Output *output.Device OutputFormat string MaxPollRetries uint8 SkipTracking bool }
VacateClusterParams is used by VacateCluster to move a cluster node from an allocator.
func (VacateClusterParams) Validate ¶
func (params VacateClusterParams) Validate() error
Validate validates the parameters
type VacateError ¶
type VacateError struct { AllocatorID string `json:"allocator_id,omitempty"` ResourceID string `json:"resource_id,omitempty"` Kind string `json:"kind,omitempty"` Ctx string `json:"context,omitempty"` Err error `json:"error,omitempty"` }
VacateError wraps an error and enriches it with some fields to be able to have a consistent output (resourcePrefixErrFmt). Or by being serialized to JSON by using `multierror.WithFormat`.
func (VacateError) Error ¶
func (e VacateError) Error() string
func (VacateError) MarshalJSON ¶
func (e VacateError) MarshalJSON() ([]byte, error)
MarshalJSON Implements the json.Marshaler interface to be able to modify the error and format it in JSON.w
type VacateParams ¶
type VacateParams struct { *api.API Region string // List of allocators that will be marked to be vacated. Allocators []string // List of allocators to be used as potential targets. PreferredAllocators []string // Can specify a list of cluster IDs that will be moved // of N numbers of allocators. ClusterFilter []string // If specified it will only move clusters that match the kind // (elasticsearch, kibana). KindFilter string // Maximum number of concurrent cluster moves at any time. Concurrency uint16 // Output device where the progress will be sent. Output *output.Device // OutputFormat to use OutputFormat string // Maximum number of errors to allow the plan status poller to tolerate. MaxPollRetries uint8 // Poll frequency TrackFrequency time.Duration // Optional value to be set to the pool on construction. PoolTimeout pool.Timeout // Optional value to be set to override the default autodiscovery of an // allocator's health. This can only be used when a single allocator is // specified. AllocatorDown *bool // Optional value to be set to keep the cluster in its current -possibly broken- state and just does the // bare minimum to move the requested instances across to another allocator. MoveOnly *bool // SkipTracking skips displaying and waiting for the individual vacates to complete. // Setting it to true will render the concurrency flag pretty much ineffective since // the vacate action is asynchronous and the only thing keeping the working items in // the pool is the tracking function call which synchronously waits until the vacate // has effectively finished. SkipTracking bool // Plan body overrides to place in all of the vacate clusters. PlanOverrides }
VacateParams used to vacate N allocators or clusters. nolint
func (VacateParams) Validate ¶
func (params VacateParams) Validate() error
Validate validates the parameters