2018-02-05 16:05:59 -05:00
|
|
|
package container // import "github.com/docker/docker/daemon/cluster/executor/container"
|
2016-08-23 19:50:15 -04:00
|
|
|
|
|
|
|
import (
|
2018-04-19 18:30:59 -04:00
|
|
|
"context"
|
|
|
|
|
2016-08-23 19:50:15 -04:00
|
|
|
executorpkg "github.com/docker/docker/daemon/cluster/executor"
|
2016-10-26 16:30:53 -04:00
|
|
|
"github.com/docker/swarmkit/agent/exec"
|
2016-08-23 19:50:15 -04:00
|
|
|
"github.com/docker/swarmkit/api"
|
|
|
|
)
|
|
|
|
|
|
|
|
// networkAttacherController implements agent.Controller against docker's API.
|
|
|
|
//
|
|
|
|
// networkAttacherController manages the lifecycle of network
|
|
|
|
// attachment of a docker unmanaged container managed as a task from
|
|
|
|
// agent point of view. It provides network attachment information to
|
|
|
|
// the unmanaged container for it to attach to the network and run.
|
|
|
|
type networkAttacherController struct {
|
|
|
|
backend executorpkg.Backend
|
|
|
|
task *api.Task
|
|
|
|
adapter *containerAdapter
|
|
|
|
closed chan struct{}
|
|
|
|
}
|
|
|
|
|
2018-02-02 17:18:46 -05:00
|
|
|
func newNetworkAttacherController(b executorpkg.Backend, i executorpkg.ImageBackend, task *api.Task, node *api.NodeDescription, dependencies exec.DependencyGetter) (*networkAttacherController, error) {
|
|
|
|
adapter, err := newContainerAdapter(b, i, task, node, dependencies)
|
2016-08-23 19:50:15 -04:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return &networkAttacherController{
|
|
|
|
backend: b,
|
|
|
|
task: task,
|
|
|
|
adapter: adapter,
|
|
|
|
closed: make(chan struct{}),
|
|
|
|
}, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (nc *networkAttacherController) Update(ctx context.Context, t *api.Task) error {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (nc *networkAttacherController) Prepare(ctx context.Context) error {
|
|
|
|
// Make sure all the networks that the task needs are created.
|
2017-09-11 14:55:05 -04:00
|
|
|
return nc.adapter.createNetworks(ctx)
|
2016-08-23 19:50:15 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
func (nc *networkAttacherController) Start(ctx context.Context) error {
|
|
|
|
return nc.adapter.networkAttach(ctx)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (nc *networkAttacherController) Wait(pctx context.Context) error {
|
|
|
|
ctx, cancel := context.WithCancel(pctx)
|
|
|
|
defer cancel()
|
|
|
|
|
|
|
|
return nc.adapter.waitForDetach(ctx)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (nc *networkAttacherController) Shutdown(ctx context.Context) error {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (nc *networkAttacherController) Terminate(ctx context.Context) error {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (nc *networkAttacherController) Remove(ctx context.Context) error {
|
|
|
|
// Try removing the network referenced in this task in case this
|
|
|
|
// task is the last one referencing it
|
2017-09-11 14:55:05 -04:00
|
|
|
return nc.adapter.removeNetworks(ctx)
|
2016-08-23 19:50:15 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
func (nc *networkAttacherController) Close() error {
|
|
|
|
return nil
|
|
|
|
}
|