133 lines
3.7 KiB
Go
133 lines
3.7 KiB
Go
/*
|
|
Copyright The containerd Authors.
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
You may obtain a copy of the License at
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
*/
|
|
|
|
package runtime
|
|
|
|
import (
|
|
"context"
|
|
"time"
|
|
|
|
"github.com/gogo/protobuf/types"
|
|
)
|
|
|
|
// TaskInfo provides task specific information
|
|
type TaskInfo struct {
|
|
ID string
|
|
Runtime string
|
|
Spec []byte
|
|
Namespace string
|
|
}
|
|
|
|
// Process is a runtime object for an executing process inside a container
|
|
type Process interface {
|
|
ID() string
|
|
// State returns the process state
|
|
State(context.Context) (State, error)
|
|
// Kill signals a container
|
|
Kill(context.Context, uint32, bool) error
|
|
// Pty resizes the processes pty/console
|
|
ResizePty(context.Context, ConsoleSize) error
|
|
// CloseStdin closes the processes stdin
|
|
CloseIO(context.Context) error
|
|
// Start the container's user defined process
|
|
Start(context.Context) error
|
|
// Wait for the process to exit
|
|
Wait(context.Context) (*Exit, error)
|
|
}
|
|
|
|
// Task is the runtime object for an executing container
|
|
type Task interface {
|
|
Process
|
|
|
|
// Information of the container
|
|
Info() TaskInfo
|
|
// Pause pauses the container process
|
|
Pause(context.Context) error
|
|
// Resume unpauses the container process
|
|
Resume(context.Context) error
|
|
// Exec adds a process into the container
|
|
Exec(context.Context, string, ExecOpts) (Process, error)
|
|
// Pids returns all pids
|
|
Pids(context.Context) ([]ProcessInfo, error)
|
|
// Checkpoint checkpoints a container to an image with live system data
|
|
Checkpoint(context.Context, string, *types.Any) error
|
|
// DeleteProcess deletes a specific exec process via its id
|
|
DeleteProcess(context.Context, string) (*Exit, error)
|
|
// Update sets the provided resources to a running task
|
|
Update(context.Context, *types.Any) error
|
|
// Process returns a process within the task for the provided id
|
|
Process(context.Context, string) (Process, error)
|
|
// Metrics returns runtime specific metrics for a task
|
|
Metrics(context.Context) (interface{}, error)
|
|
}
|
|
|
|
// ExecOpts provides additional options for additional processes running in a task
|
|
type ExecOpts struct {
|
|
Spec *types.Any
|
|
IO IO
|
|
}
|
|
|
|
// ConsoleSize of a pty or windows terminal
|
|
type ConsoleSize struct {
|
|
Width uint32
|
|
Height uint32
|
|
}
|
|
|
|
// Status is the runtime status of a task and/or process
|
|
type Status int
|
|
|
|
const (
|
|
// CreatedStatus when a process has been created
|
|
CreatedStatus Status = iota + 1
|
|
// RunningStatus when a process is running
|
|
RunningStatus
|
|
// StoppedStatus when a process has stopped
|
|
StoppedStatus
|
|
// DeletedStatus when a process has been deleted
|
|
DeletedStatus
|
|
// PausedStatus when a process is paused
|
|
PausedStatus
|
|
// PausingStatus when a process is currently pausing
|
|
PausingStatus
|
|
)
|
|
|
|
// State information for a process
|
|
type State struct {
|
|
// Status is the current status of the container
|
|
Status Status
|
|
// Pid is the main process id for the container
|
|
Pid uint32
|
|
// ExitStatus of the process
|
|
// Only valid if the Status is Stopped
|
|
ExitStatus uint32
|
|
// ExitedAt is the time at which the process exited
|
|
// Only valid if the Status is Stopped
|
|
ExitedAt time.Time
|
|
Stdin string
|
|
Stdout string
|
|
Stderr string
|
|
Terminal bool
|
|
}
|
|
|
|
// ProcessInfo holds platform specific process information
|
|
type ProcessInfo struct {
|
|
// Pid is the process ID
|
|
Pid uint32
|
|
// Info includes additional process information
|
|
// Info varies by platform
|
|
Info interface{}
|
|
}
|