2019-01-12 04:58:27 +00:00
|
|
|
/*
|
|
|
|
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"
|
|
|
|
|
2020-08-10 17:43:49 +00:00
|
|
|
"k8s.io/klog/v2"
|
2019-01-12 04:58:27 +00:00
|
|
|
)
|
|
|
|
|
2020-08-10 17:43:49 +00:00
|
|
|
// GCPolicy specifies a policy for garbage collecting containers.
|
|
|
|
type GCPolicy struct {
|
2019-01-12 04:58:27 +00:00
|
|
|
// 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
|
|
|
|
}
|
|
|
|
|
2020-08-10 17:43:49 +00:00
|
|
|
// GC manages garbage collection of dead containers.
|
2019-01-12 04:58:27 +00:00
|
|
|
//
|
|
|
|
// Implementation is thread-compatible.
|
2020-08-10 17:43:49 +00:00
|
|
|
type GC interface {
|
2019-01-12 04:58:27 +00:00
|
|
|
// 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.
|
2020-08-10 17:43:49 +00:00
|
|
|
policy GCPolicy
|
2019-01-12 04:58:27 +00:00
|
|
|
|
|
|
|
// sourcesReadyProvider provides the readiness of kubelet configuration sources.
|
|
|
|
sourcesReadyProvider SourcesReadyProvider
|
|
|
|
}
|
|
|
|
|
2020-08-10 17:43:49 +00:00
|
|
|
// NewContainerGC creates a new instance of GC with the specified policy.
|
|
|
|
func NewContainerGC(runtime Runtime, policy GCPolicy, sourcesReadyProvider SourcesReadyProvider) (GC, error) {
|
2019-01-12 04:58:27 +00:00
|
|
|
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 {
|
2021-03-18 22:40:29 +00:00
|
|
|
klog.InfoS("Attempting to delete unused containers")
|
2019-01-12 04:58:27 +00:00
|
|
|
return cgc.runtime.GarbageCollect(cgc.policy, cgc.sourcesReadyProvider.AllReady(), true)
|
|
|
|
}
|