driver

package
v1.29.0-alpha.182 Latest Latest
Warning

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

Go to latest
Published: Nov 30, 2023 License: MIT Imports: 22 Imported by: 0

Documentation

Overview

Package driver xxx

Index

Constants

View Source
const (
	// SlaveUri xxx
	SlaveUri = "/api/v1/executor"

	// KeepAliveConn xxx
	KeepAliveConn = true
	// NotKeepAliveConn xxx
	NotKeepAliveConn = false
)

Variables

This section is empty.

Functions

func NewReader

func NewReader(r io.Reader) io.Reader

NewReader returns an io.Reader that unpacks the data read from r out of RecordIO framing before returning it.

Types

type DriverEnv

type DriverEnv struct {
	MesosSlavePID            string // agent slave pid
	MesosSlaveID             string // agent slave uniq id
	MesosAgentEndpoint       string // agent ip:port endpoint to connect to the agent
	MesosFrameworkID         string // frameworkid from agent
	MesosExecutorID          string // exector id from agent
	SSLEnabled               bool   // true is agent enable https
	MesosSandBox             string // Path to the mapped sandbox inside of the container
	MesosCheckpoint          bool   // If set to true, denotes that framework has checkpointing enabled
	MesosRecoveryTimeout     int    // The total duration that the executor should spend retrying before shutting it self down when it is disconnected from the agent
	MesosSubscriptionBackoff int    // The maximum backoff duration between two retries when disconnected
	MesosShutdownGracePeriod int    // Amount of time the agent would wait for an executor to shut down (e.g., 60secs, 3mins etc.) after sending a SHUTDOWN event
}

DriverEnv The following environment variables are set by the agent that can be

used by the executor upon startup:

MESOS_FRAMEWORK_ID: FrameworkID of the scheduler needed as part of the SUBSCRIBE call. MESOS_EXECUTOR_ID: ExecutorID of the executor needed as part of the SUBSCRIBE call. MESOS_DIRECTORY: Path to the working directory for the executor on the host filesystem(deprecated). MESOS_SANDBOX: Path to the mapped sandbox inside of the container (determined by the

agent flag sandbox_directory) for either mesos container with image or docker container.
For the case of command task without image specified, it is the path to the sandbox
on the host filesystem, which is identical to MESOS_DIRECTORY. MESOS_DIRECTORY
is always the sandbox on the host filesystem.

MESOS_AGENT_ENDPOINT: agent endpoint i.e. ip:port to be used by the executor to connect

to the agent.

MESOS_CHECKPOINT: If set to true, denotes that framework has checkpointing enabled. MESOS_EXECUTOR_SHUTDOWN_GRACE_PERIOD: Amount of time the agent would wait for an

executor to shut down (e.g., 60secs, 3mins etc.) after sending a SHUTDOWN event.

If MESOS_CHECKPOINT is set i.e. when framework checkpointing is enabled, the following

additional variables are also set that can be used by the executor for retrying
upon a disconnection with the agent:

MESOS_RECOVERY_TIMEOUT: The total duration that the executor should spend retrying

before shutting itself down when it is disconnected from the agent (e.g., 15mins,
5secs etc.). This is configurable at agent startup via the flag --recovery_timeout.

MESOS_SUBSCRIPTION_BACKOFF_MAX: The maximum backoff duration to be used by the executor

between two retries when disconnected (e.g., 250ms, 1mins etc.). This is configurable
at agent startup via the flag --executor_reregistration_timeout.

type ExecutorDriver

type ExecutorDriver struct {
	sync.RWMutex
	// contains filtered or unexported fields
}

ExecutorDriver BCS implementation for ExecutorDriver

func NewExecutorDriver

func NewExecutorDriver(cxt context.Context, bcsExec executor.Executor) (*ExecutorDriver, error)

NewExecutorDriver xxx

func (*ExecutorDriver) Start

func (driver *ExecutorDriver) Start()

Start xxx

func (*ExecutorDriver) UpdateTaskStatus

func (driver *ExecutorDriver) UpdateTaskStatus(status *mesos.TaskStatus) error

UpdateTaskStatus xxx

type HttpConnection

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

HttpConnection xxx

func NewHttpConnection

func NewHttpConnection(endpoint, uri string) *HttpConnection

NewHttpConnection xxx

func (*HttpConnection) Send

func (conn *HttpConnection) Send(call *protoExec.Call, keepAlive bool) (*http.Response, error)

Send xxx

Jump to

Keyboard shortcuts

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