pub struct MachineDeploymentSpec {
pub cluster_name: String,
pub machine_naming_strategy: Option<MachineDeploymentMachineNamingStrategy>,
pub min_ready_seconds: Option<i32>,
pub paused: Option<bool>,
pub progress_deadline_seconds: Option<i32>,
pub replicas: Option<i32>,
pub revision_history_limit: Option<i32>,
pub rollout_after: Option<String>,
pub selector: MachineDeploymentSelector,
pub strategy: Option<MachineDeploymentStrategy>,
pub template: MachineDeploymentTemplate,
}
Expand description
spec is the desired state of MachineDeployment.
Fields§
§cluster_name: String
clusterName is the name of the Cluster this object belongs to.
machine_naming_strategy: Option<MachineDeploymentMachineNamingStrategy>
machineNamingStrategy allows changing the naming pattern used when creating Machines. Note: InfraMachines & BootstrapConfigs will use the same name as the corresponding Machines.
min_ready_seconds: Option<i32>
minReadySeconds is the minimum number of seconds for which a Node for a newly created machine should be ready before considering the replica available. Defaults to 0 (machine will be considered available as soon as the Node is ready)
paused: Option<bool>
paused indicates that the deployment is paused.
progress_deadline_seconds: Option<i32>
progressDeadlineSeconds is the maximum time in seconds for a deployment to make progress before it is considered to be failed. The deployment controller will continue to process failed deployments and a condition with a ProgressDeadlineExceeded reason will be surfaced in the deployment status. Note that progress will not be estimated during the time a deployment is paused. Defaults to 600s.
Deprecated: This field is deprecated and is going to be removed in the next apiVersion. Please see https://github.com/kubernetes-sigs/cluster-api/issues/11470 for more details.
replicas: Option<i32>
replicas is the number of desired machines. This is a pointer to distinguish between explicit zero and not specified.
Defaults to:
- if the Kubernetes autoscaler min size and max size annotations are set:
- if it’s a new MachineDeployment, use min size
- if the replicas field of the old MachineDeployment is < min size, use min size
- if the replicas field of the old MachineDeployment is > max size, use max size
- if the replicas field of the old MachineDeployment is in the (min size, max size) range, keep the value from the oldMD
- otherwise use 1 Note: Defaulting will be run whenever the replicas field is not set:
- A new MachineDeployment is created with replicas not set.
- On an existing MachineDeployment the replicas field was first set and is now unset. Those cases are especially relevant for the following Kubernetes autoscaler use cases:
- A new MachineDeployment is created and replicas should be managed by the autoscaler
- An existing MachineDeployment which initially wasn’t controlled by the autoscaler should be later controlled by the autoscaler
revision_history_limit: Option<i32>
revisionHistoryLimit is the number of old MachineSets to retain to allow rollback. This is a pointer to distinguish between explicit zero and not specified. Defaults to 1.
Deprecated: This field is deprecated and is going to be removed in the next apiVersion. Please see https://github.com/kubernetes-sigs/cluster-api/issues/10479 for more details.
rollout_after: Option<String>
rolloutAfter is a field to indicate a rollout should be performed after the specified time even if no changes have been made to the MachineDeployment. Example: In the YAML the time can be specified in the RFC3339 format. To specify the rolloutAfter target as March 9, 2023, at 9 am UTC use “2023-03-09T09:00:00Z”.
selector: MachineDeploymentSelector
selector is the label selector for machines. Existing MachineSets whose machines are selected by this will be the ones affected by this deployment. It must match the machine template’s labels.
strategy: Option<MachineDeploymentStrategy>
strategy is the deployment strategy to use to replace existing machines with new ones.
template: MachineDeploymentTemplate
template describes the machines that will be created.
Trait Implementations§
Source§impl Clone for MachineDeploymentSpec
impl Clone for MachineDeploymentSpec
Source§fn clone(&self) -> MachineDeploymentSpec
fn clone(&self) -> MachineDeploymentSpec
1.0.0 · Source§const fn clone_from(&mut self, source: &Self)
const fn clone_from(&mut self, source: &Self)
source
. Read moreSource§impl Debug for MachineDeploymentSpec
impl Debug for MachineDeploymentSpec
Source§impl Default for MachineDeploymentSpec
impl Default for MachineDeploymentSpec
Source§fn default() -> MachineDeploymentSpec
fn default() -> MachineDeploymentSpec
Source§impl<'de> Deserialize<'de> for MachineDeploymentSpec
impl<'de> Deserialize<'de> for MachineDeploymentSpec
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Source§impl JsonSchema for MachineDeploymentSpec
impl JsonSchema for MachineDeploymentSpec
Source§fn schema_name() -> String
fn schema_name() -> String
Source§fn schema_id() -> Cow<'static, str>
fn schema_id() -> Cow<'static, str>
Source§fn json_schema(generator: &mut SchemaGenerator) -> Schema
fn json_schema(generator: &mut SchemaGenerator) -> Schema
Source§fn is_referenceable() -> bool
fn is_referenceable() -> bool
$ref
keyword. Read moreSource§impl PartialEq for MachineDeploymentSpec
impl PartialEq for MachineDeploymentSpec
Source§impl Serialize for MachineDeploymentSpec
impl Serialize for MachineDeploymentSpec
impl StructuralPartialEq for MachineDeploymentSpec
Auto Trait Implementations§
impl Freeze for MachineDeploymentSpec
impl RefUnwindSafe for MachineDeploymentSpec
impl Send for MachineDeploymentSpec
impl Sync for MachineDeploymentSpec
impl Unpin for MachineDeploymentSpec
impl UnwindSafe for MachineDeploymentSpec
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more