All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.amazonaws.services.ecs.model.DeploymentCircuitBreaker Maven / Gradle / Ivy

Go to download

The AWS Java SDK for the Amazon EC2 Container Service holds the client classes that are used for communicating with the Amazon EC2 Container Service

There is a newer version: 1.12.780
Show newest version
/*
 * Copyright 2018-2023 Amazon.com, Inc. or its affiliates. All Rights Reserved.
 * 
 * Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance with
 * the License. A copy of the License is located at
 * 
 * http://aws.amazon.com/apache2.0
 * 
 * or in the "license" file accompanying this file. This file 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 com.amazonaws.services.ecs.model;

import java.io.Serializable;
import javax.annotation.Generated;
import com.amazonaws.protocol.StructuredPojo;
import com.amazonaws.protocol.ProtocolMarshaller;

/**
 * 
 * 

* The deployment circuit breaker can only be used for services using the rolling update (ECS) deployment * type. *

*
*

* The deployment circuit breaker determines whether a service deployment will fail if the service can't reach a * steady state. If it is turned on, a service deployment will transition to a failed state and stop launching new * tasks. You can also configure Amazon ECS to roll back your service to the last completed deployment after a failure. * For more information, see Rolling update in the * Amazon Elastic Container Service Developer Guide. *

*

* For more information about API failure reasons, see API failure reasons * in the Amazon Elastic Container Service Developer Guide. *

* * @see AWS API * Documentation */ @Generated("com.amazonaws:aws-java-sdk-code-generator") public class DeploymentCircuitBreaker implements Serializable, Cloneable, StructuredPojo { /** *

* Determines whether to use the deployment circuit breaker logic for the service. *

*/ private Boolean enable; /** *

* Determines whether to configure Amazon ECS to roll back the service if a service deployment fails. If rollback is * on, when a service deployment fails, the service is rolled back to the last deployment that completed * successfully. *

*/ private Boolean rollback; /** *

* Determines whether to use the deployment circuit breaker logic for the service. *

* * @param enable * Determines whether to use the deployment circuit breaker logic for the service. */ public void setEnable(Boolean enable) { this.enable = enable; } /** *

* Determines whether to use the deployment circuit breaker logic for the service. *

* * @return Determines whether to use the deployment circuit breaker logic for the service. */ public Boolean getEnable() { return this.enable; } /** *

* Determines whether to use the deployment circuit breaker logic for the service. *

* * @param enable * Determines whether to use the deployment circuit breaker logic for the service. * @return Returns a reference to this object so that method calls can be chained together. */ public DeploymentCircuitBreaker withEnable(Boolean enable) { setEnable(enable); return this; } /** *

* Determines whether to use the deployment circuit breaker logic for the service. *

* * @return Determines whether to use the deployment circuit breaker logic for the service. */ public Boolean isEnable() { return this.enable; } /** *

* Determines whether to configure Amazon ECS to roll back the service if a service deployment fails. If rollback is * on, when a service deployment fails, the service is rolled back to the last deployment that completed * successfully. *

* * @param rollback * Determines whether to configure Amazon ECS to roll back the service if a service deployment fails. If * rollback is on, when a service deployment fails, the service is rolled back to the last deployment that * completed successfully. */ public void setRollback(Boolean rollback) { this.rollback = rollback; } /** *

* Determines whether to configure Amazon ECS to roll back the service if a service deployment fails. If rollback is * on, when a service deployment fails, the service is rolled back to the last deployment that completed * successfully. *

* * @return Determines whether to configure Amazon ECS to roll back the service if a service deployment fails. If * rollback is on, when a service deployment fails, the service is rolled back to the last deployment that * completed successfully. */ public Boolean getRollback() { return this.rollback; } /** *

* Determines whether to configure Amazon ECS to roll back the service if a service deployment fails. If rollback is * on, when a service deployment fails, the service is rolled back to the last deployment that completed * successfully. *

* * @param rollback * Determines whether to configure Amazon ECS to roll back the service if a service deployment fails. If * rollback is on, when a service deployment fails, the service is rolled back to the last deployment that * completed successfully. * @return Returns a reference to this object so that method calls can be chained together. */ public DeploymentCircuitBreaker withRollback(Boolean rollback) { setRollback(rollback); return this; } /** *

* Determines whether to configure Amazon ECS to roll back the service if a service deployment fails. If rollback is * on, when a service deployment fails, the service is rolled back to the last deployment that completed * successfully. *

* * @return Determines whether to configure Amazon ECS to roll back the service if a service deployment fails. If * rollback is on, when a service deployment fails, the service is rolled back to the last deployment that * completed successfully. */ public Boolean isRollback() { return this.rollback; } /** * Returns a string representation of this object. This is useful for testing and debugging. Sensitive data will be * redacted from this string using a placeholder value. * * @return A string representation of this object. * * @see java.lang.Object#toString() */ @Override public String toString() { StringBuilder sb = new StringBuilder(); sb.append("{"); if (getEnable() != null) sb.append("Enable: ").append(getEnable()).append(","); if (getRollback() != null) sb.append("Rollback: ").append(getRollback()); sb.append("}"); return sb.toString(); } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof DeploymentCircuitBreaker == false) return false; DeploymentCircuitBreaker other = (DeploymentCircuitBreaker) obj; if (other.getEnable() == null ^ this.getEnable() == null) return false; if (other.getEnable() != null && other.getEnable().equals(this.getEnable()) == false) return false; if (other.getRollback() == null ^ this.getRollback() == null) return false; if (other.getRollback() != null && other.getRollback().equals(this.getRollback()) == false) return false; return true; } @Override public int hashCode() { final int prime = 31; int hashCode = 1; hashCode = prime * hashCode + ((getEnable() == null) ? 0 : getEnable().hashCode()); hashCode = prime * hashCode + ((getRollback() == null) ? 0 : getRollback().hashCode()); return hashCode; } @Override public DeploymentCircuitBreaker clone() { try { return (DeploymentCircuitBreaker) super.clone(); } catch (CloneNotSupportedException e) { throw new IllegalStateException("Got a CloneNotSupportedException from Object.clone() " + "even though we're Cloneable!", e); } } @com.amazonaws.annotation.SdkInternalApi @Override public void marshall(ProtocolMarshaller protocolMarshaller) { com.amazonaws.services.ecs.model.transform.DeploymentCircuitBreakerMarshaller.getInstance().marshall(this, protocolMarshaller); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy