Documentation ¶
Index ¶
- Constants
- Variables
- type AllocBroadcaster
- type AllocExecRequest
- type AllocFileInfo
- type AllocListener
- type AllocResourceUsage
- type AllocStatsRequest
- type AllocStatsResponse
- type ClientStatsResponse
- type CpuStats
- type FsListRequest
- type FsListResponse
- type FsLogsRequest
- type FsStatRequest
- type FsStatResponse
- type FsStreamRequest
- type HealthCheckIntervalRequest
- type HealthCheckIntervalResponse
- type HealthCheckRequest
- type HealthCheckResponse
- type MemoryStats
- type ResourceUsage
- type RpcError
- type StreamErrWrapper
- type TaskResourceUsage
Constants ¶
const CheckBufSize = 4 * 1024
CheckBufSize is the size of the buffer that is used for job output
Variables ¶
var DriverStatsNotImplemented = errors.New("stats not implemented for driver")
DriverStatsNotImplemented is the error to be returned if a driver doesn't implement stats.
var ErrAllocBroadcasterClosed = errors.New("alloc broadcaster closed")
Functions ¶
This section is empty.
Types ¶
type AllocBroadcaster ¶
type AllocBroadcaster struct {
// contains filtered or unexported fields
}
AllocBroadcaster implements an allocation broadcast channel where each listener receives allocation updates. Pending updates are dropped and replaced by newer allocation updates, so listeners may not receive every allocation update. However this ensures Sends never block and listeners only receive the latest allocation update -- never a stale version.
func NewAllocBroadcaster ¶
func NewAllocBroadcaster(l hclog.Logger) *AllocBroadcaster
NewAllocBroadcaster returns a new AllocBroadcaster.
func (*AllocBroadcaster) Close ¶
func (b *AllocBroadcaster) Close()
Close closes the channel, disabling the sending of further allocation updates. Pending updates are still received by listeners. Safe to call concurrently and more than once.
func (*AllocBroadcaster) Listen ¶
func (b *AllocBroadcaster) Listen() *AllocListener
Listen returns a Listener for the broadcast channel. New listeners receive the last sent alloc update.
func (*AllocBroadcaster) Send ¶
func (b *AllocBroadcaster) Send(v *structs.Allocation) error
Send broadcasts an allocation update. Any pending updates are replaced with this version of the allocation to prevent blocking on slow receivers. Returns ErrAllocBroadcasterClosed if called after broadcaster is closed.
type AllocExecRequest ¶
type AllocExecRequest struct { // AllocID is the allocation to stream logs from AllocID string // Task is the task to stream logs from Task string // Tty indicates whether to allocate a pseudo-TTY Tty bool // Cmd is the command to be executed Cmd []string structs.QueryOptions }
AllocExecRequest is the initial request for execing into an Alloc task
func (*AllocExecRequest) CodecDecodeSelf ¶
func (x *AllocExecRequest) CodecDecodeSelf(d *codec1978.Decoder)
func (*AllocExecRequest) CodecEncodeSelf ¶
func (x *AllocExecRequest) CodecEncodeSelf(e *codec1978.Encoder)
type AllocFileInfo ¶
AllocFileInfo holds information about a file inside the AllocDir
func (*AllocFileInfo) CodecDecodeSelf ¶
func (x *AllocFileInfo) CodecDecodeSelf(d *codec1978.Decoder)
func (*AllocFileInfo) CodecEncodeSelf ¶
func (x *AllocFileInfo) CodecEncodeSelf(e *codec1978.Encoder)
type AllocListener ¶
type AllocListener struct {
// contains filtered or unexported fields
}
AllocListener implements a listening endpoint for an allocation broadcast channel.
func (*AllocListener) Ch ¶
func (l *AllocListener) Ch() <-chan *structs.Allocation
func (*AllocListener) Close ¶
func (l *AllocListener) Close()
Close closes the Listener, disabling the receival of further messages. Safe to call more than once and concurrently with receiving on Ch.
type AllocResourceUsage ¶
type AllocResourceUsage struct { // ResourceUsage is the summation of the task resources ResourceUsage *ResourceUsage // Tasks contains the resource usage of each task Tasks map[string]*TaskResourceUsage // The max timestamp of all the Tasks Timestamp int64 }
AllocResourceUsage holds the aggregated task resource usage of the allocation.
func (*AllocResourceUsage) CodecDecodeSelf ¶
func (x *AllocResourceUsage) CodecDecodeSelf(d *codec1978.Decoder)
func (*AllocResourceUsage) CodecEncodeSelf ¶
func (x *AllocResourceUsage) CodecEncodeSelf(e *codec1978.Encoder)
type AllocStatsRequest ¶
type AllocStatsRequest struct { // AllocID is the allocation to retrieves stats for AllocID string // Task is an optional filter to only request stats for the task. Task string structs.QueryOptions }
AllocStatsRequest is used to request the resource usage of a given allocation, potentially filtering by task
func (*AllocStatsRequest) CodecDecodeSelf ¶
func (x *AllocStatsRequest) CodecDecodeSelf(d *codec1978.Decoder)
func (*AllocStatsRequest) CodecEncodeSelf ¶
func (x *AllocStatsRequest) CodecEncodeSelf(e *codec1978.Encoder)
type AllocStatsResponse ¶
type AllocStatsResponse struct { Stats *AllocResourceUsage structs.QueryMeta }
AllocStatsResponse is used to return the resource usage of a given allocation.
func (*AllocStatsResponse) CodecDecodeSelf ¶
func (x *AllocStatsResponse) CodecDecodeSelf(d *codec1978.Decoder)
func (*AllocStatsResponse) CodecEncodeSelf ¶
func (x *AllocStatsResponse) CodecEncodeSelf(e *codec1978.Encoder)
type ClientStatsResponse ¶
ClientStatsResponse is used to return statistics about a node.
func (*ClientStatsResponse) CodecDecodeSelf ¶
func (x *ClientStatsResponse) CodecDecodeSelf(d *codec1978.Decoder)
func (*ClientStatsResponse) CodecEncodeSelf ¶
func (x *ClientStatsResponse) CodecEncodeSelf(e *codec1978.Encoder)
type CpuStats ¶
type CpuStats struct { SystemMode float64 UserMode float64 TotalTicks float64 ThrottledPeriods uint64 ThrottledTime uint64 Percent float64 // A list of fields whose values were actually sampled Measured []string }
CpuStats holds cpu usage related stats
func (*CpuStats) CodecDecodeSelf ¶
func (*CpuStats) CodecEncodeSelf ¶
type FsListRequest ¶
type FsListRequest struct { // AllocID is the allocation to list from AllocID string // Path is the path to list Path string structs.QueryOptions }
FsListRequest is used to list an allocation's directory.
func (*FsListRequest) CodecDecodeSelf ¶
func (x *FsListRequest) CodecDecodeSelf(d *codec1978.Decoder)
func (*FsListRequest) CodecEncodeSelf ¶
func (x *FsListRequest) CodecEncodeSelf(e *codec1978.Encoder)
type FsListResponse ¶
type FsListResponse struct { // Files are the result of listing a directory. Files []*AllocFileInfo structs.QueryMeta }
FsListResponse is used to return the listings of an allocation's directory.
func (*FsListResponse) CodecDecodeSelf ¶
func (x *FsListResponse) CodecDecodeSelf(d *codec1978.Decoder)
func (*FsListResponse) CodecEncodeSelf ¶
func (x *FsListResponse) CodecEncodeSelf(e *codec1978.Encoder)
type FsLogsRequest ¶
type FsLogsRequest struct { // AllocID is the allocation to stream logs from AllocID string // Task is the task to stream logs from Task string // LogType indicates whether "stderr" or "stdout" should be streamed LogType string // Offset is the offset to start streaming data at. Offset int64 // Origin can either be "start" or "end" and determines where the offset is // applied. Origin string // PlainText disables base64 encoding. PlainText bool // Follow follows logs. Follow bool structs.QueryOptions }
FsLogsRequest is the initial request for accessing allocation logs.
func (*FsLogsRequest) CodecDecodeSelf ¶
func (x *FsLogsRequest) CodecDecodeSelf(d *codec1978.Decoder)
func (*FsLogsRequest) CodecEncodeSelf ¶
func (x *FsLogsRequest) CodecEncodeSelf(e *codec1978.Encoder)
type FsStatRequest ¶
type FsStatRequest struct { // AllocID is the allocation to stat the file in AllocID string // Path is the path to list Path string structs.QueryOptions }
FsStatRequest is used to stat a file
func (*FsStatRequest) CodecDecodeSelf ¶
func (x *FsStatRequest) CodecDecodeSelf(d *codec1978.Decoder)
func (*FsStatRequest) CodecEncodeSelf ¶
func (x *FsStatRequest) CodecEncodeSelf(e *codec1978.Encoder)
type FsStatResponse ¶
type FsStatResponse struct { // Info is the result of stating a file Info *AllocFileInfo structs.QueryMeta }
FsStatResponse is used to return the stat results of a file
func (*FsStatResponse) CodecDecodeSelf ¶
func (x *FsStatResponse) CodecDecodeSelf(d *codec1978.Decoder)
func (*FsStatResponse) CodecEncodeSelf ¶
func (x *FsStatResponse) CodecEncodeSelf(e *codec1978.Encoder)
type FsStreamRequest ¶
type FsStreamRequest struct { // AllocID is the allocation to stream logs from AllocID string // Path is the path to the file to stream Path string // Offset is the offset to start streaming data at. Offset int64 // Origin can either be "start" or "end" and determines where the offset is // applied. Origin string // PlainText disables base64 encoding. PlainText bool // Limit is the number of bytes to read Limit int64 // Follow follows the file. Follow bool structs.QueryOptions }
FsStreamRequest is the initial request for streaming the content of a file.
func (*FsStreamRequest) CodecDecodeSelf ¶
func (x *FsStreamRequest) CodecDecodeSelf(d *codec1978.Decoder)
func (*FsStreamRequest) CodecEncodeSelf ¶
func (x *FsStreamRequest) CodecEncodeSelf(e *codec1978.Encoder)
type HealthCheckIntervalRequest ¶
type HealthCheckIntervalRequest struct{}
func (*HealthCheckIntervalRequest) CodecDecodeSelf ¶
func (x *HealthCheckIntervalRequest) CodecDecodeSelf(d *codec1978.Decoder)
func (*HealthCheckIntervalRequest) CodecEncodeSelf ¶
func (x *HealthCheckIntervalRequest) CodecEncodeSelf(e *codec1978.Encoder)
type HealthCheckIntervalResponse ¶
func (*HealthCheckIntervalResponse) CodecDecodeSelf ¶
func (x *HealthCheckIntervalResponse) CodecDecodeSelf(d *codec1978.Decoder)
func (*HealthCheckIntervalResponse) CodecEncodeSelf ¶
func (x *HealthCheckIntervalResponse) CodecEncodeSelf(e *codec1978.Encoder)
type HealthCheckRequest ¶
type HealthCheckRequest struct{}
HealthCheckRequest is the request type for a type that fulfils the Health Check interface
func (*HealthCheckRequest) CodecDecodeSelf ¶
func (x *HealthCheckRequest) CodecDecodeSelf(d *codec1978.Decoder)
func (*HealthCheckRequest) CodecEncodeSelf ¶
func (x *HealthCheckRequest) CodecEncodeSelf(e *codec1978.Encoder)
type HealthCheckResponse ¶
type HealthCheckResponse struct { // Drivers is a map of driver names to current driver information Drivers map[string]*structs.DriverInfo }
HealthCheckResponse is the response type for a type that fulfills the Health Check interface
func (*HealthCheckResponse) AddDriverInfo ¶
func (h *HealthCheckResponse) AddDriverInfo(name string, driverInfo *structs.DriverInfo)
AddDriverInfo adds information about a driver to the fingerprint response. If the Drivers field has not yet been initialized, it does so here.
func (*HealthCheckResponse) CodecDecodeSelf ¶
func (x *HealthCheckResponse) CodecDecodeSelf(d *codec1978.Decoder)
func (*HealthCheckResponse) CodecEncodeSelf ¶
func (x *HealthCheckResponse) CodecEncodeSelf(e *codec1978.Encoder)
type MemoryStats ¶
type MemoryStats struct { RSS uint64 Cache uint64 Swap uint64 Usage uint64 MaxUsage uint64 KernelUsage uint64 KernelMaxUsage uint64 // A list of fields whose values were actually sampled Measured []string }
MemoryStats holds memory usage related stats
func (*MemoryStats) Add ¶
func (ms *MemoryStats) Add(other *MemoryStats)
func (*MemoryStats) CodecDecodeSelf ¶
func (x *MemoryStats) CodecDecodeSelf(d *codec1978.Decoder)
func (*MemoryStats) CodecEncodeSelf ¶
func (x *MemoryStats) CodecEncodeSelf(e *codec1978.Encoder)
type ResourceUsage ¶
type ResourceUsage struct { MemoryStats *MemoryStats CpuStats *CpuStats DeviceStats []*device.DeviceGroupStats }
ResourceUsage holds information related to cpu and memory stats
func (*ResourceUsage) Add ¶
func (ru *ResourceUsage) Add(other *ResourceUsage)
func (*ResourceUsage) CodecDecodeSelf ¶
func (x *ResourceUsage) CodecDecodeSelf(d *codec1978.Decoder)
func (*ResourceUsage) CodecEncodeSelf ¶
func (x *ResourceUsage) CodecEncodeSelf(e *codec1978.Encoder)
type RpcError ¶
RpcError is used for serializing errors with a potential error code
func NewRpcError ¶
func (*RpcError) CodecDecodeSelf ¶
func (*RpcError) CodecEncodeSelf ¶
type StreamErrWrapper ¶
type StreamErrWrapper struct { // Error stores any error that may have occurred. Error *RpcError // Payload is the payload Payload []byte }
StreamErrWrapper is used to serialize output of a stream of a file or logs.
func (*StreamErrWrapper) CodecDecodeSelf ¶
func (x *StreamErrWrapper) CodecDecodeSelf(d *codec1978.Decoder)
func (*StreamErrWrapper) CodecEncodeSelf ¶
func (x *StreamErrWrapper) CodecEncodeSelf(e *codec1978.Encoder)
type TaskResourceUsage ¶
type TaskResourceUsage struct { ResourceUsage *ResourceUsage Timestamp int64 // UnixNano Pids map[string]*ResourceUsage }
TaskResourceUsage holds aggregated resource usage of all processes in a Task and the resource usage of the individual pids
func (*TaskResourceUsage) CodecDecodeSelf ¶
func (x *TaskResourceUsage) CodecDecodeSelf(d *codec1978.Decoder)
func (*TaskResourceUsage) CodecEncodeSelf ¶
func (x *TaskResourceUsage) CodecEncodeSelf(e *codec1978.Encoder)