mirror of
https://github.com/k3s-io/kubernetes.git
synced 2025-07-23 19:56:01 +00:00
Merge pull request #64344 from freehan/pod-ready-plus2
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>. Teach Kubelet about Pod Ready++ Follow up PR of https://github.com/kubernetes/kubernetes/pull/62306 and https://github.com/kubernetes/kubernetes/pull/64057, **Only the last 3 commits are new.** Will rebase once the previous ones are merged. ref: https://github.com/kubernetes/community/blob/master/keps/sig-network/0007-pod-ready%2B%2B.md kind/feature priority/important-soon sig/network sig/node /assign @yujuhong ```release-note NONE ```
This commit is contained in:
commit
e64b81342b
@ -261,9 +261,18 @@ func GetPodCondition(status *v1.PodStatus, conditionType v1.PodConditionType) (i
|
|||||||
if status == nil {
|
if status == nil {
|
||||||
return -1, nil
|
return -1, nil
|
||||||
}
|
}
|
||||||
for i := range status.Conditions {
|
return GetPodConditionFromList(status.Conditions, conditionType)
|
||||||
if status.Conditions[i].Type == conditionType {
|
}
|
||||||
return i, &status.Conditions[i]
|
|
||||||
|
// GetPodConditionFromList extracts the provided condition from the given list of condition and
|
||||||
|
// returns the index of the condition and the condition. Returns -1 and nil if the condition is not present.
|
||||||
|
func GetPodConditionFromList(conditions []v1.PodCondition, conditionType v1.PodConditionType) (int, *v1.PodCondition) {
|
||||||
|
if conditions == nil {
|
||||||
|
return -1, nil
|
||||||
|
}
|
||||||
|
for i := range conditions {
|
||||||
|
if conditions[i].Type == conditionType {
|
||||||
|
return i, &conditions[i]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return -1, nil
|
return -1, nil
|
||||||
|
@ -2046,11 +2046,18 @@ func (kl *Kubelet) HandlePodRemoves(pods []*v1.Pod) {
|
|||||||
// HandlePodReconcile is the callback in the SyncHandler interface for pods
|
// HandlePodReconcile is the callback in the SyncHandler interface for pods
|
||||||
// that should be reconciled.
|
// that should be reconciled.
|
||||||
func (kl *Kubelet) HandlePodReconcile(pods []*v1.Pod) {
|
func (kl *Kubelet) HandlePodReconcile(pods []*v1.Pod) {
|
||||||
|
start := kl.clock.Now()
|
||||||
for _, pod := range pods {
|
for _, pod := range pods {
|
||||||
// Update the pod in pod manager, status manager will do periodically reconcile according
|
// Update the pod in pod manager, status manager will do periodically reconcile according
|
||||||
// to the pod manager.
|
// to the pod manager.
|
||||||
kl.podManager.UpdatePod(pod)
|
kl.podManager.UpdatePod(pod)
|
||||||
|
|
||||||
|
// Reconcile Pod "Ready" condition if necessary. Trigger sync pod for reconciliation.
|
||||||
|
if status.NeedToReconcilePodReadiness(pod) {
|
||||||
|
mirrorPod, _ := kl.podManager.GetMirrorPodByPod(pod)
|
||||||
|
kl.dispatchWork(pod, kubetypes.SyncPodSync, mirrorPod, start)
|
||||||
|
}
|
||||||
|
|
||||||
// After an evicted pod is synced, all dead containers in the pod can be removed.
|
// After an evicted pod is synced, all dead containers in the pod can be removed.
|
||||||
if eviction.PodIsEvicted(pod.Status) {
|
if eviction.PodIsEvicted(pod.Status) {
|
||||||
if podStatus, err := kl.podCache.Get(pod.UID); err == nil {
|
if podStatus, err := kl.podCache.Get(pod.UID); err == nil {
|
||||||
|
@ -1353,7 +1353,7 @@ func (kl *Kubelet) generateAPIPodStatus(pod *v1.Pod, podStatus *kubecontainer.Po
|
|||||||
}
|
}
|
||||||
kl.probeManager.UpdatePodStatus(pod.UID, s)
|
kl.probeManager.UpdatePodStatus(pod.UID, s)
|
||||||
s.Conditions = append(s.Conditions, status.GeneratePodInitializedCondition(spec, s.InitContainerStatuses, s.Phase))
|
s.Conditions = append(s.Conditions, status.GeneratePodInitializedCondition(spec, s.InitContainerStatuses, s.Phase))
|
||||||
s.Conditions = append(s.Conditions, status.GeneratePodReadyCondition(spec, s.ContainerStatuses, s.Phase))
|
s.Conditions = append(s.Conditions, status.GeneratePodReadyCondition(spec, s.Conditions, s.ContainerStatuses, s.Phase))
|
||||||
// Status manager will take care of the LastTransitionTimestamp, either preserve
|
// Status manager will take care of the LastTransitionTimestamp, either preserve
|
||||||
// the timestamp from apiserver, or set a new one. When kubelet sees the pod,
|
// the timestamp from apiserver, or set a new one. When kubelet sees the pod,
|
||||||
// `PodScheduled` condition must be true.
|
// `PodScheduled` condition must be true.
|
||||||
@ -1406,6 +1406,12 @@ func (kl *Kubelet) convertStatusToAPIStatus(pod *v1.Pod, podStatus *kubecontaine
|
|||||||
true,
|
true,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
// Preserves conditions not controlled by kubelet
|
||||||
|
for _, c := range pod.Status.Conditions {
|
||||||
|
if !kubetypes.PodConditionByKubelet(c.Type) {
|
||||||
|
apiPodStatus.Conditions = append(apiPodStatus.Conditions, c)
|
||||||
|
}
|
||||||
|
}
|
||||||
return &apiPodStatus
|
return &apiPodStatus
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -29,11 +29,13 @@ const (
|
|||||||
PodCompleted = "PodCompleted"
|
PodCompleted = "PodCompleted"
|
||||||
ContainersNotReady = "ContainersNotReady"
|
ContainersNotReady = "ContainersNotReady"
|
||||||
ContainersNotInitialized = "ContainersNotInitialized"
|
ContainersNotInitialized = "ContainersNotInitialized"
|
||||||
|
ReadinessGatesNotReady = "ReadinessGatesNotReady"
|
||||||
)
|
)
|
||||||
|
|
||||||
// GeneratePodReadyCondition returns ready condition if all containers in a pod are ready, else it
|
// GeneratePodReadyCondition returns "Ready" condition of a pod.
|
||||||
// returns an unready condition.
|
// The status of "Ready" condition is "True", if all containers in a pod are ready
|
||||||
func GeneratePodReadyCondition(spec *v1.PodSpec, containerStatuses []v1.ContainerStatus, podPhase v1.PodPhase) v1.PodCondition {
|
// AND all matching conditions specified in the ReadinessGates have status equal to "True".
|
||||||
|
func GeneratePodReadyCondition(spec *v1.PodSpec, conditions []v1.PodCondition, containerStatuses []v1.ContainerStatus, podPhase v1.PodPhase) v1.PodCondition {
|
||||||
// Find if all containers are ready or not.
|
// Find if all containers are ready or not.
|
||||||
if containerStatuses == nil {
|
if containerStatuses == nil {
|
||||||
return v1.PodCondition{
|
return v1.PodCondition{
|
||||||
@ -63,6 +65,7 @@ func GeneratePodReadyCondition(spec *v1.PodSpec, containerStatuses []v1.Containe
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Generate message for containers in unknown condition.
|
||||||
unreadyMessages := []string{}
|
unreadyMessages := []string{}
|
||||||
if len(unknownContainers) > 0 {
|
if len(unknownContainers) > 0 {
|
||||||
unreadyMessages = append(unreadyMessages, fmt.Sprintf("containers with unknown status: %s", unknownContainers))
|
unreadyMessages = append(unreadyMessages, fmt.Sprintf("containers with unknown status: %s", unknownContainers))
|
||||||
@ -80,6 +83,29 @@ func GeneratePodReadyCondition(spec *v1.PodSpec, containerStatuses []v1.Containe
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Evaluate corresponding conditions specified in readiness gate
|
||||||
|
// Generate message if any readiness gate is not satisfied.
|
||||||
|
unreadyMessages = []string{}
|
||||||
|
for _, rg := range spec.ReadinessGates {
|
||||||
|
_, c := podutil.GetPodConditionFromList(conditions, rg.ConditionType)
|
||||||
|
if c == nil {
|
||||||
|
unreadyMessages = append(unreadyMessages, fmt.Sprintf("corresponding condition of pod readiness gate %q does not exist.", string(rg.ConditionType)))
|
||||||
|
} else if c.Status != v1.ConditionTrue {
|
||||||
|
unreadyMessages = append(unreadyMessages, fmt.Sprintf("the status of pod readiness gate %q is not \"True\", but %v", string(rg.ConditionType), c.Status))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Set "Ready" condition to "False" if any readiness gate is not ready.
|
||||||
|
if len(unreadyMessages) != 0 {
|
||||||
|
unreadyMessage := strings.Join(unreadyMessages, ", ")
|
||||||
|
return v1.PodCondition{
|
||||||
|
Type: v1.PodReady,
|
||||||
|
Status: v1.ConditionFalse,
|
||||||
|
Reason: ReadinessGatesNotReady,
|
||||||
|
Message: unreadyMessage,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return v1.PodCondition{
|
return v1.PodCondition{
|
||||||
Type: v1.PodReady,
|
Type: v1.PodReady,
|
||||||
Status: v1.ConditionTrue,
|
Status: v1.ConditionTrue,
|
||||||
|
@ -27,21 +27,24 @@ import (
|
|||||||
func TestGeneratePodReadyCondition(t *testing.T) {
|
func TestGeneratePodReadyCondition(t *testing.T) {
|
||||||
tests := []struct {
|
tests := []struct {
|
||||||
spec *v1.PodSpec
|
spec *v1.PodSpec
|
||||||
|
conditions []v1.PodCondition
|
||||||
containerStatuses []v1.ContainerStatus
|
containerStatuses []v1.ContainerStatus
|
||||||
podPhase v1.PodPhase
|
podPhase v1.PodPhase
|
||||||
expected v1.PodCondition
|
expectReady v1.PodCondition
|
||||||
}{
|
}{
|
||||||
{
|
{
|
||||||
spec: nil,
|
spec: nil,
|
||||||
|
conditions: nil,
|
||||||
containerStatuses: nil,
|
containerStatuses: nil,
|
||||||
podPhase: v1.PodRunning,
|
podPhase: v1.PodRunning,
|
||||||
expected: getReadyCondition(false, UnknownContainerStatuses, ""),
|
expectReady: getPodCondition(v1.PodReady, v1.ConditionFalse, UnknownContainerStatuses, ""),
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
spec: &v1.PodSpec{},
|
spec: &v1.PodSpec{},
|
||||||
|
conditions: nil,
|
||||||
containerStatuses: []v1.ContainerStatus{},
|
containerStatuses: []v1.ContainerStatus{},
|
||||||
podPhase: v1.PodRunning,
|
podPhase: v1.PodRunning,
|
||||||
expected: getReadyCondition(true, "", ""),
|
expectReady: getPodCondition(v1.PodReady, v1.ConditionTrue, "", ""),
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
spec: &v1.PodSpec{
|
spec: &v1.PodSpec{
|
||||||
@ -49,9 +52,10 @@ func TestGeneratePodReadyCondition(t *testing.T) {
|
|||||||
{Name: "1234"},
|
{Name: "1234"},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
conditions: nil,
|
||||||
containerStatuses: []v1.ContainerStatus{},
|
containerStatuses: []v1.ContainerStatus{},
|
||||||
podPhase: v1.PodRunning,
|
podPhase: v1.PodRunning,
|
||||||
expected: getReadyCondition(false, ContainersNotReady, "containers with unknown status: [1234]"),
|
expectReady: getPodCondition(v1.PodReady, v1.ConditionFalse, ContainersNotReady, "containers with unknown status: [1234]"),
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
spec: &v1.PodSpec{
|
spec: &v1.PodSpec{
|
||||||
@ -60,12 +64,13 @@ func TestGeneratePodReadyCondition(t *testing.T) {
|
|||||||
{Name: "5678"},
|
{Name: "5678"},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
conditions: nil,
|
||||||
containerStatuses: []v1.ContainerStatus{
|
containerStatuses: []v1.ContainerStatus{
|
||||||
getReadyStatus("1234"),
|
getReadyStatus("1234"),
|
||||||
getReadyStatus("5678"),
|
getReadyStatus("5678"),
|
||||||
},
|
},
|
||||||
podPhase: v1.PodRunning,
|
podPhase: v1.PodRunning,
|
||||||
expected: getReadyCondition(true, "", ""),
|
expectReady: getPodCondition(v1.PodReady, v1.ConditionTrue, "", ""),
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
spec: &v1.PodSpec{
|
spec: &v1.PodSpec{
|
||||||
@ -74,11 +79,12 @@ func TestGeneratePodReadyCondition(t *testing.T) {
|
|||||||
{Name: "5678"},
|
{Name: "5678"},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
conditions: nil,
|
||||||
containerStatuses: []v1.ContainerStatus{
|
containerStatuses: []v1.ContainerStatus{
|
||||||
getReadyStatus("1234"),
|
getReadyStatus("1234"),
|
||||||
},
|
},
|
||||||
podPhase: v1.PodRunning,
|
podPhase: v1.PodRunning,
|
||||||
expected: getReadyCondition(false, ContainersNotReady, "containers with unknown status: [5678]"),
|
expectReady: getPodCondition(v1.PodReady, v1.ConditionFalse, ContainersNotReady, "containers with unknown status: [5678]"),
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
spec: &v1.PodSpec{
|
spec: &v1.PodSpec{
|
||||||
@ -87,12 +93,13 @@ func TestGeneratePodReadyCondition(t *testing.T) {
|
|||||||
{Name: "5678"},
|
{Name: "5678"},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
conditions: nil,
|
||||||
containerStatuses: []v1.ContainerStatus{
|
containerStatuses: []v1.ContainerStatus{
|
||||||
getReadyStatus("1234"),
|
getReadyStatus("1234"),
|
||||||
getNotReadyStatus("5678"),
|
getNotReadyStatus("5678"),
|
||||||
},
|
},
|
||||||
podPhase: v1.PodRunning,
|
podPhase: v1.PodRunning,
|
||||||
expected: getReadyCondition(false, ContainersNotReady, "containers with unready status: [5678]"),
|
expectReady: getPodCondition(v1.PodReady, v1.ConditionFalse, ContainersNotReady, "containers with unready status: [5678]"),
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
spec: &v1.PodSpec{
|
spec: &v1.PodSpec{
|
||||||
@ -100,18 +107,116 @@ func TestGeneratePodReadyCondition(t *testing.T) {
|
|||||||
{Name: "1234"},
|
{Name: "1234"},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
conditions: nil,
|
||||||
containerStatuses: []v1.ContainerStatus{
|
containerStatuses: []v1.ContainerStatus{
|
||||||
getNotReadyStatus("1234"),
|
getNotReadyStatus("1234"),
|
||||||
},
|
},
|
||||||
podPhase: v1.PodSucceeded,
|
podPhase: v1.PodSucceeded,
|
||||||
expected: getReadyCondition(false, PodCompleted, ""),
|
expectReady: getPodCondition(v1.PodReady, v1.ConditionFalse, PodCompleted, ""),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
spec: &v1.PodSpec{
|
||||||
|
ReadinessGates: []v1.PodReadinessGate{
|
||||||
|
{ConditionType: v1.PodConditionType("gate1")},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
conditions: nil,
|
||||||
|
containerStatuses: []v1.ContainerStatus{},
|
||||||
|
podPhase: v1.PodRunning,
|
||||||
|
expectReady: getPodCondition(v1.PodReady, v1.ConditionFalse, ReadinessGatesNotReady, `corresponding condition of pod readiness gate "gate1" does not exist.`),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
spec: &v1.PodSpec{
|
||||||
|
ReadinessGates: []v1.PodReadinessGate{
|
||||||
|
{ConditionType: v1.PodConditionType("gate1")},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
conditions: []v1.PodCondition{
|
||||||
|
getPodCondition("gate1", v1.ConditionFalse, "", ""),
|
||||||
|
},
|
||||||
|
containerStatuses: []v1.ContainerStatus{},
|
||||||
|
podPhase: v1.PodRunning,
|
||||||
|
expectReady: getPodCondition(v1.PodReady, v1.ConditionFalse, ReadinessGatesNotReady, `the status of pod readiness gate "gate1" is not "True", but False`),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
spec: &v1.PodSpec{
|
||||||
|
ReadinessGates: []v1.PodReadinessGate{
|
||||||
|
{ConditionType: v1.PodConditionType("gate1")},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
conditions: []v1.PodCondition{
|
||||||
|
getPodCondition("gate1", v1.ConditionTrue, "", ""),
|
||||||
|
},
|
||||||
|
containerStatuses: []v1.ContainerStatus{},
|
||||||
|
podPhase: v1.PodRunning,
|
||||||
|
expectReady: getPodCondition(v1.PodReady, v1.ConditionTrue, "", ""),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
spec: &v1.PodSpec{
|
||||||
|
ReadinessGates: []v1.PodReadinessGate{
|
||||||
|
{ConditionType: v1.PodConditionType("gate1")},
|
||||||
|
{ConditionType: v1.PodConditionType("gate2")},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
conditions: []v1.PodCondition{
|
||||||
|
getPodCondition("gate1", v1.ConditionTrue, "", ""),
|
||||||
|
},
|
||||||
|
containerStatuses: []v1.ContainerStatus{},
|
||||||
|
podPhase: v1.PodRunning,
|
||||||
|
expectReady: getPodCondition(v1.PodReady, v1.ConditionFalse, ReadinessGatesNotReady, `corresponding condition of pod readiness gate "gate2" does not exist.`),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
spec: &v1.PodSpec{
|
||||||
|
ReadinessGates: []v1.PodReadinessGate{
|
||||||
|
{ConditionType: v1.PodConditionType("gate1")},
|
||||||
|
{ConditionType: v1.PodConditionType("gate2")},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
conditions: []v1.PodCondition{
|
||||||
|
getPodCondition("gate1", v1.ConditionTrue, "", ""),
|
||||||
|
getPodCondition("gate2", v1.ConditionFalse, "", ""),
|
||||||
|
},
|
||||||
|
containerStatuses: []v1.ContainerStatus{},
|
||||||
|
podPhase: v1.PodRunning,
|
||||||
|
expectReady: getPodCondition(v1.PodReady, v1.ConditionFalse, ReadinessGatesNotReady, `the status of pod readiness gate "gate2" is not "True", but False`),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
spec: &v1.PodSpec{
|
||||||
|
ReadinessGates: []v1.PodReadinessGate{
|
||||||
|
{ConditionType: v1.PodConditionType("gate1")},
|
||||||
|
{ConditionType: v1.PodConditionType("gate2")},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
conditions: []v1.PodCondition{
|
||||||
|
getPodCondition("gate1", v1.ConditionTrue, "", ""),
|
||||||
|
getPodCondition("gate2", v1.ConditionTrue, "", ""),
|
||||||
|
},
|
||||||
|
containerStatuses: []v1.ContainerStatus{},
|
||||||
|
podPhase: v1.PodRunning,
|
||||||
|
expectReady: getPodCondition(v1.PodReady, v1.ConditionTrue, "", ""),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
spec: &v1.PodSpec{
|
||||||
|
Containers: []v1.Container{
|
||||||
|
{Name: "1234"},
|
||||||
|
},
|
||||||
|
ReadinessGates: []v1.PodReadinessGate{
|
||||||
|
{ConditionType: v1.PodConditionType("gate1")},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
conditions: []v1.PodCondition{
|
||||||
|
getPodCondition("gate1", v1.ConditionTrue, "", ""),
|
||||||
|
},
|
||||||
|
containerStatuses: []v1.ContainerStatus{getNotReadyStatus("1234")},
|
||||||
|
podPhase: v1.PodRunning,
|
||||||
|
expectReady: getPodCondition(v1.PodReady, v1.ConditionFalse, ContainersNotReady, "containers with unready status: [1234]"),
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
for i, test := range tests {
|
for i, test := range tests {
|
||||||
condition := GeneratePodReadyCondition(test.spec, test.containerStatuses, test.podPhase)
|
ready := GeneratePodReadyCondition(test.spec, test.conditions, test.containerStatuses, test.podPhase)
|
||||||
if !reflect.DeepEqual(condition, test.expected) {
|
if !reflect.DeepEqual(ready, test.expectReady) {
|
||||||
t.Errorf("On test case %v, expected:\n%+v\ngot\n%+v\n", i, test.expected, condition)
|
t.Errorf("On test case %v, expectReady:\n%+v\ngot\n%+v\n", i, test.expectReady, ready)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -220,13 +325,9 @@ func TestGeneratePodInitializedCondition(t *testing.T) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func getReadyCondition(ready bool, reason, message string) v1.PodCondition {
|
func getPodCondition(conditionType v1.PodConditionType, status v1.ConditionStatus, reason, message string) v1.PodCondition {
|
||||||
status := v1.ConditionFalse
|
|
||||||
if ready {
|
|
||||||
status = v1.ConditionTrue
|
|
||||||
}
|
|
||||||
return v1.PodCondition{
|
return v1.PodCondition{
|
||||||
Type: v1.PodReady,
|
Type: conditionType,
|
||||||
Status: status,
|
Status: status,
|
||||||
Reason: reason,
|
Reason: reason,
|
||||||
Message: message,
|
Message: message,
|
||||||
|
@ -227,21 +227,20 @@ func (m *manager) SetContainerReadiness(podUID types.UID, containerID kubecontai
|
|||||||
containerStatus.Ready = ready
|
containerStatus.Ready = ready
|
||||||
|
|
||||||
// Update pod condition.
|
// Update pod condition.
|
||||||
readyConditionIndex := -1
|
podReadyConditionIndex := -1
|
||||||
for i, condition := range status.Conditions {
|
for i, condition := range status.Conditions {
|
||||||
if condition.Type == v1.PodReady {
|
if condition.Type == v1.PodReady {
|
||||||
readyConditionIndex = i
|
podReadyConditionIndex = i
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
readyCondition := GeneratePodReadyCondition(&pod.Spec, status.ContainerStatuses, status.Phase)
|
podReady := GeneratePodReadyCondition(&pod.Spec, status.Conditions, status.ContainerStatuses, status.Phase)
|
||||||
if readyConditionIndex != -1 {
|
if podReadyConditionIndex != -1 {
|
||||||
status.Conditions[readyConditionIndex] = readyCondition
|
status.Conditions[podReadyConditionIndex] = podReady
|
||||||
} else {
|
} else {
|
||||||
glog.Warningf("PodStatus missing PodReady condition: %+v", status)
|
glog.Warningf("PodStatus missing PodReady condition: %+v", status)
|
||||||
status.Conditions = append(status.Conditions, readyCondition)
|
status.Conditions = append(status.Conditions, podReady)
|
||||||
}
|
}
|
||||||
|
|
||||||
m.updateStatusInternal(pod, status, false)
|
m.updateStatusInternal(pod, status, false)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -652,3 +651,17 @@ func mergePodStatus(oldPodStatus, newPodStatus v1.PodStatus) v1.PodStatus {
|
|||||||
newPodStatus.Conditions = podConditions
|
newPodStatus.Conditions = podConditions
|
||||||
return newPodStatus
|
return newPodStatus
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// NeedToReconcilePodReadiness returns if the pod "Ready" condition need to be reconcile
|
||||||
|
func NeedToReconcilePodReadiness(pod *v1.Pod) bool {
|
||||||
|
if len(pod.Spec.ReadinessGates) == 0 {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
podReadyCondition := GeneratePodReadyCondition(&pod.Spec, pod.Status.Conditions, pod.Status.ContainerStatuses, pod.Status.Phase)
|
||||||
|
i, curCondition := podutil.GetPodConditionFromList(pod.Status.Conditions, v1.PodReady)
|
||||||
|
// Only reconcile if "Ready" condition is present
|
||||||
|
if i >= 0 && curCondition.Status != podReadyCondition.Status {
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user