123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143 |
- /*
- 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 kuberuntime
- import (
- "k8s.io/api/core/v1"
- utilerrors "k8s.io/apimachinery/pkg/util/errors"
- runtimeapi "k8s.io/cri-api/pkg/apis/runtime/v1alpha2"
- "k8s.io/klog"
- credentialprovidersecrets "k8s.io/kubernetes/pkg/credentialprovider/secrets"
- kubecontainer "k8s.io/kubernetes/pkg/kubelet/container"
- "k8s.io/kubernetes/pkg/util/parsers"
- )
- // PullImage pulls an image from the network to local storage using the supplied
- // secrets if necessary.
- func (m *kubeGenericRuntimeManager) PullImage(image kubecontainer.ImageSpec, pullSecrets []v1.Secret, podSandboxConfig *runtimeapi.PodSandboxConfig) (string, error) {
- img := image.Image
- repoToPull, _, _, err := parsers.ParseImageName(img)
- if err != nil {
- return "", err
- }
- keyring, err := credentialprovidersecrets.MakeDockerKeyring(pullSecrets, m.keyring)
- if err != nil {
- return "", err
- }
- imgSpec := &runtimeapi.ImageSpec{Image: img}
- creds, withCredentials := keyring.Lookup(repoToPull)
- if !withCredentials {
- klog.V(3).Infof("Pulling image %q without credentials", img)
- imageRef, err := m.imageService.PullImage(imgSpec, nil, podSandboxConfig)
- if err != nil {
- klog.Errorf("Pull image %q failed: %v", img, err)
- return "", err
- }
- return imageRef, nil
- }
- var pullErrs []error
- for _, currentCreds := range creds {
- auth := &runtimeapi.AuthConfig{
- Username: currentCreds.Username,
- Password: currentCreds.Password,
- Auth: currentCreds.Auth,
- ServerAddress: currentCreds.ServerAddress,
- IdentityToken: currentCreds.IdentityToken,
- RegistryToken: currentCreds.RegistryToken,
- }
- imageRef, err := m.imageService.PullImage(imgSpec, auth, podSandboxConfig)
- // If there was no error, return success
- if err == nil {
- return imageRef, nil
- }
- pullErrs = append(pullErrs, err)
- }
- return "", utilerrors.NewAggregate(pullErrs)
- }
- // GetImageRef gets the ID of the image which has already been in
- // the local storage. It returns ("", nil) if the image isn't in the local storage.
- func (m *kubeGenericRuntimeManager) GetImageRef(image kubecontainer.ImageSpec) (string, error) {
- status, err := m.imageService.ImageStatus(&runtimeapi.ImageSpec{Image: image.Image})
- if err != nil {
- klog.Errorf("ImageStatus for image %q failed: %v", image, err)
- return "", err
- }
- if status == nil {
- return "", nil
- }
- return status.Id, nil
- }
- // ListImages gets all images currently on the machine.
- func (m *kubeGenericRuntimeManager) ListImages() ([]kubecontainer.Image, error) {
- var images []kubecontainer.Image
- allImages, err := m.imageService.ListImages(nil)
- if err != nil {
- klog.Errorf("ListImages failed: %v", err)
- return nil, err
- }
- for _, img := range allImages {
- images = append(images, kubecontainer.Image{
- ID: img.Id,
- Size: int64(img.Size_),
- RepoTags: img.RepoTags,
- RepoDigests: img.RepoDigests,
- })
- }
- return images, nil
- }
- // RemoveImage removes the specified image.
- func (m *kubeGenericRuntimeManager) RemoveImage(image kubecontainer.ImageSpec) error {
- err := m.imageService.RemoveImage(&runtimeapi.ImageSpec{Image: image.Image})
- if err != nil {
- klog.Errorf("Remove image %q failed: %v", image.Image, err)
- return err
- }
- return nil
- }
- // ImageStats returns the statistics of the image.
- // Notice that current logic doesn't really work for images which share layers (e.g. docker image),
- // this is a known issue, and we'll address this by getting imagefs stats directly from CRI.
- // TODO: Get imagefs stats directly from CRI.
- func (m *kubeGenericRuntimeManager) ImageStats() (*kubecontainer.ImageStats, error) {
- allImages, err := m.imageService.ListImages(nil)
- if err != nil {
- klog.Errorf("ListImages failed: %v", err)
- return nil, err
- }
- stats := &kubecontainer.ImageStats{}
- for _, img := range allImages {
- stats.TotalStorageBytes += img.Size_
- }
- return stats, nil
- }
|