Documentation ¶
Index ¶
- Constants
- Variables
- func ErrorIsOkToSendToClient(err error) bool
- func NewNode(id string, allocateable atypes.ResourceUnits, available atypes.ResourceUnits) ctypes.Node
- func NewServiceLog(name string, stream io.ReadCloser) *ctypes.ServiceLog
- type Client
- type Cluster
- type Config
- type HostnameServiceClient
- type ReadClient
- type Service
- type SimpleHostnames
- type StatusClient
Constants ¶
View Source
const HostnameSeparator = '.'
Variables ¶
View Source
var ( // Errors types returned by the Exec function on the client interface ErrExec = errors.New("remote command execute error") ErrExecNoServiceWithName = fmt.Errorf("%w: no such service exists with that name", ErrExec) ErrExecServiceNotRunning = fmt.Errorf("%w: service with that name is not running", ErrExec) ErrExecCommandExecutionFailed = fmt.Errorf("%w: command execution failed", ErrExec) ErrExecCommandDoesNotExist = fmt.Errorf("%w: command could not be executed because it does not exist", ErrExec) ErrExecDeploymentNotYetRunning = fmt.Errorf("%w: deployment is not yet active", ErrExec) ErrExecMultiplePods = fmt.Errorf("%w: cannot execute without specifying a pod explicitly", ErrExec) ErrExecPodIndexOutOfRange = fmt.Errorf("%w: pod index out of range", ErrExec) )
View Source
var ( // ErrInsufficientCapacity is the new error when capacity is insufficient ErrInsufficientCapacity = errors.New("insufficient capacity") )
View Source
var ErrNotRunning = errors.New("not running")
ErrNotRunning is the error when service is not running
Functions ¶
func ErrorIsOkToSendToClient ¶ added in v0.12.2
func NewNode ¶ added in v0.2.4
func NewNode(id string, allocateable atypes.ResourceUnits, available atypes.ResourceUnits) ctypes.Node
NewNode returns new Node instance with provided details
func NewServiceLog ¶ added in v0.2.2
func NewServiceLog(name string, stream io.ReadCloser) *ctypes.ServiceLog
NewServiceLog creates and returns a service log with provided details
Types ¶
type Client ¶ added in v0.0.8
type Client interface { ReadClient Deploy(context.Context, mtypes.LeaseID, *manifest.Group) error TeardownLease(context.Context, mtypes.LeaseID) error Deployments(context.Context) ([]ctypes.Deployment, error) Inventory(context.Context) ([]ctypes.Node, error) Exec(ctx context.Context, lID mtypes.LeaseID, service string, podIndex uint, cmd []string, stdin io.Reader, stdout io.Writer, stderr io.Writer, tty bool, tsq remotecommand.TerminalSizeQueue) (ctypes.ExecResult, error) }
Client interface lease and deployment methods
type Cluster ¶
type Cluster interface { Reserve(mtypes.OrderID, atypes.ResourceGroup) (ctypes.Reservation, error) Unreserve(mtypes.OrderID) error }
Cluster is the interface that wraps Reserve and Unreserve methods
type Config ¶ added in v0.9.1
type Config struct { InventoryResourcePollPeriod time.Duration InventoryResourceDebugFrequency uint InventoryExternalPortQuantity uint CPUCommitLevel float64 MemoryCommitLevel float64 StorageCommitLevel float64 BlockedHostnames []string }
func NewDefaultConfig ¶ added in v0.9.1
func NewDefaultConfig() Config
type HostnameServiceClient ¶ added in v0.9.3
type HostnameServiceClient interface { ReserveHostnames(hostnames []string, did dtypes.DeploymentID) <-chan error ReleaseHostnames(hostnames []string) CanReserveHostnames(hostnames []string, did dtypes.DeploymentID) <-chan error }
type ReadClient ¶ added in v0.7.3
type ReadClient interface { LeaseStatus(context.Context, mtypes.LeaseID) (*ctypes.LeaseStatus, error) LeaseEvents(context.Context, mtypes.LeaseID, string, bool) (ctypes.EventsWatcher, error) LeaseLogs(context.Context, mtypes.LeaseID, string, bool, *int64) ([]*ctypes.ServiceLog, error) ServiceStatus(context.Context, mtypes.LeaseID, string) (*ctypes.ServiceStatus, error) }
type Service ¶
type Service interface { StatusClient Cluster Close() error Ready() <-chan struct{} Done() <-chan struct{} HostnameService() HostnameServiceClient }
Service manage compute cluster for the provider. Will eventually integrate with kubernetes, etc...
type SimpleHostnames ¶ added in v0.9.3
type SimpleHostnames struct { Hostnames map[string]dtypes.DeploymentID // contains filtered or unexported fields } /* Used in test code */
func (*SimpleHostnames) CanReserveHostnames ¶ added in v0.9.3
func (sh *SimpleHostnames) CanReserveHostnames(hostnames []string, did dtypes.DeploymentID) <-chan error
func (*SimpleHostnames) ReleaseHostnames ¶ added in v0.9.3
func (sh *SimpleHostnames) ReleaseHostnames(hostnames []string)
func (*SimpleHostnames) ReserveHostnames ¶ added in v0.9.3
func (sh *SimpleHostnames) ReserveHostnames(hostnames []string, did dtypes.DeploymentID) <-chan error
Source Files ¶
Click to show internal directories.
Click to hide internal directories.