Documentation ¶
Overview ¶
Package exec is used to invoke child processes across various platforms to provide the following features:
- Least privilege - Resource constraints - Process isolation
A "platform" may be defined as coarsely as "Windows" or as specifically as "linux 3.20 with systemd". This allows Nomad to use best-effort, best- available capabilities of each platform to provide resource constraints, process isolation, and security features, or otherwise take advantage of features that are unique to that platform.
The `semantics of any particular instance are left up to the implementation. However, these should be completely transparent to the calling context. In other words, the Java driver should be able to call exec for any platform and just work.
Index ¶
- type Executor
- type UniversalExecutor
- func (e *UniversalExecutor) Command() *cmd
- func (e *UniversalExecutor) ConfigureTaskDir(taskName string, alloc *allocdir.AllocDir) error
- func (e *UniversalExecutor) ForceStop() error
- func (e *UniversalExecutor) ID() (string, error)
- func (e *UniversalExecutor) Limit(resources *structs.Resources) error
- func (e *UniversalExecutor) Open(pid string) error
- func (c *UniversalExecutor) SetGID(groupid string) error
- func (c *UniversalExecutor) SetUID(userid string) error
- func (e *UniversalExecutor) Shutdown() error
- func (e *UniversalExecutor) Start() error
- func (e *UniversalExecutor) Wait() error
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Executor ¶
type Executor interface { // Limit must be called before Start and restricts the amount of resources // the process can use. Note that an error may be returned ONLY IF the // executor implements resource limiting. Otherwise Limit is ignored. Limit(*structs.Resources) error // ConfigureTaskDir must be called before Start and ensures that the tasks // directory is properly configured. ConfigureTaskDir(taskName string, alloc *allocdir.AllocDir) error // Start the process. This may wrap the actual process in another command, // depending on the capabilities in this environment. Errors that arise from // Limits or Runas may bubble through Start() Start() error // Open should be called to restore a previous execution. This might be needed if // nomad is restarted. Open(string) error // Wait waits till the user's command is completed. Wait() error // Returns a handle that is executor specific for use in reopening. ID() (string, error) // Shutdown should use a graceful stop mechanism so the application can // perform checkpointing or cleanup, if such a mechanism is available. // If such a mechanism is not available, Shutdown() should call ForceStop(). Shutdown() error // ForceStop will terminate the process without waiting for cleanup. Every // implementations must provide this. ForceStop() error // Command provides access the underlying Cmd struct in case the Executor // interface doesn't expose the functionality you need. Command() *cmd }
Executor is an interface that any platform- or capability-specific exec wrapper must implement. You should not need to implement a Java executor. Rather, you would implement a cgroups executor that the Java driver will use.
func NewExecutor ¶
func NewExecutor() Executor
type UniversalExecutor ¶
type UniversalExecutor struct {
// contains filtered or unexported fields
}
UniversalExecutor should work everywhere, and as a result does not include any resource restrictions or runas capabilities.
func (*UniversalExecutor) Command ¶
func (e *UniversalExecutor) Command() *cmd
func (*UniversalExecutor) ConfigureTaskDir ¶
func (e *UniversalExecutor) ConfigureTaskDir(taskName string, alloc *allocdir.AllocDir) error
func (*UniversalExecutor) ForceStop ¶
func (e *UniversalExecutor) ForceStop() error
func (*UniversalExecutor) ID ¶
func (e *UniversalExecutor) ID() (string, error)
func (*UniversalExecutor) Limit ¶
func (e *UniversalExecutor) Limit(resources *structs.Resources) error
func (*UniversalExecutor) Open ¶
func (e *UniversalExecutor) Open(pid string) error
func (*UniversalExecutor) SetGID ¶
SetGID changes the Gid for this command (must be set before starting)
func (*UniversalExecutor) SetUID ¶
SetUID changes the Uid for this command (must be set before starting)
func (*UniversalExecutor) Shutdown ¶
func (e *UniversalExecutor) Shutdown() error
func (*UniversalExecutor) Start ¶
func (e *UniversalExecutor) Start() error
func (*UniversalExecutor) Wait ¶
func (e *UniversalExecutor) Wait() error