Documentation ¶
Overview ¶
Package runtime defines interfaces for accessing runtime specific settings, and state.
Index ¶
- Variables
- func IsRebootError(err error) bool
- type ActorIDCtxKey
- type Board
- type ClusterState
- type Controller
- type DBusState
- type DrainEvent
- type DrainSubscription
- type Drainer
- type Event
- type EventFatalSequencerError
- type EventInfo
- type EventSequenceStart
- type EventStream
- type LockOption
- type LockOptions
- type LogEvent
- type LogHandler
- type LogOption
- type LogOptions
- type LogSender
- type LoggingManager
- type Machine
- type MachineState
- type Mode
- type ModeCapability
- type PartitionOptions
- type PartitionTarget
- type Phase
- type Platform
- type PlatformNetworkConfig
- type Publisher
- type RebootError
- type ResetOptions
- type Runtime
- type Sequence
- type Sequencer
- type State
- type TaskExecutionFunc
- type TaskSetupFunc
- type V1Alpha2Controller
- type V1Alpha2State
- type WatchFunc
- type WatchOptionFunc
- type WatchOptions
- type Watcher
Constants ¶
This section is empty.
Variables ¶
var ( // ErrLocked indicates that the sequencer is currently locked, and processing // another sequence. ErrLocked = errors.New("locked") // ErrInvalidSequenceData indicates that the sequencer got data the wrong // data type for a sequence. ErrInvalidSequenceData = errors.New("invalid sequence data") // ErrUndefinedRuntime indicates that the sequencer's runtime is not defined. ErrUndefinedRuntime = errors.New("undefined runtime") )
var ErrDontRetry = fmt.Errorf("don't retry")
ErrDontRetry indicates that log event should not be resent.
Functions ¶
func IsRebootError ¶ added in v0.8.2
IsRebootError checks whether given error is RebootError.
Types ¶
type ActorIDCtxKey ¶ added in v1.2.0
type ActorIDCtxKey struct{}
ActorIDCtxKey is the context key used for event actor id.
type Board ¶ added in v0.8.0
type Board interface { Name() string Install(string) error KernelArgs() procfs.Parameters PartitionOptions() *PartitionOptions }
Board defines the requirements for a SBC.
type Controller ¶
type Controller interface { Runtime() Runtime Sequencer() Sequencer Run(context.Context, Sequence, interface{}, ...LockOption) error V1Alpha2() V1Alpha2Controller }
Controller represents the controller responsible for managing the execution of sequences.
type DrainEvent ¶ added in v0.14.0
type DrainEvent struct{}
DrainEvent is sent to the events channel when drainer starts the shutdown sequence.
type DrainSubscription ¶ added in v0.14.0
type DrainSubscription struct {
// contains filtered or unexported fields
}
DrainSubscription keeps ingoing and outgoing events channels.
func (*DrainSubscription) Cancel ¶ added in v0.14.0
func (s *DrainSubscription) Cancel()
Cancel the subscription which triggers drain to shutdown.
func (*DrainSubscription) EventCh ¶ added in v0.14.0
func (s *DrainSubscription) EventCh() <-chan DrainEvent
EventCh returns drain events channel.
type Drainer ¶ added in v0.14.0
type Drainer struct {
// contains filtered or unexported fields
}
Drainer is used in controllers to ensure graceful shutdown.
func (*Drainer) Drain ¶ added in v0.14.0
Drain initializes drain sequence waits for it to succeed until the context is canceled.
func (*Drainer) Subscribe ¶ added in v0.14.0
func (d *Drainer) Subscribe() *DrainSubscription
Subscribe should be called from a controller that needs graceful shutdown.
type Event ¶ added in v0.6.0
Event is what is sent on the wire.
type EventFatalSequencerError ¶
EventFatalSequencerError represents a fatal sequencer error.
type EventSequenceStart ¶
type EventSequenceStart struct {
Sequence Sequence
}
EventSequenceStart represents the sequence start event.
type EventStream ¶
EventStream defines the runtime event stream.
type LockOption ¶ added in v1.2.0
type LockOption func(o *LockOptions) error
LockOption represents an option setter.
func WithTakeover ¶ added in v0.9.0
func WithTakeover() LockOption
WithTakeover sets the take option to true.
type LockOptions ¶ added in v1.2.0
type LockOptions struct {
Takeover bool
}
LockOptions represents the options for a controller.
func DefaultControllerOptions ¶ added in v0.6.0
func DefaultControllerOptions() LockOptions
DefaultControllerOptions returns the default controller options.
type LogEvent ¶ added in v0.14.0
type LogEvent struct { Msg string Time time.Time Level zapcore.Level Fields map[string]interface{} }
LogEvent represents a log message to be send.
type LogHandler ¶ added in v0.6.0
type LogHandler interface { Writer() (io.WriteCloser, error) Reader(opt ...LogOption) (io.ReadCloser, error) }
LogHandler provides interface to access particular log source.
type LogOption ¶ added in v0.6.0
type LogOption func(*LogOptions) error
LogOption provides functional options for LogHandler.Reader.
func WithFollow ¶ added in v0.6.0
func WithFollow() LogOption
WithFollow enables follow mode for the logs.
func WithTailLines ¶ added in v0.6.0
WithTailLines starts log reading from lines from the tail of the log.
type LogOptions ¶ added in v0.6.0
LogOptions for LogHandler.Reader.
type LogSender ¶ added in v0.14.0
type LogSender interface { // Send tries to send the log event once, exiting on success, error, or context cancelation. // // Returned error is nil on success, non-nil otherwise. // As a special case, Send can return (possibly wrapped) ErrDontRetry if the log event should not be resent // (if it is invalid, if it was sent partially, etc). // // Send should be thread-safe. Send(ctx context.Context, e *LogEvent) error // Close stops the sender gracefully if possible, or forcefully on context cancelation. // // Close should be thread-safe. Close(ctx context.Context) error }
LogSender provides common interface for log senders.
type LoggingManager ¶ added in v0.6.0
type LoggingManager interface { // ServiceLog privides a log handler for a given service (that may not exist). ServiceLog(service string) LogHandler // SetSenders sets log senders for all derived log handlers // and returns the previous ones for closing. // // SetSenders should be thread-safe. SetSenders(senders []LogSender) []LogSender }
LoggingManager provides unified interface to publish and consume logs.
type Machine ¶
type Machine interface { State() MachineState Config() config.MachineConfig }
Machine defines the runtime parameters.
type MachineState ¶
type MachineState interface { Disk(options ...disk.Option) *probe.ProbedBlockDevice Close() error Installed() bool IsInstallStaged() bool StagedInstallImageRef() string StagedInstallOptions() []byte KexecPrepared(bool) IsKexecPrepared() bool DBus() DBusState }
MachineState defines the machined state.
type Mode ¶
type Mode int
Mode is a runtime mode.
func (Mode) RequiresInstall ¶ added in v0.6.0
RequiresInstall implements config.RuntimeMode.
func (Mode) Supports ¶ added in v0.7.0
func (m Mode) Supports(feature ModeCapability) bool
Supports returns mode capability.
type ModeCapability ¶ added in v0.7.0
type ModeCapability uint64
ModeCapability describes mode capability flags.
const ( // Reboot node reboot. Reboot ModeCapability = 1 << iota // Rollback node rollback. Rollback // Shutdown node shutdown. Shutdown // Upgrade node upgrade. Upgrade )
type PartitionOptions ¶ added in v0.8.0
type PartitionOptions struct {
PartitionsOffset uint64
}
PartitionOptions are the board specific options for customizing the partition table.
type PartitionTarget ¶ added in v0.8.0
PartitionTarget provides interface to the disk partition.
type Phase ¶
type Phase struct { Name string Tasks []TaskSetupFunc }
Phase represents a collection of tasks to be performed concurrently.
type Platform ¶
type Platform interface { // Name returns platform name. Name() string // Mode returns platform mode (metal, cloud or container). Mode() Mode // Configuration fetches the machine configuration from platform-specific location. // // On cloud-like platform it is user-data in metadata service. // For metal platform that is either `talos.config=` URL or mounted ISO image. Configuration(context.Context, state.State) ([]byte, error) // KernelArgs returns additional kernel arguments which should be injected for the kernel boot. KernelArgs() procfs.Parameters // NetworkConfiguration fetches network configuration from the platform metadata. // // Controller will run this in function a separate goroutine, restarting it // on error. Platform is expected to deliver network configuration over the channel, // including updates to the configuration over time. NetworkConfiguration(context.Context, chan<- *PlatformNetworkConfig) error }
Platform defines the requirements for a platform.
type PlatformNetworkConfig ¶ added in v1.0.0
type PlatformNetworkConfig struct { Addresses []network.AddressSpecSpec `yaml:"addresses"` Links []network.LinkSpecSpec `yaml:"links"` Routes []network.RouteSpecSpec `yaml:"routes"` Hostnames []network.HostnameSpecSpec `yaml:"hostnames"` Resolvers []network.ResolverSpecSpec `yaml:"resolvers"` TimeServers []network.TimeServerSpecSpec `yaml:"timeServers"` Operators []network.OperatorSpecSpec `yaml:"operators"` ExternalIPs []netaddr.IP `yaml:"externalIPs"` }
PlatformNetworkConfig describes the network configuration produced by the platform.
This structure is marshaled to STATE partition to persist cached network configuration across reboots.
type RebootError ¶ added in v0.8.2
type RebootError struct {
Cmd int
}
RebootError encapsulates unix.Reboot() cmd argument.
func (RebootError) Error ¶ added in v0.8.2
func (e RebootError) Error() string
type ResetOptions ¶ added in v0.8.0
type ResetOptions interface { GetGraceful() bool GetReboot() bool GetSystemDiskTargets() []PartitionTarget }
ResetOptions are parameters to Reset sequence.
type Runtime ¶
type Runtime interface { Config() config.Provider LoadAndValidateConfig([]byte) (config.Provider, error) RollbackToConfigAfter([]byte, time.Duration) error CancelConfigRollbackTimeout() SetConfig(config.Provider) error CanApplyImmediate(config.Provider) error State() State Events() EventStream Logging() LoggingManager NodeName() (string, error) IsBootstrapAllowed() bool }
Runtime defines the runtime parameters.
type Sequence ¶
type Sequence int
Sequence represents a sequence type.
const ( // SequenceNoop is the noop sequence. SequenceNoop Sequence = iota // SequenceBoot is the boot sequence. SequenceBoot // SequenceInitialize is the initialize sequence. SequenceInitialize // SequenceInstall is the install sequence. SequenceInstall // SequenceShutdown is the shutdown sequence. SequenceShutdown // SequenceUpgrade is the upgrade sequence. SequenceUpgrade // SequenceStageUpgrade is the stage upgrade sequence. SequenceStageUpgrade // SequenceReset is the reset sequence. SequenceReset // SequenceReboot is the reboot sequence. SequenceReboot )
func ParseSequence ¶
ParseSequence returns a `Sequence` that matches the specified string.
func (Sequence) CanTakeOver ¶ added in v1.2.0
CanTakeOver defines sequences priority.
| what is running (columns) what is requested (rows) | boot | reboot | reset | upgrade | |----------------------------------------------------|------|--------|-------|---------| | reboot | Y | Y | Y | N | | reset | Y | N | N | N | | upgrade | Y | N | N | N |.
type Sequencer ¶
type Sequencer interface { Boot(Runtime) []Phase Initialize(Runtime) []Phase Install(Runtime) []Phase Reboot(Runtime) []Phase Reset(Runtime, ResetOptions) []Phase Shutdown(Runtime, *machine.ShutdownRequest) []Phase StageUpgrade(Runtime, *machine.UpgradeRequest) []Phase Upgrade(Runtime, *machine.UpgradeRequest) []Phase }
Sequencer describes the set of sequences required for the lifecycle management of the operating system.
type State ¶
type State interface { Platform() Platform Machine() MachineState Cluster() ClusterState V1Alpha2() V1Alpha2State }
State defines the state.
type TaskExecutionFunc ¶
TaskExecutionFunc defines the function that a task will execute for a specific runtime mode.
type TaskSetupFunc ¶
type TaskSetupFunc func(seq Sequence, data interface{}) (TaskExecutionFunc, string)
TaskSetupFunc defines the function that a task will execute for a specific runtime mode.
type V1Alpha2Controller ¶ added in v0.9.0
type V1Alpha2Controller interface { Run(context.Context, *Drainer) error DependencyGraph() (*controller.DependencyGraph, error) }
V1Alpha2Controller provides glue into v2alpha1 controller runtime.
type V1Alpha2State ¶ added in v0.9.0
type V1Alpha2State interface { Resources() state.State NamespaceRegistry() *registry.NamespaceRegistry ResourceRegistry() *registry.ResourceRegistry SetConfig(config.Provider) error }
V1Alpha2State defines the next generation (v2) interface binding into v1 runtime.
type WatchFunc ¶
type WatchFunc func(<-chan EventInfo)
WatchFunc defines the watcher callback function.
type WatchOptionFunc ¶ added in v0.6.0
type WatchOptionFunc func(opts *WatchOptions) error
WatchOptionFunc defines the options for the watcher.
func WithActorID ¶ added in v1.2.0
func WithActorID(actorID string) WatchOptionFunc
WithActorID sets up Watcher to return events filtered by given actor id.
func WithTailDuration ¶ added in v0.6.0
func WithTailDuration(dur time.Duration) WatchOptionFunc
WithTailDuration sets up Watcher to return events with timestamp >= (now - tailDuration).
func WithTailEvents ¶ added in v0.6.0
func WithTailEvents(number int) WatchOptionFunc
WithTailEvents sets up Watcher to return specified number of past events.
If number is negative, all the available past events are returned.
func WithTailID ¶ added in v0.6.0
func WithTailID(id xid.ID) WatchOptionFunc
WithTailID sets up Watcher to return events with ID > TailID.
type WatchOptions ¶ added in v0.6.0
type WatchOptions struct { // Return that many past events. // // If TailEvents is negative, return all the events available. TailEvents int // Start at ID > specified. TailID xid.ID // Start at timestamp Now() - TailDuration. TailDuration time.Duration // ActorID to ID of the actor to filter events by. ActorID string }
WatchOptions defines options for the watch call.
Only one of TailEvents, TailID or TailDuration should be non-zero.
type Watcher ¶
type Watcher interface {
Watch(WatchFunc, ...WatchOptionFunc) error
}
Watcher defines a runtime event watcher.
Source Files ¶
Directories ¶
Path | Synopsis |
---|---|
Package disk contains abstract utility function to filter disks in MachineState.Disk call.
|
Package disk contains abstract utility function to filter disks in MachineState.Disk call. |
Package logging provides implementations of runtime.LoggingManager.
|
Package logging provides implementations of runtime.LoggingManager. |
Package v1alpha1 implements a `Runtime`.
|
Package v1alpha1 implements a `Runtime`. |
bootloader/adv
Package adv provides common interfaces to access ADV data.
|
Package adv provides common interfaces to access ADV data. |
bootloader/adv/syslinux
Package syslinux provides syslinux-compatible ADV data.
|
Package syslinux provides syslinux-compatible ADV data. |
bootloader/adv/talos
Package talos implements modern ADV which supports large size for the values and tags.
|
Package talos implements modern ADV which supports large size for the values and tags. |
bootloader/grub
Package grub provides the interface to the GRUB bootloader: config management, installation, etc.
|
Package grub provides the interface to the GRUB bootloader: config management, installation, etc. |
Package v1alpha2 provides runtime implementation based on os-runtime.
|
Package v1alpha2 provides runtime implementation based on os-runtime. |