Class PodStatus
- java.lang.Object
-
- com.marcnuri.yakc.model.io.k8s.api.core.v1.PodStatus
-
- All Implemented Interfaces:
com.marcnuri.yakc.model.Model
public class PodStatus extends java.lang.Object implements com.marcnuri.yakc.model.Model
PodStatus represents information about the status of a pod. Status may trail the actual state of a system, especially if the node that hosts the pod cannot contact the control plane.
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static class
PodStatus.Builder
-
Constructor Summary
Constructors Constructor Description PodStatus()
PodStatus(java.util.List<PodCondition> conditions, java.util.List<ContainerStatus> containerStatuses, java.util.List<ContainerStatus> ephemeralContainerStatuses, java.lang.String hostIP, java.util.List<HostIP> hostIPs, java.util.List<ContainerStatus> initContainerStatuses, java.lang.String message, java.lang.String nominatedNodeName, java.lang.String phase, java.lang.String podIP, java.util.List<PodIP> podIPs, java.lang.String qosClass, java.lang.String reason, java.lang.String resize, java.util.List<PodResourceClaimStatus> resourceClaimStatuses, java.time.OffsetDateTime startTime)
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description static PodStatus.Builder
builder()
protected boolean
canEqual(java.lang.Object other)
boolean
equals(java.lang.Object o)
java.util.List<PodCondition>
getConditions()
Current service state of pod.java.util.List<ContainerStatus>
getContainerStatuses()
The list has one entry per container in the manifest.java.util.List<ContainerStatus>
getEphemeralContainerStatuses()
Status for any ephemeral containers that have run in this pod.java.lang.String
getHostIP()
hostIP holds the IP address of the host to which the pod is assigned.java.util.List<HostIP>
getHostIPs()
hostIPs holds the IP addresses allocated to the host.java.util.List<ContainerStatus>
getInitContainerStatuses()
The list has one entry per init container in the manifest.java.lang.String
getMessage()
A human readable message indicating details about why the pod is in this condition.java.lang.String
getNominatedNodeName()
nominatedNodeName is set only when this pod preempts other pods on the node, but it cannot be scheduled right away as preemption victims receive their graceful termination periods.java.lang.String
getPhase()
The phase of a Pod is a simple, high-level summary of where the Pod is in its lifecycle.java.lang.String
getPodIP()
podIP address allocated to the pod.java.util.List<PodIP>
getPodIPs()
podIPs holds the IP addresses allocated to the pod.java.lang.String
getQosClass()
The Quality of Service (QOS) classification assigned to the pod based on resource requirements See PodQOSClass type for available QOS classes More info: https://kubernetes.io/docs/concepts/workloads/pods/pod-qos/#quality-of-service-classesjava.lang.String
getReason()
A brief CamelCase message indicating details about why the pod is in this state.java.lang.String
getResize()
Status of resources resize desired for pod's containers.java.util.List<PodResourceClaimStatus>
getResourceClaimStatuses()
Status of resource claims.java.time.OffsetDateTime
getStartTime()
int
hashCode()
void
setConditions(java.util.List<PodCondition> conditions)
Current service state of pod.void
setContainerStatuses(java.util.List<ContainerStatus> containerStatuses)
The list has one entry per container in the manifest.void
setEphemeralContainerStatuses(java.util.List<ContainerStatus> ephemeralContainerStatuses)
Status for any ephemeral containers that have run in this pod.void
setHostIP(java.lang.String hostIP)
hostIP holds the IP address of the host to which the pod is assigned.void
setHostIPs(java.util.List<HostIP> hostIPs)
hostIPs holds the IP addresses allocated to the host.void
setInitContainerStatuses(java.util.List<ContainerStatus> initContainerStatuses)
The list has one entry per init container in the manifest.void
setMessage(java.lang.String message)
A human readable message indicating details about why the pod is in this condition.void
setNominatedNodeName(java.lang.String nominatedNodeName)
nominatedNodeName is set only when this pod preempts other pods on the node, but it cannot be scheduled right away as preemption victims receive their graceful termination periods.void
setPhase(java.lang.String phase)
The phase of a Pod is a simple, high-level summary of where the Pod is in its lifecycle.void
setPodIP(java.lang.String podIP)
podIP address allocated to the pod.void
setPodIPs(java.util.List<PodIP> podIPs)
podIPs holds the IP addresses allocated to the pod.void
setQosClass(java.lang.String qosClass)
The Quality of Service (QOS) classification assigned to the pod based on resource requirements See PodQOSClass type for available QOS classes More info: https://kubernetes.io/docs/concepts/workloads/pods/pod-qos/#quality-of-service-classesvoid
setReason(java.lang.String reason)
A brief CamelCase message indicating details about why the pod is in this state.void
setResize(java.lang.String resize)
Status of resources resize desired for pod's containers.void
setResourceClaimStatuses(java.util.List<PodResourceClaimStatus> resourceClaimStatuses)
Status of resource claims.void
setStartTime(java.time.OffsetDateTime startTime)
PodStatus.Builder
toBuilder()
java.lang.String
toString()
-
-
-
Constructor Detail
-
PodStatus
public PodStatus(java.util.List<PodCondition> conditions, java.util.List<ContainerStatus> containerStatuses, java.util.List<ContainerStatus> ephemeralContainerStatuses, java.lang.String hostIP, java.util.List<HostIP> hostIPs, java.util.List<ContainerStatus> initContainerStatuses, java.lang.String message, java.lang.String nominatedNodeName, java.lang.String phase, java.lang.String podIP, java.util.List<PodIP> podIPs, java.lang.String qosClass, java.lang.String reason, java.lang.String resize, java.util.List<PodResourceClaimStatus> resourceClaimStatuses, java.time.OffsetDateTime startTime)
-
PodStatus
public PodStatus()
-
-
Method Detail
-
builder
public static PodStatus.Builder builder()
-
toBuilder
public PodStatus.Builder toBuilder()
-
getConditions
public java.util.List<PodCondition> getConditions()
Current service state of pod. More info: https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle#pod-conditions
-
getContainerStatuses
public java.util.List<ContainerStatus> getContainerStatuses()
The list has one entry per container in the manifest. More info: https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle#pod-and-container-status
-
getEphemeralContainerStatuses
public java.util.List<ContainerStatus> getEphemeralContainerStatuses()
Status for any ephemeral containers that have run in this pod.
-
getHostIP
public java.lang.String getHostIP()
hostIP holds the IP address of the host to which the pod is assigned. Empty if the pod has not started yet. A pod can be assigned to a node that has a problem in kubelet which in turns mean that HostIP will not be updated even if there is a node is assigned to pod
-
getHostIPs
public java.util.List<HostIP> getHostIPs()
hostIPs holds the IP addresses allocated to the host. If this field is specified, the first entry must match the hostIP field. This list is empty if the pod has not started yet. A pod can be assigned to a node that has a problem in kubelet which in turns means that HostIPs will not be updated even if there is a node is assigned to this pod.
-
getInitContainerStatuses
public java.util.List<ContainerStatus> getInitContainerStatuses()
The list has one entry per init container in the manifest. The most recent successful init container will have ready = true, the most recently started container will have startTime set. More info: https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle#pod-and-container-status
-
getMessage
public java.lang.String getMessage()
A human readable message indicating details about why the pod is in this condition.
-
getNominatedNodeName
public java.lang.String getNominatedNodeName()
nominatedNodeName is set only when this pod preempts other pods on the node, but it cannot be scheduled right away as preemption victims receive their graceful termination periods. This field does not guarantee that the pod will be scheduled on this node. Scheduler may decide to place the pod elsewhere if other nodes become available sooner. Scheduler may also decide to give the resources on this node to a higher priority pod that is created after preemption. As a result, this field may be different than PodSpec.nodeName when the pod is scheduled.
-
getPhase
public java.lang.String getPhase()
The phase of a Pod is a simple, high-level summary of where the Pod is in its lifecycle. The conditions array, the reason and message fields, and the individual container status arrays contain more detail about the pod's status. There are five possible phase values:Pending: The pod has been accepted by the Kubernetes system, but one or more of the container images has not been created. This includes time before being scheduled as well as time spent downloading images over the network, which could take a while. Running: The pod has been bound to a node, and all of the containers have been created. At least one container is still running, or is in the process of starting or restarting. Succeeded: All containers in the pod have terminated in success, and will not be restarted. Failed: All containers in the pod have terminated, and at least one container has terminated in failure. The container either exited with non-zero status or was terminated by the system. Unknown: For some reason the state of the pod could not be obtained, typically due to an error in communicating with the host of the pod.
More info: https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle#pod-phase
-
getPodIP
public java.lang.String getPodIP()
podIP address allocated to the pod. Routable at least within the cluster. Empty if not yet allocated.
-
getPodIPs
public java.util.List<PodIP> getPodIPs()
podIPs holds the IP addresses allocated to the pod. If this field is specified, the 0th entry must match the podIP field. Pods may be allocated at most 1 value for each of IPv4 and IPv6. This list is empty if no IPs have been allocated yet.
-
getQosClass
public java.lang.String getQosClass()
The Quality of Service (QOS) classification assigned to the pod based on resource requirements See PodQOSClass type for available QOS classes More info: https://kubernetes.io/docs/concepts/workloads/pods/pod-qos/#quality-of-service-classes
-
getReason
public java.lang.String getReason()
A brief CamelCase message indicating details about why the pod is in this state. e.g. 'Evicted'
-
getResize
public java.lang.String getResize()
Status of resources resize desired for pod's containers. It is empty if no resources resize is pending. Any changes to container resources will automatically set this to "Proposed"
-
getResourceClaimStatuses
public java.util.List<PodResourceClaimStatus> getResourceClaimStatuses()
Status of resource claims.
-
getStartTime
public java.time.OffsetDateTime getStartTime()
-
setConditions
public void setConditions(java.util.List<PodCondition> conditions)
Current service state of pod. More info: https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle#pod-conditions
-
setContainerStatuses
public void setContainerStatuses(java.util.List<ContainerStatus> containerStatuses)
The list has one entry per container in the manifest. More info: https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle#pod-and-container-status
-
setEphemeralContainerStatuses
public void setEphemeralContainerStatuses(java.util.List<ContainerStatus> ephemeralContainerStatuses)
Status for any ephemeral containers that have run in this pod.
-
setHostIP
public void setHostIP(java.lang.String hostIP)
hostIP holds the IP address of the host to which the pod is assigned. Empty if the pod has not started yet. A pod can be assigned to a node that has a problem in kubelet which in turns mean that HostIP will not be updated even if there is a node is assigned to pod
-
setHostIPs
public void setHostIPs(java.util.List<HostIP> hostIPs)
hostIPs holds the IP addresses allocated to the host. If this field is specified, the first entry must match the hostIP field. This list is empty if the pod has not started yet. A pod can be assigned to a node that has a problem in kubelet which in turns means that HostIPs will not be updated even if there is a node is assigned to this pod.
-
setInitContainerStatuses
public void setInitContainerStatuses(java.util.List<ContainerStatus> initContainerStatuses)
The list has one entry per init container in the manifest. The most recent successful init container will have ready = true, the most recently started container will have startTime set. More info: https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle#pod-and-container-status
-
setMessage
public void setMessage(java.lang.String message)
A human readable message indicating details about why the pod is in this condition.
-
setNominatedNodeName
public void setNominatedNodeName(java.lang.String nominatedNodeName)
nominatedNodeName is set only when this pod preempts other pods on the node, but it cannot be scheduled right away as preemption victims receive their graceful termination periods. This field does not guarantee that the pod will be scheduled on this node. Scheduler may decide to place the pod elsewhere if other nodes become available sooner. Scheduler may also decide to give the resources on this node to a higher priority pod that is created after preemption. As a result, this field may be different than PodSpec.nodeName when the pod is scheduled.
-
setPhase
public void setPhase(java.lang.String phase)
The phase of a Pod is a simple, high-level summary of where the Pod is in its lifecycle. The conditions array, the reason and message fields, and the individual container status arrays contain more detail about the pod's status. There are five possible phase values:Pending: The pod has been accepted by the Kubernetes system, but one or more of the container images has not been created. This includes time before being scheduled as well as time spent downloading images over the network, which could take a while. Running: The pod has been bound to a node, and all of the containers have been created. At least one container is still running, or is in the process of starting or restarting. Succeeded: All containers in the pod have terminated in success, and will not be restarted. Failed: All containers in the pod have terminated, and at least one container has terminated in failure. The container either exited with non-zero status or was terminated by the system. Unknown: For some reason the state of the pod could not be obtained, typically due to an error in communicating with the host of the pod.
More info: https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle#pod-phase
-
setPodIP
public void setPodIP(java.lang.String podIP)
podIP address allocated to the pod. Routable at least within the cluster. Empty if not yet allocated.
-
setPodIPs
public void setPodIPs(java.util.List<PodIP> podIPs)
podIPs holds the IP addresses allocated to the pod. If this field is specified, the 0th entry must match the podIP field. Pods may be allocated at most 1 value for each of IPv4 and IPv6. This list is empty if no IPs have been allocated yet.
-
setQosClass
public void setQosClass(java.lang.String qosClass)
The Quality of Service (QOS) classification assigned to the pod based on resource requirements See PodQOSClass type for available QOS classes More info: https://kubernetes.io/docs/concepts/workloads/pods/pod-qos/#quality-of-service-classes
-
setReason
public void setReason(java.lang.String reason)
A brief CamelCase message indicating details about why the pod is in this state. e.g. 'Evicted'
-
setResize
public void setResize(java.lang.String resize)
Status of resources resize desired for pod's containers. It is empty if no resources resize is pending. Any changes to container resources will automatically set this to "Proposed"
-
setResourceClaimStatuses
public void setResourceClaimStatuses(java.util.List<PodResourceClaimStatus> resourceClaimStatuses)
Status of resource claims.
-
setStartTime
public void setStartTime(java.time.OffsetDateTime startTime)
-
equals
public boolean equals(java.lang.Object o)
- Overrides:
equals
in classjava.lang.Object
-
canEqual
protected boolean canEqual(java.lang.Object other)
-
hashCode
public int hashCode()
- Overrides:
hashCode
in classjava.lang.Object
-
toString
public java.lang.String toString()
- Overrides:
toString
in classjava.lang.Object
-
-