333 lines
		
	
	
		
			13 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			333 lines
		
	
	
		
			13 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"
 | 
						|
 | 
						|
	api "github.com/kubernetes-incubator/cri-containerd/pkg/api/v1"
 | 
						|
)
 | 
						|
 | 
						|
// 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)
 | 
						|
}
 | 
						|
 | 
						|
func (in *instrumentedService) ImageFsInfo(ctx context.Context, r *runtime.ImageFsInfoRequest) (res *runtime.ImageFsInfoResponse, err error) {
 | 
						|
	glog.V(4).Infof("ImageFsInfo")
 | 
						|
	defer func() {
 | 
						|
		if err != nil {
 | 
						|
			glog.Errorf("ImageFsInfo failed, error: %v", err)
 | 
						|
		} else {
 | 
						|
			glog.V(4).Infof("ImageFsInfo returns filesystem info %+v", res.ImageFilesystems)
 | 
						|
		}
 | 
						|
	}()
 | 
						|
	return in.criContainerdService.ImageFsInfo(ctx, r)
 | 
						|
}
 | 
						|
 | 
						|
func (in *instrumentedService) ContainerStats(ctx context.Context, r *runtime.ContainerStatsRequest) (res *runtime.ContainerStatsResponse, err error) {
 | 
						|
	glog.V(4).Infof("ContainerStats for %q", r.GetContainerId())
 | 
						|
	defer func() {
 | 
						|
		if err != nil {
 | 
						|
			glog.Errorf("ContainerStats for %q failed, error: %v", r.GetContainerId(), err)
 | 
						|
		} else {
 | 
						|
			glog.V(4).Infof("ContainerStats for %q returns stats %+v", r.GetContainerId(), res.GetStats())
 | 
						|
		}
 | 
						|
	}()
 | 
						|
	return in.criContainerdService.ContainerStats(ctx, r)
 | 
						|
}
 | 
						|
 | 
						|
func (in *instrumentedService) ListContainerStats(ctx context.Context, r *runtime.ListContainerStatsRequest) (res *runtime.ListContainerStatsResponse, err error) {
 | 
						|
	glog.V(5).Infof("ListContainerStats with filter %+v", r.GetFilter())
 | 
						|
	defer func() {
 | 
						|
		if err != nil {
 | 
						|
			glog.Errorf("ListContainerStats failed, error: %v", err)
 | 
						|
		} else {
 | 
						|
			glog.V(5).Infof("ListContainerStats returns stats %+v", res.GetStats())
 | 
						|
		}
 | 
						|
	}()
 | 
						|
	return in.criContainerdService.ListContainerStats(ctx, r)
 | 
						|
}
 | 
						|
 | 
						|
func (in *instrumentedService) LoadImage(ctx context.Context, r *api.LoadImageRequest) (res *api.LoadImageResponse, err error) {
 | 
						|
	glog.V(4).Infof("LoadImage from file %q", r.GetFilePath())
 | 
						|
	defer func() {
 | 
						|
		if err != nil {
 | 
						|
			glog.Errorf("LoadImage failed, error: %v", err)
 | 
						|
		} else {
 | 
						|
			glog.V(4).Infof("LoadImage returns images %+v", res.GetImages())
 | 
						|
		}
 | 
						|
	}()
 | 
						|
	return in.criContainerdService.LoadImage(ctx, r)
 | 
						|
}
 |