Update containerd to 1.3.9

PiperOrigin-RevId: 345564927
This commit is contained in:
Fabricio Voznika 2020-12-03 16:53:22 -08:00 committed by gVisor bot
parent cae3149b2a
commit 9eb77281c4
6 changed files with 58 additions and 25 deletions

View File

@ -57,8 +57,8 @@ steps:
label: ":person_in_lotus_position: KVM tests" label: ":person_in_lotus_position: KVM tests"
command: make kvm-tests command: make kvm-tests
- <<: *common - <<: *common
label: ":docker: Containerd 1.3.4 tests" label: ":docker: Containerd 1.3.9 tests"
command: make containerd-test-1.3.4 command: make containerd-test-1.3.9
- <<: *common - <<: *common
label: ":docker: Containerd 1.4.1 tests" label: ":docker: Containerd 1.4.1 tests"
command: make containerd-test-1.4.1 command: make containerd-test-1.4.1

View File

@ -151,7 +151,7 @@ tests: unit-tests syscall-tests
integration-tests: ## Run all standard integration tests. integration-tests: ## Run all standard integration tests.
integration-tests: docker-tests overlay-tests hostnet-tests swgso-tests integration-tests: docker-tests overlay-tests hostnet-tests swgso-tests
integration-tests: do-tests kvm-tests containerd-test-1.3.4 integration-tests: do-tests kvm-tests containerd-test-1.3.9
.PHONY: integration-tests .PHONY: integration-tests
network-tests: ## Run all networking integration tests. network-tests: ## Run all networking integration tests.
@ -261,7 +261,7 @@ containerd-test-%: load-basic_alpine load-basic_python load-basic_busybox load-b
# actually drive the tests. The v1 API is tested exclusively through 1.2.13. # actually drive the tests. The v1 API is tested exclusively through 1.2.13.
containerd-tests: ## Runs all supported containerd version tests. containerd-tests: ## Runs all supported containerd version tests.
containerd-tests: containerd-test-1.2.13 containerd-tests: containerd-test-1.2.13
containerd-tests: containerd-test-1.3.4 containerd-tests: containerd-test-1.3.9
containerd-tests: containerd-test-1.4.0-beta.0 containerd-tests: containerd-test-1.4.0-beta.0
## ##

View File

@ -193,8 +193,8 @@ go_repository(
name = "com_github_containerd_containerd", name = "com_github_containerd_containerd",
build_file_proto_mode = "disable", build_file_proto_mode = "disable",
importpath = "github.com/containerd/containerd", importpath = "github.com/containerd/containerd",
sum = "h1:3o0smo5SKY7H6AJCmJhsnCjR2/V2T8VmiHt7seN2/kI=", sum = "h1:K2U/F4jGAMBqeUssfgJRbFuomLcS2Fxo1vR3UM/Mbh8=",
version = "v1.3.4", version = "v1.3.9",
) )
go_repository( go_repository(

2
go.mod
View File

@ -11,7 +11,7 @@ require (
github.com/cenkalti/backoff v1.1.1-0.20190506075156-2146c9339422 // indirect github.com/cenkalti/backoff v1.1.1-0.20190506075156-2146c9339422 // indirect
github.com/cilium/ebpf v0.0.0-20200110133405-4032b1d8aae3 // indirect github.com/cilium/ebpf v0.0.0-20200110133405-4032b1d8aae3 // indirect
github.com/containerd/cgroups v0.0.0-20181219155423-39b18af02c41 // indirect github.com/containerd/cgroups v0.0.0-20181219155423-39b18af02c41 // indirect
github.com/containerd/containerd v1.3.4 // indirect github.com/containerd/containerd v1.3.9 // indirect
github.com/containerd/continuity v0.0.0-20200928162600-f2cc35102c2a // indirect github.com/containerd/continuity v0.0.0-20200928162600-f2cc35102c2a // indirect
github.com/containerd/fifo v0.0.0-20191213151349-ff969a566b00 // indirect github.com/containerd/fifo v0.0.0-20191213151349-ff969a566b00 // indirect
github.com/containerd/go-runc v0.0.0-20200220073739-7016d3ce2328 // indirect github.com/containerd/go-runc v0.0.0-20200220073739-7016d3ce2328 // indirect

4
go.sum
View File

@ -54,9 +54,7 @@ github.com/containerd/cgroups v0.0.0-20200531161412-0dbf7f05ba59/go.mod h1:pA0z1
github.com/containerd/console v0.0.0-20180822173158-c12b1e7919c1/go.mod h1:Tj/on1eG8kiEhd0+fhSDzsPAFESxzBBvdyEgyryXffw= github.com/containerd/console v0.0.0-20180822173158-c12b1e7919c1/go.mod h1:Tj/on1eG8kiEhd0+fhSDzsPAFESxzBBvdyEgyryXffw=
github.com/containerd/console v0.0.0-20191206165004-02ecf6a7291e h1:GdiIYd8ZDOrT++e1NjhSD4rGt9zaJukHm4rt5F4mRQc= github.com/containerd/console v0.0.0-20191206165004-02ecf6a7291e h1:GdiIYd8ZDOrT++e1NjhSD4rGt9zaJukHm4rt5F4mRQc=
github.com/containerd/console v0.0.0-20191206165004-02ecf6a7291e/go.mod h1:8Pf4gM6VEbTNRIT26AyyU7hxdQU3MvAvxVI0sc00XBE= github.com/containerd/console v0.0.0-20191206165004-02ecf6a7291e/go.mod h1:8Pf4gM6VEbTNRIT26AyyU7hxdQU3MvAvxVI0sc00XBE=
github.com/containerd/containerd v1.3.2/go.mod h1:bC6axHOhabU15QhwfG7w5PipXdVtMXFTttgp+kVtyUA= github.com/containerd/containerd v1.3.9/go.mod h1:bC6axHOhabU15QhwfG7w5PipXdVtMXFTttgp+kVtyUA=
github.com/containerd/containerd v1.3.4 h1:3o0smo5SKY7H6AJCmJhsnCjR2/V2T8VmiHt7seN2/kI=
github.com/containerd/containerd v1.3.4/go.mod h1:bC6axHOhabU15QhwfG7w5PipXdVtMXFTttgp+kVtyUA=
github.com/containerd/continuity v0.0.0-20190426062206-aaeac12a7ffc/go.mod h1:GL3xCUCBDV3CZiTSEKksMWbLE66hEyuu9qyDOOqM47Y= github.com/containerd/continuity v0.0.0-20190426062206-aaeac12a7ffc/go.mod h1:GL3xCUCBDV3CZiTSEKksMWbLE66hEyuu9qyDOOqM47Y=
github.com/containerd/continuity v0.0.0-20200928162600-f2cc35102c2a h1:jEIoR0aA5GogXZ8pP3DUzE+zrhaF6/1rYZy+7KkYEWM= github.com/containerd/continuity v0.0.0-20200928162600-f2cc35102c2a h1:jEIoR0aA5GogXZ8pP3DUzE+zrhaF6/1rYZy+7KkYEWM=
github.com/containerd/continuity v0.0.0-20200928162600-f2cc35102c2a/go.mod h1:W0qIOTD7mp2He++YVq+kgfXezRYqzP1uDuMVH1bITDY= github.com/containerd/continuity v0.0.0-20200928162600-f2cc35102c2a/go.mod h1:W0qIOTD7mp2He++YVq+kgfXezRYqzP1uDuMVH1bITDY=

View File

@ -67,9 +67,15 @@ var (
var _ = (taskAPI.TaskService)(&service{}) var _ = (taskAPI.TaskService)(&service{})
// configFile is the default config file name. For containerd 1.2, const (
// we assume that a config.toml should exist in the runtime root. // configFile is the default config file name. For containerd 1.2,
const configFile = "config.toml" // we assume that a config.toml should exist in the runtime root.
configFile = "config.toml"
// shimAddressPath is the relative path to a file that contains the address
// to the shim UDS. See service.shimAddress.
shimAddressPath = "address"
)
// New returns a new shim service that can be used via GRPC. // New returns a new shim service that can be used via GRPC.
func New(ctx context.Context, id string, publisher shim.Publisher, cancel func()) (shim.Shim, error) { func New(ctx context.Context, id string, publisher shim.Publisher, cancel func()) (shim.Shim, error) {
@ -101,6 +107,11 @@ func New(ctx context.Context, id string, publisher shim.Publisher, cancel func()
return nil, fmt.Errorf("failed to initialized platform behavior: %w", err) return nil, fmt.Errorf("failed to initialized platform behavior: %w", err)
} }
go s.forward(ctx, publisher) go s.forward(ctx, publisher)
if address, err := shim.ReadAddress(shimAddressPath); err == nil {
s.shimAddress = address
}
return s, nil return s, nil
} }
@ -152,6 +163,9 @@ type service struct {
// cancel is a function that needs to be called before the shim stops. The // cancel is a function that needs to be called before the shim stops. The
// function is provided by the caller to New(). // function is provided by the caller to New().
cancel func() cancel func()
// shimAddress is the location of the UDS used to communicate to containerd.
shimAddress string
} }
func (s *service) newCommand(ctx context.Context, containerdBinary, containerdAddress string) (*exec.Cmd, error) { func (s *service) newCommand(ctx context.Context, containerdBinary, containerdAddress string) (*exec.Cmd, error) {
@ -191,38 +205,58 @@ func (s *service) StartShim(ctx context.Context, id, containerdBinary, container
if err != nil { if err != nil {
return "", err return "", err
} }
address, err := shim.SocketAddress(ctx, id) address, err := shim.SocketAddress(ctx, containerdAddress, id)
if err != nil { if err != nil {
return "", err return "", err
} }
socket, err := shim.NewSocket(address) socket, err := shim.NewSocket(address)
if err != nil { if err != nil {
return "", err // The only time where this would happen is if there is a bug and the socket
// was not cleaned up in the cleanup method of the shim or we are using the
// grouping functionality where the new process should be run with the same
// shim as an existing container.
if !shim.SocketEaddrinuse(err) {
return "", fmt.Errorf("create new shim socket: %w", err)
}
if shim.CanConnect(address) {
if err := shim.WriteAddress(shimAddressPath, address); err != nil {
return "", fmt.Errorf("write existing socket for shim: %w", err)
}
return address, nil
}
if err := shim.RemoveSocket(address); err != nil {
return "", fmt.Errorf("remove pre-existing socket: %w", err)
}
if socket, err = shim.NewSocket(address); err != nil {
return "", fmt.Errorf("try create new shim socket 2x: %w", err)
}
} }
defer socket.Close() cu := cleanup.Make(func() {
socket.Close()
_ = shim.RemoveSocket(address)
})
defer cu.Clean()
f, err := socket.File() f, err := socket.File()
if err != nil { if err != nil {
return "", err return "", err
} }
defer f.Close()
cmd.ExtraFiles = append(cmd.ExtraFiles, f) cmd.ExtraFiles = append(cmd.ExtraFiles, f)
log.L.Debugf("Executing: %q %s", cmd.Path, cmd.Args) log.L.Debugf("Executing: %q %s", cmd.Path, cmd.Args)
if err := cmd.Start(); err != nil { if err := cmd.Start(); err != nil {
f.Close()
return "", err return "", err
} }
cu := cleanup.Make(func() { cu.Add(func() { cmd.Process.Kill() })
cmd.Process.Kill()
})
defer cu.Clean()
// make sure to wait after start // make sure to wait after start
go cmd.Wait() go cmd.Wait()
if err := shim.WritePidFile("shim.pid", cmd.Process.Pid); err != nil { if err := shim.WritePidFile("shim.pid", cmd.Process.Pid); err != nil {
return "", err return "", err
} }
if err := shim.WriteAddress("address", address); err != nil { if err := shim.WriteAddress(shimAddressPath, address); err != nil {
return "", err return "", err
} }
if err := shim.SetScore(cmd.Process.Pid); err != nil { if err := shim.SetScore(cmd.Process.Pid); err != nil {
@ -675,8 +709,11 @@ func (s *service) Connect(ctx context.Context, r *taskAPI.ConnectRequest) (*task
func (s *service) Shutdown(ctx context.Context, r *taskAPI.ShutdownRequest) (*types.Empty, error) { func (s *service) Shutdown(ctx context.Context, r *taskAPI.ShutdownRequest) (*types.Empty, error) {
log.L.Debugf("Shutdown, id: %s", r.ID) log.L.Debugf("Shutdown, id: %s", r.ID)
s.cancel() s.cancel()
if s.shimAddress != "" {
_ = shim.RemoveSocket(s.shimAddress)
}
os.Exit(0) os.Exit(0)
return empty, nil panic("Should not get here")
} }
func (s *service) Stats(ctx context.Context, r *taskAPI.StatsRequest) (*taskAPI.StatsResponse, error) { func (s *service) Stats(ctx context.Context, r *taskAPI.StatsRequest) (*taskAPI.StatsResponse, error) {
@ -843,9 +880,7 @@ func (s *service) getContainerPids(ctx context.Context, id string) ([]uint32, er
func (s *service) forward(ctx context.Context, publisher shim.Publisher) { func (s *service) forward(ctx context.Context, publisher shim.Publisher) {
for e := range s.events { for e := range s.events {
ctx, cancel := context.WithTimeout(ctx, 5*time.Second)
err := publisher.Publish(ctx, getTopic(e), e) err := publisher.Publish(ctx, getTopic(e), e)
cancel()
if err != nil { if err != nil {
// Should not happen. // Should not happen.
panic(fmt.Errorf("post event: %w", err)) panic(fmt.Errorf("post event: %w", err))