283 lines
11 KiB
Go
283 lines
11 KiB
Go
/*
|
|
Copyright 2017 The Kubernetes Authors.
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
You may obtain a copy of the License at
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
*/
|
|
|
|
package server
|
|
|
|
import (
|
|
"github.com/golang/glog"
|
|
"golang.org/x/net/context"
|
|
"k8s.io/kubernetes/pkg/kubelet/apis/cri/v1alpha1/runtime"
|
|
)
|
|
|
|
// instrumentedService wraps service and logs each operation.
|
|
type instrumentedService struct {
|
|
*criContainerdService
|
|
}
|
|
|
|
func newInstrumentedService(c *criContainerdService) CRIContainerdService {
|
|
return &instrumentedService{criContainerdService: c}
|
|
}
|
|
|
|
func (in *instrumentedService) RunPodSandbox(ctx context.Context, r *runtime.RunPodSandboxRequest) (res *runtime.RunPodSandboxResponse, err error) {
|
|
glog.V(2).Infof("RunPodSandbox with config %+v", r.GetConfig())
|
|
defer func() {
|
|
if err != nil {
|
|
glog.Errorf("RunPodSandbox for %+v failed, error: %v", r.GetConfig().GetMetadata(), err)
|
|
} else {
|
|
glog.V(2).Infof("RunPodSandbox for %+v returns sandbox id %q", r.GetConfig().GetMetadata(), res.GetPodSandboxId())
|
|
}
|
|
}()
|
|
return in.criContainerdService.RunPodSandbox(ctx, r)
|
|
}
|
|
|
|
func (in *instrumentedService) ListPodSandbox(ctx context.Context, r *runtime.ListPodSandboxRequest) (res *runtime.ListPodSandboxResponse, err error) {
|
|
glog.V(5).Infof("ListPodSandbox with filter %+v", r.GetFilter())
|
|
defer func() {
|
|
if err != nil {
|
|
glog.Errorf("ListPodSandbox failed, error: %v", err)
|
|
} else {
|
|
glog.V(5).Infof("ListPodSandbox returns sandboxes %+v", res.GetItems())
|
|
}
|
|
}()
|
|
return in.criContainerdService.ListPodSandbox(ctx, r)
|
|
}
|
|
|
|
func (in *instrumentedService) PodSandboxStatus(ctx context.Context, r *runtime.PodSandboxStatusRequest) (res *runtime.PodSandboxStatusResponse, err error) {
|
|
glog.V(5).Infof("PodSandboxStatus for %q", r.GetPodSandboxId())
|
|
defer func() {
|
|
if err != nil {
|
|
glog.Errorf("PodSandboxStatus for %q failed, error: %v", r.GetPodSandboxId(), err)
|
|
} else {
|
|
glog.V(5).Infof("PodSandboxStatus for %q returns status %+v", r.GetPodSandboxId(), res.GetStatus())
|
|
}
|
|
}()
|
|
return in.criContainerdService.PodSandboxStatus(ctx, r)
|
|
}
|
|
|
|
func (in *instrumentedService) StopPodSandbox(ctx context.Context, r *runtime.StopPodSandboxRequest) (_ *runtime.StopPodSandboxResponse, err error) {
|
|
glog.V(2).Infof("StopPodSandbox for %q", r.GetPodSandboxId())
|
|
defer func() {
|
|
if err != nil {
|
|
glog.Errorf("StopPodSandbox for %q failed, error: %v", r.GetPodSandboxId(), err)
|
|
} else {
|
|
glog.V(2).Infof("StopPodSandbox for %q returns successfully", r.GetPodSandboxId())
|
|
}
|
|
}()
|
|
return in.criContainerdService.StopPodSandbox(ctx, r)
|
|
}
|
|
|
|
func (in *instrumentedService) RemovePodSandbox(ctx context.Context, r *runtime.RemovePodSandboxRequest) (_ *runtime.RemovePodSandboxResponse, err error) {
|
|
glog.V(2).Infof("RemovePodSandbox for %q", r.GetPodSandboxId())
|
|
defer func() {
|
|
if err != nil {
|
|
glog.Errorf("RemovePodSandbox for %q failed, error: %v", r.GetPodSandboxId(), err)
|
|
} else {
|
|
glog.V(2).Infof("RemovePodSandbox %q returns successfully", r.GetPodSandboxId())
|
|
}
|
|
}()
|
|
return in.criContainerdService.RemovePodSandbox(ctx, r)
|
|
}
|
|
|
|
func (in *instrumentedService) PortForward(ctx context.Context, r *runtime.PortForwardRequest) (res *runtime.PortForwardResponse, err error) {
|
|
glog.V(2).Infof("Portforward for %q port %v", r.GetPodSandboxId(), r.GetPort())
|
|
defer func() {
|
|
if err != nil {
|
|
glog.Errorf("Portforward for %q failed, error: %v", r.GetPodSandboxId(), err)
|
|
} else {
|
|
glog.V(2).Infof("Portforward for %q returns URL %q", r.GetPodSandboxId(), res.GetUrl())
|
|
}
|
|
}()
|
|
return in.criContainerdService.PortForward(ctx, r)
|
|
}
|
|
|
|
func (in *instrumentedService) CreateContainer(ctx context.Context, r *runtime.CreateContainerRequest) (res *runtime.CreateContainerResponse, err error) {
|
|
glog.V(2).Infof("CreateContainer within sandbox %q with container config %+v and sandbox config %+v",
|
|
r.GetPodSandboxId(), r.GetConfig(), r.GetSandboxConfig())
|
|
defer func() {
|
|
if err != nil {
|
|
glog.Errorf("CreateContainer within sandbox %q for %+v failed, error: %v",
|
|
r.GetPodSandboxId(), r.GetConfig().GetMetadata(), err)
|
|
} else {
|
|
glog.V(2).Infof("CreateContainer within sandbox %q for %+v returns container id %q",
|
|
r.GetPodSandboxId(), r.GetConfig().GetMetadata(), res.GetContainerId())
|
|
}
|
|
}()
|
|
return in.criContainerdService.CreateContainer(ctx, r)
|
|
}
|
|
|
|
func (in *instrumentedService) StartContainer(ctx context.Context, r *runtime.StartContainerRequest) (_ *runtime.StartContainerResponse, err error) {
|
|
glog.V(2).Infof("StartContainer for %q", r.GetContainerId())
|
|
defer func() {
|
|
if err != nil {
|
|
glog.Errorf("StartContainer for %q failed, error: %v", r.GetContainerId(), err)
|
|
} else {
|
|
glog.V(2).Infof("StartContainer for %q returns successfully", r.GetContainerId())
|
|
}
|
|
}()
|
|
return in.criContainerdService.StartContainer(ctx, r)
|
|
}
|
|
|
|
func (in *instrumentedService) ListContainers(ctx context.Context, r *runtime.ListContainersRequest) (res *runtime.ListContainersResponse, err error) {
|
|
glog.V(5).Infof("ListContainers with filter %+v", r.GetFilter())
|
|
defer func() {
|
|
if err != nil {
|
|
glog.Errorf("ListContainers with filter %+v failed, error: %v", r.GetFilter(), err)
|
|
} else {
|
|
glog.V(5).Infof("ListContainers with filter %+v returns containers %+v",
|
|
r.GetFilter(), res.GetContainers())
|
|
}
|
|
}()
|
|
return in.criContainerdService.ListContainers(ctx, r)
|
|
}
|
|
|
|
func (in *instrumentedService) ContainerStatus(ctx context.Context, r *runtime.ContainerStatusRequest) (res *runtime.ContainerStatusResponse, err error) {
|
|
glog.V(5).Infof("ContainerStatus for %q", r.GetContainerId())
|
|
defer func() {
|
|
if err != nil {
|
|
glog.Errorf("ContainerStatus for %q failed, error: %v", r.GetContainerId(), err)
|
|
} else {
|
|
glog.V(5).Infof("ContainerStatus for %q returns status %+v", r.GetContainerId(), res.GetStatus())
|
|
}
|
|
}()
|
|
return in.criContainerdService.ContainerStatus(ctx, r)
|
|
}
|
|
|
|
func (in *instrumentedService) StopContainer(ctx context.Context, r *runtime.StopContainerRequest) (res *runtime.StopContainerResponse, err error) {
|
|
glog.V(2).Infof("StopContainer for %q with timeout %d (s)", r.GetContainerId(), r.GetTimeout())
|
|
defer func() {
|
|
if err != nil {
|
|
glog.Errorf("StopContainer for %q failed, error: %v", r.GetContainerId(), err)
|
|
} else {
|
|
glog.V(2).Infof("StopContainer for %q returns successfully", r.GetContainerId())
|
|
}
|
|
}()
|
|
return in.criContainerdService.StopContainer(ctx, r)
|
|
}
|
|
|
|
func (in *instrumentedService) RemoveContainer(ctx context.Context, r *runtime.RemoveContainerRequest) (res *runtime.RemoveContainerResponse, err error) {
|
|
glog.V(2).Infof("RemoveContainer for %q", r.GetContainerId())
|
|
defer func() {
|
|
if err != nil {
|
|
glog.Errorf("RemoveContainer for %q failed, error: %v", r.GetContainerId(), err)
|
|
} else {
|
|
glog.V(2).Infof("RemoveContainer for %q returns successfully", r.GetContainerId())
|
|
}
|
|
}()
|
|
return in.criContainerdService.RemoveContainer(ctx, r)
|
|
}
|
|
|
|
func (in *instrumentedService) ExecSync(ctx context.Context, r *runtime.ExecSyncRequest) (res *runtime.ExecSyncResponse, err error) {
|
|
glog.V(2).Infof("ExecSync for %q with command %+v and timeout %d (s)", r.GetContainerId(), r.GetCmd(), r.GetTimeout())
|
|
defer func() {
|
|
if err != nil {
|
|
glog.Errorf("ExecSync for %q failed, error: %v", r.GetContainerId(), err)
|
|
} else {
|
|
glog.V(2).Infof("ExecSync for %q returns with exit code %d", r.GetContainerId(), res.GetExitCode())
|
|
glog.V(4).Infof("ExecSync for %q outputs - stdout: %q, stderr: %q", r.GetContainerId(),
|
|
res.GetStdout(), res.GetStderr())
|
|
}
|
|
}()
|
|
return in.criContainerdService.ExecSync(ctx, r)
|
|
}
|
|
|
|
func (in *instrumentedService) Exec(ctx context.Context, r *runtime.ExecRequest) (res *runtime.ExecResponse, err error) {
|
|
glog.V(2).Infof("Exec for %q with command %+v, tty %v and stdin %v",
|
|
r.GetContainerId(), r.GetCmd(), r.GetTty(), r.GetStdin())
|
|
defer func() {
|
|
if err != nil {
|
|
glog.Errorf("Exec for %q failed, error: %v", r.GetContainerId(), err)
|
|
} else {
|
|
glog.V(2).Infof("Exec for %q returns URL %q", r.GetContainerId(), res.GetUrl())
|
|
}
|
|
}()
|
|
return in.criContainerdService.Exec(ctx, r)
|
|
}
|
|
|
|
func (in *instrumentedService) Attach(ctx context.Context, r *runtime.AttachRequest) (res *runtime.AttachResponse, err error) {
|
|
glog.V(2).Infof("Attach for %q with tty %v and stdin %v", r.GetContainerId(), r.GetTty(), r.GetStdin())
|
|
defer func() {
|
|
if err != nil {
|
|
glog.Errorf("Attach for %q failed, error: %v", r.GetContainerId(), err)
|
|
} else {
|
|
glog.V(2).Infof("Attach for %q returns URL %q", r.GetContainerId(), res.Url)
|
|
}
|
|
}()
|
|
return in.criContainerdService.Attach(ctx, r)
|
|
}
|
|
|
|
func (in *instrumentedService) UpdateContainerResources(ctx context.Context, r *runtime.UpdateContainerResourcesRequest) (res *runtime.UpdateContainerResourcesResponse, err error) {
|
|
glog.V(2).Infof("UpdateContainerResources for %q with %+v", r.GetContainerId(), r.GetLinux())
|
|
defer func() {
|
|
if err != nil {
|
|
glog.Errorf("UpdateContainerResources for %q failed, error: %v", r.GetContainerId(), err)
|
|
} else {
|
|
glog.V(2).Infof("UpdateContainerResources for %q returns successfully", r.GetContainerId())
|
|
}
|
|
}()
|
|
return in.criContainerdService.UpdateContainerResources(ctx, r)
|
|
}
|
|
|
|
func (in *instrumentedService) PullImage(ctx context.Context, r *runtime.PullImageRequest) (res *runtime.PullImageResponse, err error) {
|
|
glog.V(2).Infof("PullImage %q with auth config %+v", r.GetImage().GetImage(), r.GetAuth())
|
|
defer func() {
|
|
if err != nil {
|
|
glog.Errorf("PullImage %q failed, error: %v", r.GetImage().GetImage(), err)
|
|
} else {
|
|
glog.V(2).Infof("PullImage %q returns image reference %q",
|
|
r.GetImage().GetImage(), res.GetImageRef())
|
|
}
|
|
}()
|
|
return in.criContainerdService.PullImage(ctx, r)
|
|
}
|
|
|
|
func (in *instrumentedService) ListImages(ctx context.Context, r *runtime.ListImagesRequest) (res *runtime.ListImagesResponse, err error) {
|
|
glog.V(5).Infof("ListImages with filter %+v", r.GetFilter())
|
|
defer func() {
|
|
if err != nil {
|
|
glog.Errorf("ListImages with filter %+v failed, error: %v", r.GetFilter(), err)
|
|
} else {
|
|
glog.V(5).Infof("ListImages with filter %+v returns image list %+v",
|
|
r.GetFilter(), res.GetImages())
|
|
}
|
|
}()
|
|
return in.criContainerdService.ListImages(ctx, r)
|
|
}
|
|
|
|
func (in *instrumentedService) ImageStatus(ctx context.Context, r *runtime.ImageStatusRequest) (res *runtime.ImageStatusResponse, err error) {
|
|
glog.V(5).Infof("ImageStatus for %q", r.GetImage().GetImage())
|
|
defer func() {
|
|
if err != nil {
|
|
glog.Errorf("ImageStatus for %q failed, error: %v", r.GetImage().GetImage(), err)
|
|
} else {
|
|
glog.V(5).Infof("ImageStatus for %q returns image status %+v",
|
|
r.GetImage().GetImage(), res.GetImage())
|
|
}
|
|
}()
|
|
return in.criContainerdService.ImageStatus(ctx, r)
|
|
}
|
|
|
|
func (in *instrumentedService) RemoveImage(ctx context.Context, r *runtime.RemoveImageRequest) (_ *runtime.RemoveImageResponse, err error) {
|
|
glog.V(2).Infof("RemoveImage %q", r.GetImage().GetImage())
|
|
defer func() {
|
|
if err != nil {
|
|
glog.Errorf("RemoveImage %q failed, error: %v", r.GetImage().GetImage(), err)
|
|
} else {
|
|
glog.V(2).Infof("RemoveImage %q returns successfully", r.GetImage().GetImage())
|
|
}
|
|
}()
|
|
return in.criContainerdService.RemoveImage(ctx, r)
|
|
}
|