Add support for TaskConfig flags.
--command --args [] --cap-add [] --cap-drop [] Signed-off-by: Shishir Mahajan <smahajan@roblox.com>
This commit is contained in:
parent
14f75eb459
commit
b4f27fa4e2
@ -1,6 +1,8 @@
|
|||||||
package containerd
|
package containerd
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"fmt"
|
||||||
|
|
||||||
"github.com/containerd/containerd"
|
"github.com/containerd/containerd"
|
||||||
"github.com/containerd/containerd/cio"
|
"github.com/containerd/containerd/cio"
|
||||||
"github.com/containerd/containerd/oci"
|
"github.com/containerd/containerd/oci"
|
||||||
@ -18,13 +20,40 @@ func (d *Driver) pullImage(imageName string) (containerd.Image, error) {
|
|||||||
return d.client.Pull(d.ctxContainerd, imageName, containerd.WithPullUnpack)
|
return d.client.Pull(d.ctxContainerd, imageName, containerd.WithPullUnpack)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (d *Driver) createContainer(image containerd.Image, containerName, containerSnapshotName, containerdRuntime string, env []string) (containerd.Container, error) {
|
func (d *Driver) createContainer(image containerd.Image, containerName, containerSnapshotName, containerdRuntime string, env []string, config *TaskConfig) (containerd.Container, error) {
|
||||||
|
if config.Command == "" && len(config.Args) > 0 {
|
||||||
|
return nil, fmt.Errorf("Command is empty. Cannot set --args without --command.")
|
||||||
|
}
|
||||||
|
|
||||||
|
var args []string
|
||||||
|
if config.Command != "" {
|
||||||
|
args = append(args, config.Command)
|
||||||
|
}
|
||||||
|
|
||||||
|
if len(config.Args) > 0 {
|
||||||
|
args = append(args, config.Args...)
|
||||||
|
}
|
||||||
|
|
||||||
|
var opts []oci.SpecOpts
|
||||||
|
|
||||||
|
opts = append(opts, oci.WithImageConfigArgs(image, args))
|
||||||
|
|
||||||
|
if len(config.CapAdd) > 0 {
|
||||||
|
opts = append(opts, oci.WithCapabilities(config.CapAdd))
|
||||||
|
}
|
||||||
|
|
||||||
|
if len(config.CapDrop) > 0 {
|
||||||
|
opts = append(opts, oci.WithDroppedCapabilities(config.CapDrop))
|
||||||
|
}
|
||||||
|
|
||||||
|
opts = append(opts, oci.WithEnv(env))
|
||||||
|
|
||||||
return d.client.NewContainer(
|
return d.client.NewContainer(
|
||||||
d.ctxContainerd,
|
d.ctxContainerd,
|
||||||
containerName,
|
containerName,
|
||||||
containerd.WithRuntime(containerdRuntime, nil),
|
containerd.WithRuntime(containerdRuntime, nil),
|
||||||
containerd.WithNewSnapshot(containerSnapshotName, image),
|
containerd.WithNewSnapshot(containerSnapshotName, image),
|
||||||
containerd.WithNewSpec(oci.WithImageConfig(image), oci.WithEnv(env)),
|
containerd.WithNewSpec(opts...),
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -69,7 +69,11 @@ var (
|
|||||||
// this is used to validate the configuration specified for the plugin
|
// this is used to validate the configuration specified for the plugin
|
||||||
// when a job is submitted.
|
// when a job is submitted.
|
||||||
taskConfigSpec = hclspec.NewObject(map[string]*hclspec.Spec{
|
taskConfigSpec = hclspec.NewObject(map[string]*hclspec.Spec{
|
||||||
"image": hclspec.NewAttr("image", "string", true),
|
"image": hclspec.NewAttr("image", "string", true),
|
||||||
|
"command": hclspec.NewAttr("command", "string", false),
|
||||||
|
"args": hclspec.NewAttr("args", "list(string)", false),
|
||||||
|
"cap_add": hclspec.NewAttr("cap_add", "list(string)", false),
|
||||||
|
"cap_drop": hclspec.NewAttr("cap_drop", "list(string)", false),
|
||||||
})
|
})
|
||||||
|
|
||||||
// capabilities indicates what optional features this driver supports
|
// capabilities indicates what optional features this driver supports
|
||||||
@ -92,7 +96,11 @@ type Config struct {
|
|||||||
// TaskConfig contains configuration information for a task that runs with
|
// TaskConfig contains configuration information for a task that runs with
|
||||||
// this plugin
|
// this plugin
|
||||||
type TaskConfig struct {
|
type TaskConfig struct {
|
||||||
Image string `codec:"image"`
|
Image string `codec:"image"`
|
||||||
|
Command string `codec:"command"`
|
||||||
|
Args []string `codec:"args"`
|
||||||
|
CapAdd []string `codec:"cap_add"`
|
||||||
|
CapDrop []string `codec:"cap_drop"`
|
||||||
}
|
}
|
||||||
|
|
||||||
// TaskState is the runtime state which is encoded in the handle returned to
|
// TaskState is the runtime state which is encoded in the handle returned to
|
||||||
@ -302,7 +310,7 @@ func (d *Driver) StartTask(cfg *drivers.TaskConfig) (*drivers.TaskHandle, *drive
|
|||||||
}
|
}
|
||||||
|
|
||||||
containerSnapshotName := fmt.Sprintf("%s-snapshot", containerName)
|
containerSnapshotName := fmt.Sprintf("%s-snapshot", containerName)
|
||||||
container, err := d.createContainer(image, containerName, containerSnapshotName, d.config.ContainerdRuntime, env)
|
container, err := d.createContainer(image, containerName, containerSnapshotName, d.config.ContainerdRuntime, env, &driverConfig)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, nil, fmt.Errorf("Error in creating container: %v", err)
|
return nil, nil, fmt.Errorf("Error in creating container: %v", err)
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user