summaryrefslogtreecommitdiff
path: root/daemon/logger/plugin_unix.go
blob: a59fda860a59e8101bbbf27c3cc53a70687a9d74 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
//go:build linux || freebsd
// +build linux freebsd

package logger // import "github.com/docker/docker/daemon/logger"

import (
	"context"
	"io"

	"github.com/containerd/fifo"
	"github.com/pkg/errors"
	"golang.org/x/sys/unix"
)

func openPluginStream(a *pluginAdapter) (io.WriteCloser, error) {
	// Make sure to also open with read (in addition to write) to avoid borken pipe errors on plugin failure.
	// It is up to the plugin to keep track of pipes that it should re-attach to, however.
	// If the plugin doesn't open for reads, then the container will block once the pipe is full.
	f, err := fifo.OpenFifo(context.Background(), a.fifoPath, unix.O_RDWR|unix.O_CREAT|unix.O_NONBLOCK, 0700)
	if err != nil {
		return nil, errors.Wrapf(err, "error creating i/o pipe for log plugin: %s", a.Name())
	}
	return f, nil
}