mirror of https://github.com/k3s-io/k3s
118 lines
6.5 KiB
Go
118 lines
6.5 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 config
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"github.com/spf13/pflag"
|
|
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
|
|
)
|
|
|
|
// ContainerRuntimeOptions defines options for the container runtime.
|
|
type ContainerRuntimeOptions struct {
|
|
// General Options.
|
|
|
|
// ContainerRuntime is the container runtime to use.
|
|
ContainerRuntime string
|
|
// RuntimeCgroups that container runtime is expected to be isolated in.
|
|
RuntimeCgroups string
|
|
|
|
// Docker-specific options.
|
|
|
|
// DockershimRootDirectory is the path to the dockershim root directory. Defaults to
|
|
// /var/lib/dockershim if unset. Exposed for integration testing (e.g. in OpenShift).
|
|
DockershimRootDirectory string
|
|
// PodSandboxImage is the image whose network/ipc namespaces
|
|
// containers in each pod will use.
|
|
PodSandboxImage string
|
|
// DockerEndpoint is the path to the docker endpoint to communicate with.
|
|
DockerEndpoint string
|
|
// If no pulling progress is made before the deadline imagePullProgressDeadline,
|
|
// the image pulling will be cancelled. Defaults to 1m0s.
|
|
// +optional
|
|
ImagePullProgressDeadline metav1.Duration
|
|
|
|
// Network plugin options.
|
|
|
|
// networkPluginName is the name of the network plugin to be invoked for
|
|
// various events in kubelet/pod lifecycle
|
|
NetworkPluginName string
|
|
// NetworkPluginMTU is the MTU to be passed to the network plugin,
|
|
// and overrides the default MTU for cases where it cannot be automatically
|
|
// computed (such as IPSEC).
|
|
NetworkPluginMTU int32
|
|
// CNIConfDir is the full path of the directory in which to search for
|
|
// CNI config files
|
|
CNIConfDir string
|
|
// CNIBinDir is the full path of the directory in which to search for
|
|
// CNI plugin binaries
|
|
CNIBinDir string
|
|
// CNICacheDir is the full path of the directory in which CNI should store
|
|
// cache files
|
|
CNICacheDir string
|
|
|
|
// Image credential provider plugin options
|
|
|
|
// ImageCredentialProviderConfigFile is the path to the credential provider plugin config file.
|
|
// This config file is a specification for what credential providers are enabled and invokved
|
|
// by the kubelet. The plugin config should contain information about what plugin binary
|
|
// to execute and what container images the plugin should be called for.
|
|
// +optional
|
|
ImageCredentialProviderConfigFile string
|
|
// ImageCredentialProviderBinDir is the path to the directory where credential provider plugin
|
|
// binaries exist. The name of each plugin binary is expected to match the name of the plugin
|
|
// specified in imageCredentialProviderConfigFile.
|
|
// +optional
|
|
ImageCredentialProviderBinDir string
|
|
}
|
|
|
|
// AddFlags adds flags to the container runtime, according to ContainerRuntimeOptions.
|
|
func (s *ContainerRuntimeOptions) AddFlags(fs *pflag.FlagSet) {
|
|
dockerOnlyWarning := "This docker-specific flag only works when container-runtime is set to docker."
|
|
|
|
// General settings.
|
|
fs.StringVar(&s.ContainerRuntime, "container-runtime", s.ContainerRuntime, "The container runtime to use. Possible values: 'docker', 'remote'.")
|
|
fs.StringVar(&s.RuntimeCgroups, "runtime-cgroups", s.RuntimeCgroups, "Optional absolute name of cgroups to create and run the runtime in.")
|
|
|
|
// Docker-specific settings.
|
|
fs.StringVar(&s.DockershimRootDirectory, "experimental-dockershim-root-directory", s.DockershimRootDirectory, "Path to the dockershim root directory.")
|
|
fs.MarkHidden("experimental-dockershim-root-directory")
|
|
fs.StringVar(&s.PodSandboxImage, "pod-infra-container-image", s.PodSandboxImage, fmt.Sprintf("Specified image will not be pruned by the image garbage collector. "+
|
|
"When container-runtime is set to 'docker', all containers in each pod will use the network/ipc namespaces from this image. Other CRI implementations have their own configuration to set this image."))
|
|
fs.StringVar(&s.DockerEndpoint, "docker-endpoint", s.DockerEndpoint, fmt.Sprintf("Use this for the docker endpoint to communicate with. %s", dockerOnlyWarning))
|
|
fs.MarkDeprecated("docker-endpoint", "will be removed along with dockershim.")
|
|
fs.DurationVar(&s.ImagePullProgressDeadline.Duration, "image-pull-progress-deadline", s.ImagePullProgressDeadline.Duration, fmt.Sprintf("If no pulling progress is made before this deadline, the image pulling will be cancelled. %s", dockerOnlyWarning))
|
|
fs.MarkDeprecated("image-pull-progress-deadline", "will be removed along with dockershim.")
|
|
|
|
// Network plugin settings for Docker.
|
|
fs.StringVar(&s.NetworkPluginName, "network-plugin", s.NetworkPluginName, fmt.Sprintf("The name of the network plugin to be invoked for various events in kubelet/pod lifecycle. %s", dockerOnlyWarning))
|
|
fs.MarkDeprecated("network-plugin", "will be removed along with dockershim.")
|
|
fs.StringVar(&s.CNIConfDir, "cni-conf-dir", s.CNIConfDir, fmt.Sprintf("The full path of the directory in which to search for CNI config files. %s", dockerOnlyWarning))
|
|
fs.MarkDeprecated("cni-conf-dir", "will be removed along with dockershim.")
|
|
fs.StringVar(&s.CNIBinDir, "cni-bin-dir", s.CNIBinDir, fmt.Sprintf("A comma-separated list of full paths of directories in which to search for CNI plugin binaries. %s", dockerOnlyWarning))
|
|
fs.MarkDeprecated("cni-bin-dir", "will be removed along with dockershim.")
|
|
fs.StringVar(&s.CNICacheDir, "cni-cache-dir", s.CNICacheDir, fmt.Sprintf("The full path of the directory in which CNI should store cache files. %s", dockerOnlyWarning))
|
|
fs.MarkDeprecated("cni-cache-dir", "will be removed along with dockershim.")
|
|
fs.Int32Var(&s.NetworkPluginMTU, "network-plugin-mtu", s.NetworkPluginMTU, fmt.Sprintf("The MTU to be passed to the network plugin, to override the default. Set to 0 to use the default 1460 MTU. %s", dockerOnlyWarning))
|
|
fs.MarkDeprecated("network-plugin-mtu", "will be removed along with dockershim.")
|
|
|
|
// Image credential provider settings.
|
|
fs.StringVar(&s.ImageCredentialProviderConfigFile, "image-credential-provider-config", s.ImageCredentialProviderConfigFile, "The path to the credential provider plugin config file.")
|
|
fs.StringVar(&s.ImageCredentialProviderBinDir, "image-credential-provider-bin-dir", s.ImageCredentialProviderBinDir, "The path to the directory where credential provider plugin binaries are located.")
|
|
}
|