123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156 |
- /*
- Copyright 2016 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 remote
- import (
- "context"
- "errors"
- "fmt"
- "time"
- "google.golang.org/grpc"
- "k8s.io/klog"
- internalapi "k8s.io/cri-api/pkg/apis"
- runtimeapi "k8s.io/cri-api/pkg/apis/runtime/v1alpha2"
- "k8s.io/kubernetes/pkg/kubelet/util"
- )
- // RemoteImageService is a gRPC implementation of internalapi.ImageManagerService.
- type RemoteImageService struct {
- timeout time.Duration
- imageClient runtimeapi.ImageServiceClient
- }
- // NewRemoteImageService creates a new internalapi.ImageManagerService.
- func NewRemoteImageService(endpoint string, connectionTimeout time.Duration) (internalapi.ImageManagerService, error) {
- klog.V(3).Infof("Connecting to image service %s", endpoint)
- addr, dialer, err := util.GetAddressAndDialer(endpoint)
- if err != nil {
- return nil, err
- }
- ctx, cancel := context.WithTimeout(context.Background(), connectionTimeout)
- defer cancel()
- conn, err := grpc.DialContext(ctx, addr, grpc.WithInsecure(), grpc.WithContextDialer(dialer), grpc.WithDefaultCallOptions(grpc.MaxCallRecvMsgSize(maxMsgSize)))
- if err != nil {
- klog.Errorf("Connect remote image service %s failed: %v", addr, err)
- return nil, err
- }
- return &RemoteImageService{
- timeout: connectionTimeout,
- imageClient: runtimeapi.NewImageServiceClient(conn),
- }, nil
- }
- // ListImages lists available images.
- func (r *RemoteImageService) ListImages(filter *runtimeapi.ImageFilter) ([]*runtimeapi.Image, error) {
- ctx, cancel := getContextWithTimeout(r.timeout)
- defer cancel()
- resp, err := r.imageClient.ListImages(ctx, &runtimeapi.ListImagesRequest{
- Filter: filter,
- })
- if err != nil {
- klog.Errorf("ListImages with filter %+v from image service failed: %v", filter, err)
- return nil, err
- }
- return resp.Images, nil
- }
- // ImageStatus returns the status of the image.
- func (r *RemoteImageService) ImageStatus(image *runtimeapi.ImageSpec) (*runtimeapi.Image, error) {
- ctx, cancel := getContextWithTimeout(r.timeout)
- defer cancel()
- resp, err := r.imageClient.ImageStatus(ctx, &runtimeapi.ImageStatusRequest{
- Image: image,
- })
- if err != nil {
- klog.Errorf("ImageStatus %q from image service failed: %v", image.Image, err)
- return nil, err
- }
- if resp.Image != nil {
- if resp.Image.Id == "" || resp.Image.Size_ == 0 {
- errorMessage := fmt.Sprintf("Id or size of image %q is not set", image.Image)
- klog.Errorf("ImageStatus failed: %s", errorMessage)
- return nil, errors.New(errorMessage)
- }
- }
- return resp.Image, nil
- }
- // PullImage pulls an image with authentication config.
- func (r *RemoteImageService) PullImage(image *runtimeapi.ImageSpec, auth *runtimeapi.AuthConfig, podSandboxConfig *runtimeapi.PodSandboxConfig) (string, error) {
- ctx, cancel := getContextWithCancel()
- defer cancel()
- resp, err := r.imageClient.PullImage(ctx, &runtimeapi.PullImageRequest{
- Image: image,
- Auth: auth,
- SandboxConfig: podSandboxConfig,
- })
- if err != nil {
- klog.Errorf("PullImage %q from image service failed: %v", image.Image, err)
- return "", err
- }
- if resp.ImageRef == "" {
- errorMessage := fmt.Sprintf("imageRef of image %q is not set", image.Image)
- klog.Errorf("PullImage failed: %s", errorMessage)
- return "", errors.New(errorMessage)
- }
- return resp.ImageRef, nil
- }
- // RemoveImage removes the image.
- func (r *RemoteImageService) RemoveImage(image *runtimeapi.ImageSpec) error {
- ctx, cancel := getContextWithTimeout(r.timeout)
- defer cancel()
- _, err := r.imageClient.RemoveImage(ctx, &runtimeapi.RemoveImageRequest{
- Image: image,
- })
- if err != nil {
- klog.Errorf("RemoveImage %q from image service failed: %v", image.Image, err)
- return err
- }
- return nil
- }
- // ImageFsInfo returns information of the filesystem that is used to store images.
- func (r *RemoteImageService) ImageFsInfo() ([]*runtimeapi.FilesystemUsage, error) {
- // Do not set timeout, because `ImageFsInfo` takes time.
- // TODO(random-liu): Should we assume runtime should cache the result, and set timeout here?
- ctx, cancel := getContextWithCancel()
- defer cancel()
- resp, err := r.imageClient.ImageFsInfo(ctx, &runtimeapi.ImageFsInfoRequest{})
- if err != nil {
- klog.Errorf("ImageFsInfo from image service failed: %v", err)
- return nil, err
- }
- return resp.GetImageFilesystems(), nil
- }
|