aboutsummaryrefslogtreecommitdiff
path: root/vendor/k8s.io/kubernetes/pkg/kubelet/container/container_gc.go
diff options
context:
space:
mode:
Diffstat (limited to 'vendor/k8s.io/kubernetes/pkg/kubelet/container/container_gc.go')
-rw-r--r--vendor/k8s.io/kubernetes/pkg/kubelet/container/container_gc.go84
1 files changed, 84 insertions, 0 deletions
diff --git a/vendor/k8s.io/kubernetes/pkg/kubelet/container/container_gc.go b/vendor/k8s.io/kubernetes/pkg/kubelet/container/container_gc.go
new file mode 100644
index 000000000..be2fac4b9
--- /dev/null
+++ b/vendor/k8s.io/kubernetes/pkg/kubelet/container/container_gc.go
@@ -0,0 +1,84 @@
+/*
+Copyright 2014 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 container
+
+import (
+ "fmt"
+ "time"
+)
+
+// Specified a policy for garbage collecting containers.
+type ContainerGCPolicy struct {
+ // Minimum age at which a container can be garbage collected, zero for no limit.
+ MinAge time.Duration
+
+ // Max number of dead containers any single pod (UID, container name) pair is
+ // allowed to have, less than zero for no limit.
+ MaxPerPodContainer int
+
+ // Max number of total dead containers, less than zero for no limit.
+ MaxContainers int
+}
+
+// Manages garbage collection of dead containers.
+//
+// Implementation is thread-compatible.
+type ContainerGC interface {
+ // Garbage collect containers.
+ GarbageCollect() error
+ // Deletes all unused containers, including containers belonging to pods that are terminated but not deleted
+ DeleteAllUnusedContainers() error
+}
+
+// SourcesReadyProvider knows how to determine if configuration sources are ready
+type SourcesReadyProvider interface {
+ // AllReady returns true if the currently configured sources have all been seen.
+ AllReady() bool
+}
+
+// TODO(vmarmol): Preferentially remove pod infra containers.
+type realContainerGC struct {
+ // Container runtime
+ runtime Runtime
+
+ // Policy for garbage collection.
+ policy ContainerGCPolicy
+
+ // sourcesReadyProvider provides the readyness of kubelet configuration sources.
+ sourcesReadyProvider SourcesReadyProvider
+}
+
+// New ContainerGC instance with the specified policy.
+func NewContainerGC(runtime Runtime, policy ContainerGCPolicy, sourcesReadyProvider SourcesReadyProvider) (ContainerGC, error) {
+ if policy.MinAge < 0 {
+ return nil, fmt.Errorf("invalid minimum garbage collection age: %v", policy.MinAge)
+ }
+
+ return &realContainerGC{
+ runtime: runtime,
+ policy: policy,
+ sourcesReadyProvider: sourcesReadyProvider,
+ }, nil
+}
+
+func (cgc *realContainerGC) GarbageCollect() error {
+ return cgc.runtime.GarbageCollect(cgc.policy, cgc.sourcesReadyProvider.AllReady(), false)
+}
+
+func (cgc *realContainerGC) DeleteAllUnusedContainers() error {
+ return cgc.runtime.GarbageCollect(cgc.policy, cgc.sourcesReadyProvider.AllReady(), true)
+}