Add cio.Load for loading io set
This adds a `Load` Opt for cio to load a tasks io/fifos without attaching or starting the copy routines. It adds the load method in `ctr` by default so that fifos or other IO are removed from disk on delete methods inbetween command runs. It is not the default for all task loads for backwards compat. and a user may want to keep io around to reuse or if log files are used. Fixes #2421 Signed-off-by: Michael Crosby <crosbymichael@gmail.com>
This commit is contained in:
parent
f15c3be348
commit
fdceb13b14
11
cio/io.go
11
cio/io.go
@ -255,3 +255,14 @@ func (l *logIO) Wait() {
|
|||||||
func (l *logIO) Close() error {
|
func (l *logIO) Close() error {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Load the io for a container but do not attach
|
||||||
|
//
|
||||||
|
// Allows io to be loaded on the task for deletion without
|
||||||
|
// starting copy routines
|
||||||
|
func Load(set *FIFOSet) (IO, error) {
|
||||||
|
return &cio{
|
||||||
|
config: set.Config,
|
||||||
|
closers: []io.Closer{set},
|
||||||
|
}, nil
|
||||||
|
}
|
||||||
|
@ -25,6 +25,7 @@ import (
|
|||||||
"text/tabwriter"
|
"text/tabwriter"
|
||||||
|
|
||||||
"github.com/containerd/containerd"
|
"github.com/containerd/containerd"
|
||||||
|
"github.com/containerd/containerd/cio"
|
||||||
"github.com/containerd/containerd/cmd/ctr/commands"
|
"github.com/containerd/containerd/cmd/ctr/commands"
|
||||||
"github.com/containerd/containerd/cmd/ctr/commands/run"
|
"github.com/containerd/containerd/cmd/ctr/commands/run"
|
||||||
"github.com/containerd/containerd/log"
|
"github.com/containerd/containerd/log"
|
||||||
@ -162,7 +163,6 @@ var deleteCommand = cli.Command{
|
|||||||
log.G(ctx).WithError(err).Errorf("failed to delete container %q", arg)
|
log.G(ctx).WithError(err).Errorf("failed to delete container %q", arg)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return exitErr
|
return exitErr
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
@ -172,7 +172,7 @@ func deleteContainer(ctx context.Context, client *containerd.Client, id string,
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
task, err := container.Task(ctx, nil)
|
task, err := container.Task(ctx, cio.Load)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return container.Delete(ctx, opts...)
|
return container.Delete(ctx, opts...)
|
||||||
}
|
}
|
||||||
|
@ -18,6 +18,7 @@ package tasks
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"github.com/containerd/containerd"
|
"github.com/containerd/containerd"
|
||||||
|
"github.com/containerd/containerd/cio"
|
||||||
"github.com/containerd/containerd/cmd/ctr/commands"
|
"github.com/containerd/containerd/cmd/ctr/commands"
|
||||||
"github.com/urfave/cli"
|
"github.com/urfave/cli"
|
||||||
)
|
)
|
||||||
@ -42,8 +43,7 @@ var deleteCommand = cli.Command{
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
task, err := container.Task(ctx, cio.Load)
|
||||||
task, err := container.Task(ctx, nil)
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
@ -307,6 +307,12 @@ func (c *container) get(ctx context.Context) (containers.Container, error) {
|
|||||||
|
|
||||||
// get the existing fifo paths from the task information stored by the daemon
|
// get the existing fifo paths from the task information stored by the daemon
|
||||||
func attachExistingIO(response *tasks.GetResponse, ioAttach cio.Attach) (cio.IO, error) {
|
func attachExistingIO(response *tasks.GetResponse, ioAttach cio.Attach) (cio.IO, error) {
|
||||||
|
fifoSet := loadFifos(response)
|
||||||
|
return ioAttach(fifoSet)
|
||||||
|
}
|
||||||
|
|
||||||
|
// loadFifos loads the containers fifos
|
||||||
|
func loadFifos(response *tasks.GetResponse) *cio.FIFOSet {
|
||||||
path := getFifoDir([]string{
|
path := getFifoDir([]string{
|
||||||
response.Process.Stdin,
|
response.Process.Stdin,
|
||||||
response.Process.Stdout,
|
response.Process.Stdout,
|
||||||
@ -315,13 +321,12 @@ func attachExistingIO(response *tasks.GetResponse, ioAttach cio.Attach) (cio.IO,
|
|||||||
closer := func() error {
|
closer := func() error {
|
||||||
return os.RemoveAll(path)
|
return os.RemoveAll(path)
|
||||||
}
|
}
|
||||||
fifoSet := cio.NewFIFOSet(cio.Config{
|
return cio.NewFIFOSet(cio.Config{
|
||||||
Stdin: response.Process.Stdin,
|
Stdin: response.Process.Stdin,
|
||||||
Stdout: response.Process.Stdout,
|
Stdout: response.Process.Stdout,
|
||||||
Stderr: response.Process.Stderr,
|
Stderr: response.Process.Stderr,
|
||||||
Terminal: response.Process.Terminal,
|
Terminal: response.Process.Terminal,
|
||||||
}, closer)
|
}, closer)
|
||||||
return ioAttach(fifoSet)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// getFifoDir looks for any non-empty path for a stdio fifo
|
// getFifoDir looks for any non-empty path for a stdio fifo
|
||||||
|
Loading…
Reference in New Issue
Block a user