config

package
v0.0.0-...-ac6a2c4 Latest Latest
Warning

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

Go to latest
Published: Oct 7, 2019 License: Apache-2.0 Imports: 10 Imported by: 0

Documentation

Index

Constants

View Source
const (
	// Batch is the batch strategy
	Batch = PlacementStrategy("batch")
	// Mimir is the Mimir strategy
	Mimir = PlacementStrategy("mimir")
)

Variables

This section is empty.

Functions

This section is empty.

Types

type Config

type Config struct {
	Metrics      metrics.Config        `yaml:"metrics"`
	Placement    PlacementConfig       `yaml:"placement"`
	Election     leader.ElectionConfig `yaml:"election"`
	Mesos        mesos.Config          `yaml:"mesos"`
	Health       health.Config         `yaml:"health"`
	Storage      config.Config         `yaml:"storage"`
	SentryConfig logging.SentryConfig  `yaml:"sentry"`
	Auth         auth.Config           `yaml:"auth"`
}

Config holds all configs to run a placement engine.

type MaxDurationsConfig

type MaxDurationsConfig struct {
	Unknown   time.Duration `yaml:"unknown"`
	Batch     time.Duration `yaml:"batch"`
	Stateless time.Duration `yaml:"stateless"`
	Daemon    time.Duration `yaml:"daemon"`
	Stateful  time.Duration `yaml:"stateful"`
}

MaxDurationsConfig is the config the maximal placement duration of a task before it should be launched.

func (MaxDurationsConfig) Value

Value returns the value of the config for the given task type.

type MaxRoundsConfig

type MaxRoundsConfig struct {
	Unknown   int `yaml:"unknown"`
	Batch     int `yaml:"batch"`
	Stateless int `yaml:"stateless"`
	Daemon    int `yaml:"daemon"`
	Stateful  int `yaml:"stateful"`
}

MaxRoundsConfig is the config of the maximal number of successful rounds that a task should go through before being launched.

func (MaxRoundsConfig) Value

func (c MaxRoundsConfig) Value(t resmgr.TaskType) int

Value returns the value of the config for the given task type.

type PlacementConfig

type PlacementConfig struct {
	// HTTP port which hostmgr is listening on
	HTTPPort int `yaml:"http_port"`

	// GRPC port which hostmgr is listening on
	GRPCPort int `yaml:"grpc_port"`

	// TaskDequeuePeriod is the period at which tasks are dequeued to be placed.
	TaskDequeuePeriod time.Duration `yaml:"task_dequeue_period"`

	// TaskDequeueLimit is the max number of tasks to dequeue in a request
	TaskDequeueLimit int `yaml:"task_dequeue_limit"`

	// TaskDequeueTimeOut is the timeout for the ready queue in resmgr
	TaskDequeueTimeOut int `yaml:"task_dequeue_timeout"`

	// OfferDequeueLimit is the max Number of HostOffers to dequeue in
	// a request
	OfferDequeueLimit int `yaml:"offer_dequeue_limit"`

	// MaxPlacementDuration is the max time duration to place tasks for a task
	// group.
	MaxPlacementDuration time.Duration `yaml:"max_placement_duration"`

	// The task type that the engine is responsible for.
	TaskType resmgr.TaskType `yaml:"task_type"`

	// If this is true the engine will fetch all tasks running on an offer
	// of the same task type as the task type that the coordinator is
	// responsible for.
	FetchOfferTasks bool `yaml:"fetch_offer_tasks"`

	// Strategy is the placement strategy that the engine should use.
	Strategy PlacementStrategy `yaml:"strategy"`

	// Concurrency is the maximal worker concurrency in the engine.
	Concurrency int `yaml:"concurrency"`

	// MaxRounds is maximal number of successful placements that a task can
	// have before it finally gets launched on the current best host for
	// the task. If max rounds for a task type is 0 it means there is no
	// limit on the maximal number of successful placement rounds it can go
	// through.
	MaxRounds MaxRoundsConfig `yaml:"max_rounds"`

	// MaxDurations is maximal time that a task can use being placed before
	// it finally gets launched on the current best host for the task.
	MaxDurations MaxDurationsConfig `yaml:"max_durations"`

	// MaxDesiredHostPlacementDuration is the max time duration to try to
	// place a task on the desired host.
	MaxDesiredHostPlacementDuration time.Duration `yaml:"max_desired_host_placement_duration"`

	// HostManagerAPIVersion is the API version that the placement engine
	// should use to talk to host manager.
	HostManagerAPIVersion api.Version `yaml:"hostmgr_api_version"`

	// UseHostPool is the config switch to use host pool logic in placement engine
	UseHostPool bool `yaml:"use_host_pool"`
}

PlacementConfig is Placement engine specific config

func (*PlacementConfig) Copy

func (config *PlacementConfig) Copy() *PlacementConfig

Copy returns a deep copy of the config.

type PlacementStrategy

type PlacementStrategy string

PlacementStrategy determines the placement strategy that the placement engine should use.

Jump to

Keyboard shortcuts

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