Merge pull request #64364 from ravisantoshgudimetla/remove-rescheduler
Automatic merge from submit-queue. If you want to cherry-pick this change to another branch, please follow the instructions <a href="https://github.com/kubernetes/community/blob/master/contributors/devel/cherry-picks.md">here</a>. Remove rescheduler and corresponding tests from master **What this PR does / why we need it**: This is to remove rescheduler from master branch as we are promoting priority and preemption to beta. **Which issue(s) this PR fixes** *(optional, in `fixes #<issue number>(, fixes #<issue_number>, ...)` format, will close the issue(s) when PR gets merged)*: Part of #57471 **Special notes for your reviewer**: /cc @bsalamat @aveshagarwal **Release note**: ```release-note Remove rescheduler from master. ```
This commit is contained in:
@@ -387,7 +387,6 @@ function kube::release::package_kube_manifests_tarball() {
|
|||||||
cp "${src_dir}/kube-controller-manager.manifest" "${dst_dir}"
|
cp "${src_dir}/kube-controller-manager.manifest" "${dst_dir}"
|
||||||
cp "${src_dir}/kube-addon-manager.yaml" "${dst_dir}"
|
cp "${src_dir}/kube-addon-manager.yaml" "${dst_dir}"
|
||||||
cp "${src_dir}/glbc.manifest" "${dst_dir}"
|
cp "${src_dir}/glbc.manifest" "${dst_dir}"
|
||||||
cp "${src_dir}/rescheduler.manifest" "${dst_dir}/"
|
|
||||||
cp "${src_dir}/e2e-image-puller.manifest" "${dst_dir}/"
|
cp "${src_dir}/e2e-image-puller.manifest" "${dst_dir}/"
|
||||||
cp "${src_dir}/etcd-empty-dir-cleanup.yaml" "${dst_dir}/"
|
cp "${src_dir}/etcd-empty-dir-cleanup.yaml" "${dst_dir}/"
|
||||||
cp "${KUBE_ROOT}/cluster/gce/gci/configure-helper.sh" "${dst_dir}/gci-configure-helper.sh"
|
cp "${KUBE_ROOT}/cluster/gce/gci/configure-helper.sh" "${dst_dir}/gci-configure-helper.sh"
|
||||||
|
@@ -273,21 +273,6 @@ data:
|
|||||||
tag kube-scheduler
|
tag kube-scheduler
|
||||||
</source>
|
</source>
|
||||||
|
|
||||||
# Example:
|
|
||||||
# I1104 10:36:20.242766 5 rescheduler.go:73] Running Rescheduler
|
|
||||||
<source>
|
|
||||||
@id rescheduler.log
|
|
||||||
@type tail
|
|
||||||
format multiline
|
|
||||||
multiline_flush_interval 5s
|
|
||||||
format_firstline /^\w\d{4}/
|
|
||||||
format1 /^(?<severity>\w)(?<time>\d{4} [^\s]*)\s+(?<pid>\d+)\s+(?<source>[^ \]]+)\] (?<message>.*)/
|
|
||||||
time_format %m%d %H:%M:%S.%N
|
|
||||||
path /var/log/rescheduler.log
|
|
||||||
pos_file /var/log/es-rescheduler.log.pos
|
|
||||||
tag rescheduler
|
|
||||||
</source>
|
|
||||||
|
|
||||||
# Example:
|
# Example:
|
||||||
# I0603 15:31:05.793605 6 cluster_manager.go:230] Reading config from path /etc/gce.conf
|
# I0603 15:31:05.793605 6 cluster_manager.go:230] Reading config from path /etc/gce.conf
|
||||||
<source>
|
<source>
|
||||||
|
@@ -210,20 +210,6 @@ data:
|
|||||||
tag kube-scheduler
|
tag kube-scheduler
|
||||||
</source>
|
</source>
|
||||||
|
|
||||||
# Example:
|
|
||||||
# I1104 10:36:20.242766 5 rescheduler.go:73] Running Rescheduler
|
|
||||||
<source>
|
|
||||||
@type tail
|
|
||||||
format multiline
|
|
||||||
multiline_flush_interval 5s
|
|
||||||
format_firstline /^\w\d{4}/
|
|
||||||
format1 /^(?<severity>\w)(?<time>\d{4} [^\s]*)\s+(?<pid>\d+)\s+(?<source>[^ \]]+)\] (?<message>.*)/
|
|
||||||
time_format %m%d %H:%M:%S.%N
|
|
||||||
path /var/log/rescheduler.log
|
|
||||||
pos_file /var/log/gcp-rescheduler.log.pos
|
|
||||||
tag rescheduler
|
|
||||||
</source>
|
|
||||||
|
|
||||||
# Example:
|
# Example:
|
||||||
# I0603 15:31:05.793605 6 cluster_manager.go:230] Reading config from path /etc/gce.conf
|
# I0603 15:31:05.793605 6 cluster_manager.go:230] Reading config from path /etc/gce.conf
|
||||||
<source>
|
<source>
|
||||||
|
@@ -223,20 +223,6 @@ data:
|
|||||||
tag kube-scheduler
|
tag kube-scheduler
|
||||||
</source>
|
</source>
|
||||||
|
|
||||||
# Example:
|
|
||||||
# I1104 10:36:20.242766 5 rescheduler.go:73] Running Rescheduler
|
|
||||||
<source>
|
|
||||||
@type tail
|
|
||||||
format multiline
|
|
||||||
multiline_flush_interval 5s
|
|
||||||
format_firstline /^\w\d{4}/
|
|
||||||
format1 /^(?<severity>\w)(?<time>\d{4} [^\s]*)\s+(?<pid>\d+)\s+(?<source>[^ \]]+)\] (?<message>.*)/
|
|
||||||
time_format %m%d %H:%M:%S.%N
|
|
||||||
path /var/log/rescheduler.log
|
|
||||||
pos_file /var/log/gcp-rescheduler.log.pos
|
|
||||||
tag rescheduler
|
|
||||||
</source>
|
|
||||||
|
|
||||||
# Example:
|
# Example:
|
||||||
# I0603 15:31:05.793605 6 cluster_manager.go:230] Reading config from path /etc/gce.conf
|
# I0603 15:31:05.793605 6 cluster_manager.go:230] Reading config from path /etc/gce.conf
|
||||||
<source>
|
<source>
|
||||||
|
@@ -276,9 +276,6 @@ if [[ "${ENABLE_CLUSTER_AUTOSCALER}" == "true" ]]; then
|
|||||||
AUTOSCALER_EXPANDER_CONFIG="${KUBE_AUTOSCALER_EXPANDER_CONFIG:---expander=price}"
|
AUTOSCALER_EXPANDER_CONFIG="${KUBE_AUTOSCALER_EXPANDER_CONFIG:---expander=price}"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Optional: Enable Rescheduler
|
|
||||||
ENABLE_RESCHEDULER="${KUBE_ENABLE_RESCHEDULER:-true}"
|
|
||||||
|
|
||||||
# Optional: Enable allocation of pod IPs using IP aliases.
|
# Optional: Enable allocation of pod IPs using IP aliases.
|
||||||
#
|
#
|
||||||
# BETA FEATURE.
|
# BETA FEATURE.
|
||||||
|
@@ -283,9 +283,6 @@ if [[ "${ENABLE_CLUSTER_AUTOSCALER}" == "true" ]]; then
|
|||||||
AUTOSCALER_EXPANDER_CONFIG="${KUBE_AUTOSCALER_EXPANDER_CONFIG:---expander=price}"
|
AUTOSCALER_EXPANDER_CONFIG="${KUBE_AUTOSCALER_EXPANDER_CONFIG:---expander=price}"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Optional: Enable Rescheduler
|
|
||||||
ENABLE_RESCHEDULER="${KUBE_ENABLE_RESCHEDULER:-true}"
|
|
||||||
|
|
||||||
# Optional: Enable allocation of pod IPs using IP aliases.
|
# Optional: Enable allocation of pod IPs using IP aliases.
|
||||||
#
|
#
|
||||||
# BETA FEATURE.
|
# BETA FEATURE.
|
||||||
|
@@ -2446,16 +2446,6 @@ function start-lb-controller {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
# Starts rescheduler.
|
|
||||||
function start-rescheduler {
|
|
||||||
if [[ "${ENABLE_RESCHEDULER:-}" == "true" ]]; then
|
|
||||||
echo "Start Rescheduler"
|
|
||||||
prepare-log-file /var/log/rescheduler.log
|
|
||||||
cp "${KUBE_HOME}/kube-manifests/kubernetes/gci-trusty/rescheduler.manifest" \
|
|
||||||
/etc/kubernetes/manifests/
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# Setup working directory for kubelet.
|
# Setup working directory for kubelet.
|
||||||
function setup-kubelet-dir {
|
function setup-kubelet-dir {
|
||||||
echo "Making /var/lib/kubelet executable for kubelet"
|
echo "Making /var/lib/kubelet executable for kubelet"
|
||||||
@@ -2616,7 +2606,6 @@ function main() {
|
|||||||
start-kube-addons
|
start-kube-addons
|
||||||
start-cluster-autoscaler
|
start-cluster-autoscaler
|
||||||
start-lb-controller
|
start-lb-controller
|
||||||
start-rescheduler
|
|
||||||
else
|
else
|
||||||
if [[ "${KUBE_PROXY_DAEMONSET:-}" != "true" ]]; then
|
if [[ "${KUBE_PROXY_DAEMONSET:-}" != "true" ]]; then
|
||||||
start-kube-proxy
|
start-kube-proxy
|
||||||
|
@@ -24,7 +24,6 @@ filegroup(
|
|||||||
"kube-controller-manager.manifest",
|
"kube-controller-manager.manifest",
|
||||||
"kube-proxy.manifest",
|
"kube-proxy.manifest",
|
||||||
"kube-scheduler.manifest",
|
"kube-scheduler.manifest",
|
||||||
"rescheduler.manifest",
|
|
||||||
],
|
],
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@@ -6,8 +6,7 @@ metadata:
|
|||||||
# This annotation ensures that kube-proxy does not get evicted if the node
|
# This annotation ensures that kube-proxy does not get evicted if the node
|
||||||
# supports critical pod annotation based priority scheme.
|
# supports critical pod annotation based priority scheme.
|
||||||
# Note that kube-proxy runs as a static pod so this annotation does NOT have
|
# Note that kube-proxy runs as a static pod so this annotation does NOT have
|
||||||
# any effect on rescheduler (default scheduler and rescheduler are not
|
# any effect on default scheduler which scheduling kube-proxy.
|
||||||
# involved in scheduling kube-proxy).
|
|
||||||
annotations:
|
annotations:
|
||||||
scheduler.alpha.kubernetes.io/critical-pod: ''
|
scheduler.alpha.kubernetes.io/critical-pod: ''
|
||||||
labels:
|
labels:
|
||||||
|
@@ -1,36 +0,0 @@
|
|||||||
apiVersion: v1
|
|
||||||
kind: Pod
|
|
||||||
metadata:
|
|
||||||
name: rescheduler-v0.3.1
|
|
||||||
namespace: kube-system
|
|
||||||
annotations:
|
|
||||||
scheduler.alpha.kubernetes.io/critical-pod: ''
|
|
||||||
labels:
|
|
||||||
k8s-app: rescheduler
|
|
||||||
version: v0.3.1
|
|
||||||
kubernetes.io/cluster-service: "true"
|
|
||||||
kubernetes.io/name: "Rescheduler"
|
|
||||||
spec:
|
|
||||||
hostNetwork: true
|
|
||||||
containers:
|
|
||||||
- image: k8s.gcr.io/rescheduler:v0.3.1
|
|
||||||
name: rescheduler
|
|
||||||
volumeMounts:
|
|
||||||
- mountPath: /var/log/rescheduler.log
|
|
||||||
name: logfile
|
|
||||||
readOnly: false
|
|
||||||
# TODO: Make resource requirements depend on the size of the cluster
|
|
||||||
resources:
|
|
||||||
requests:
|
|
||||||
cpu: 10m
|
|
||||||
memory: 100Mi
|
|
||||||
command:
|
|
||||||
# TODO: split this out into args when we no longer need to pipe stdout to a file #6428
|
|
||||||
- sh
|
|
||||||
- -c
|
|
||||||
- 'exec /rescheduler --running-in-cluster=false 1>>/var/log/rescheduler.log 2>&1'
|
|
||||||
volumes:
|
|
||||||
- hostPath:
|
|
||||||
path: /var/log/rescheduler.log
|
|
||||||
type: FileOrCreate
|
|
||||||
name: logfile
|
|
@@ -832,7 +832,6 @@ ENABLE_NODE_PROBLEM_DETECTOR: $(yaml-quote ${ENABLE_NODE_PROBLEM_DETECTOR:-none}
|
|||||||
NODE_PROBLEM_DETECTOR_VERSION: $(yaml-quote ${NODE_PROBLEM_DETECTOR_VERSION:-})
|
NODE_PROBLEM_DETECTOR_VERSION: $(yaml-quote ${NODE_PROBLEM_DETECTOR_VERSION:-})
|
||||||
NODE_PROBLEM_DETECTOR_TAR_HASH: $(yaml-quote ${NODE_PROBLEM_DETECTOR_TAR_HASH:-})
|
NODE_PROBLEM_DETECTOR_TAR_HASH: $(yaml-quote ${NODE_PROBLEM_DETECTOR_TAR_HASH:-})
|
||||||
ENABLE_NODE_LOGGING: $(yaml-quote ${ENABLE_NODE_LOGGING:-false})
|
ENABLE_NODE_LOGGING: $(yaml-quote ${ENABLE_NODE_LOGGING:-false})
|
||||||
ENABLE_RESCHEDULER: $(yaml-quote ${ENABLE_RESCHEDULER:-false})
|
|
||||||
LOGGING_DESTINATION: $(yaml-quote ${LOGGING_DESTINATION:-})
|
LOGGING_DESTINATION: $(yaml-quote ${LOGGING_DESTINATION:-})
|
||||||
ELASTICSEARCH_LOGGING_REPLICAS: $(yaml-quote ${ELASTICSEARCH_LOGGING_REPLICAS:-})
|
ELASTICSEARCH_LOGGING_REPLICAS: $(yaml-quote ${ELASTICSEARCH_LOGGING_REPLICAS:-})
|
||||||
ENABLE_CLUSTER_DNS: $(yaml-quote ${ENABLE_CLUSTER_DNS:-false})
|
ENABLE_CLUSTER_DNS: $(yaml-quote ${ENABLE_CLUSTER_DNS:-false})
|
||||||
|
@@ -41,7 +41,7 @@ readonly master_ssh_supported_providers="gce aws kubernetes-anywhere"
|
|||||||
readonly node_ssh_supported_providers="gce gke aws kubernetes-anywhere"
|
readonly node_ssh_supported_providers="gce gke aws kubernetes-anywhere"
|
||||||
readonly gcloud_supported_providers="gce gke kubernetes-anywhere"
|
readonly gcloud_supported_providers="gce gke kubernetes-anywhere"
|
||||||
|
|
||||||
readonly master_logfiles="kube-apiserver kube-apiserver-audit kube-scheduler rescheduler kube-controller-manager etcd etcd-events glbc cluster-autoscaler kube-addon-manager fluentd"
|
readonly master_logfiles="kube-apiserver kube-apiserver-audit kube-scheduler kube-controller-manager etcd etcd-events glbc cluster-autoscaler kube-addon-manager fluentd"
|
||||||
readonly node_logfiles="kube-proxy fluentd node-problem-detector"
|
readonly node_logfiles="kube-proxy fluentd node-problem-detector"
|
||||||
readonly node_systemd_services="node-problem-detector"
|
readonly node_systemd_services="node-problem-detector"
|
||||||
readonly hollow_node_logfiles="kubelet-hollow-node-* kubeproxy-hollow-node-* npd-hollow-node-*"
|
readonly hollow_node_logfiles="kubelet-hollow-node-* kubeproxy-hollow-node-* npd-hollow-node-*"
|
||||||
|
@@ -141,7 +141,7 @@ func (sp SyncPodType) String() string {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// IsCriticalPod returns true if the pod bears the critical pod annotation key or if pod's priority is greater than
|
// IsCriticalPod returns true if the pod bears the critical pod annotation key or if pod's priority is greater than
|
||||||
// or equal to SystemCriticalPriority. Both the rescheduler(deprecated in 1.10) and the kubelet use this function
|
// or equal to SystemCriticalPriority. Both the default scheduler and the kubelet use this function
|
||||||
// to make admission and scheduling decisions.
|
// to make admission and scheduling decisions.
|
||||||
func IsCriticalPod(pod *v1.Pod) bool {
|
func IsCriticalPod(pod *v1.Pod) bool {
|
||||||
return IsCritical(pod.Namespace, pod.Annotations) || (pod.Spec.Priority != nil && IsCriticalPodBasedOnPriority(*pod.Spec.Priority))
|
return IsCritical(pod.Namespace, pod.Annotations) || (pod.Spec.Priority != nil && IsCriticalPodBasedOnPriority(*pod.Spec.Priority))
|
||||||
|
@@ -11,7 +11,6 @@ go_library(
|
|||||||
"predicates.go",
|
"predicates.go",
|
||||||
"preemption.go",
|
"preemption.go",
|
||||||
"priorities.go",
|
"priorities.go",
|
||||||
"rescheduler.go",
|
|
||||||
"resource_quota.go",
|
"resource_quota.go",
|
||||||
"ubernetes_lite.go",
|
"ubernetes_lite.go",
|
||||||
"ubernetes_lite_volumes.go",
|
"ubernetes_lite_volumes.go",
|
||||||
@@ -19,7 +18,6 @@ go_library(
|
|||||||
importpath = "k8s.io/kubernetes/test/e2e/scheduling",
|
importpath = "k8s.io/kubernetes/test/e2e/scheduling",
|
||||||
visibility = ["//visibility:public"],
|
visibility = ["//visibility:public"],
|
||||||
deps = [
|
deps = [
|
||||||
"//pkg/api/v1/pod:go_default_library",
|
|
||||||
"//pkg/apis/core:go_default_library",
|
"//pkg/apis/core:go_default_library",
|
||||||
"//pkg/apis/extensions:go_default_library",
|
"//pkg/apis/extensions:go_default_library",
|
||||||
"//pkg/apis/scheduling:go_default_library",
|
"//pkg/apis/scheduling:go_default_library",
|
||||||
|
@@ -35,6 +35,10 @@ import (
|
|||||||
_ "github.com/stretchr/testify/assert"
|
_ "github.com/stretchr/testify/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
const (
|
||||||
|
defaultTimeout = 3 * time.Minute
|
||||||
|
)
|
||||||
|
|
||||||
var _ = framework.KubeDescribe("EquivalenceCache [Serial]", func() {
|
var _ = framework.KubeDescribe("EquivalenceCache [Serial]", func() {
|
||||||
var cs clientset.Interface
|
var cs clientset.Interface
|
||||||
var nodeList *v1.NodeList
|
var nodeList *v1.NodeList
|
||||||
|
@@ -1,133 +0,0 @@
|
|||||||
/*
|
|
||||||
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 scheduling
|
|
||||||
|
|
||||||
import (
|
|
||||||
"fmt"
|
|
||||||
"time"
|
|
||||||
|
|
||||||
"k8s.io/api/core/v1"
|
|
||||||
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
|
|
||||||
"k8s.io/apimachinery/pkg/labels"
|
|
||||||
podutil "k8s.io/kubernetes/pkg/api/v1/pod"
|
|
||||||
"k8s.io/kubernetes/test/e2e/framework"
|
|
||||||
testutils "k8s.io/kubernetes/test/utils"
|
|
||||||
imageutils "k8s.io/kubernetes/test/utils/image"
|
|
||||||
|
|
||||||
. "github.com/onsi/ginkgo"
|
|
||||||
. "github.com/onsi/gomega"
|
|
||||||
)
|
|
||||||
|
|
||||||
const (
|
|
||||||
defaultTimeout = 3 * time.Minute
|
|
||||||
)
|
|
||||||
|
|
||||||
// This test requires Rescheduler to be enabled.
|
|
||||||
var _ = SIGDescribe("Rescheduler [Serial]", func() {
|
|
||||||
f := framework.NewDefaultFramework("rescheduler")
|
|
||||||
var ns string
|
|
||||||
var totalMillicores int
|
|
||||||
|
|
||||||
BeforeEach(func() {
|
|
||||||
framework.Skipf("Rescheduler is being deprecated soon in Kubernetes 1.10")
|
|
||||||
ns = f.Namespace.Name
|
|
||||||
nodes := framework.GetReadySchedulableNodesOrDie(f.ClientSet)
|
|
||||||
nodeCount := len(nodes.Items)
|
|
||||||
Expect(nodeCount).NotTo(BeZero())
|
|
||||||
|
|
||||||
cpu := nodes.Items[0].Status.Capacity[v1.ResourceCPU]
|
|
||||||
totalMillicores = int((&cpu).MilliValue()) * nodeCount
|
|
||||||
})
|
|
||||||
|
|
||||||
It("should ensure that critical pod is scheduled in case there is no resources available", func() {
|
|
||||||
By("reserving all available cpu")
|
|
||||||
err := reserveAllCpu(f, "reserve-all-cpu", totalMillicores)
|
|
||||||
defer framework.DeleteRCAndWaitForGC(f.ClientSet, ns, "reserve-all-cpu")
|
|
||||||
framework.ExpectNoError(err)
|
|
||||||
|
|
||||||
By("creating a new instance of Dashboard and waiting for Dashboard to be scheduled")
|
|
||||||
label := labels.SelectorFromSet(labels.Set(map[string]string{"k8s-app": "kubernetes-dashboard"}))
|
|
||||||
listOpts := metav1.ListOptions{LabelSelector: label.String()}
|
|
||||||
deployments, err := f.ClientSet.ExtensionsV1beta1().Deployments(metav1.NamespaceSystem).List(listOpts)
|
|
||||||
framework.ExpectNoError(err)
|
|
||||||
Expect(len(deployments.Items)).Should(Equal(1))
|
|
||||||
|
|
||||||
deployment := deployments.Items[0]
|
|
||||||
replicas := uint(*(deployment.Spec.Replicas))
|
|
||||||
|
|
||||||
err = framework.ScaleDeployment(f.ClientSet, f.ScalesGetter, metav1.NamespaceSystem, deployment.Name, replicas+1, true)
|
|
||||||
defer framework.ExpectNoError(framework.ScaleDeployment(f.ClientSet, f.ScalesGetter, metav1.NamespaceSystem, deployment.Name, replicas, true))
|
|
||||||
framework.ExpectNoError(err)
|
|
||||||
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
func reserveAllCpu(f *framework.Framework, id string, millicores int) error {
|
|
||||||
timeout := 5 * time.Minute
|
|
||||||
replicas := millicores / 100
|
|
||||||
|
|
||||||
reserveCpu(f, id, 1, 100)
|
|
||||||
framework.ExpectNoError(framework.ScaleRC(f.ClientSet, f.ScalesGetter, f.Namespace.Name, id, uint(replicas), false))
|
|
||||||
|
|
||||||
for start := time.Now(); time.Since(start) < timeout; time.Sleep(10 * time.Second) {
|
|
||||||
pods, err := framework.GetPodsInNamespace(f.ClientSet, f.Namespace.Name, framework.ImagePullerLabels)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
if len(pods) != replicas {
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
|
|
||||||
allRunningOrUnschedulable := true
|
|
||||||
for _, pod := range pods {
|
|
||||||
if !podRunningOrUnschedulable(pod) {
|
|
||||||
allRunningOrUnschedulable = false
|
|
||||||
break
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if allRunningOrUnschedulable {
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return fmt.Errorf("Pod name %s: Gave up waiting %v for %d pods to come up", id, timeout, replicas)
|
|
||||||
}
|
|
||||||
|
|
||||||
func podRunningOrUnschedulable(pod *v1.Pod) bool {
|
|
||||||
_, cond := podutil.GetPodCondition(&pod.Status, v1.PodScheduled)
|
|
||||||
if cond != nil && cond.Status == v1.ConditionFalse && cond.Reason == "Unschedulable" {
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
running, _ := testutils.PodRunningReady(pod)
|
|
||||||
return running
|
|
||||||
}
|
|
||||||
|
|
||||||
func reserveCpu(f *framework.Framework, id string, replicas, millicores int) {
|
|
||||||
By(fmt.Sprintf("Running RC which reserves %v millicores", millicores))
|
|
||||||
request := int64(millicores / replicas)
|
|
||||||
config := &testutils.RCConfig{
|
|
||||||
Client: f.ClientSet,
|
|
||||||
InternalClient: f.InternalClientset,
|
|
||||||
Name: id,
|
|
||||||
Namespace: f.Namespace.Name,
|
|
||||||
Timeout: defaultTimeout,
|
|
||||||
Image: imageutils.GetPauseImageName(),
|
|
||||||
Replicas: replicas,
|
|
||||||
CpuRequest: request,
|
|
||||||
}
|
|
||||||
framework.ExpectNoError(framework.RunRC(*config))
|
|
||||||
}
|
|
Reference in New Issue
Block a user