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

com.amazonaws.services.ecs.model.PlacementStrategy 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 2015-2020 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 task placement strategy for a task or service. For more information, see Task Placement * Strategies in the Amazon Elastic Container Service Developer Guide. *

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

* The type of placement strategy. The random placement strategy randomly places tasks on available * candidates. The spread placement strategy spreads placement across available candidates evenly based * on the field parameter. The binpack strategy places tasks on available candidates that * have the least available amount of the resource that is specified with the field parameter. For * example, if you binpack on memory, a task is placed on the instance with the least amount of remaining memory * (but still enough to run the task). *

*/ private String type; /** *

* The field to apply the placement strategy against. For the spread placement strategy, valid values * are instanceId (or host, which has the same effect), or any platform or custom * attribute that is applied to a container instance, such as attribute:ecs.availability-zone. For the * binpack placement strategy, valid values are cpu and memory. For the * random placement strategy, this field is not used. *

*/ private String field; /** *

* The type of placement strategy. The random placement strategy randomly places tasks on available * candidates. The spread placement strategy spreads placement across available candidates evenly based * on the field parameter. The binpack strategy places tasks on available candidates that * have the least available amount of the resource that is specified with the field parameter. For * example, if you binpack on memory, a task is placed on the instance with the least amount of remaining memory * (but still enough to run the task). *

* * @param type * The type of placement strategy. The random placement strategy randomly places tasks on * available candidates. The spread placement strategy spreads placement across available * candidates evenly based on the field parameter. The binpack strategy places * tasks on available candidates that have the least available amount of the resource that is specified with * the field parameter. For example, if you binpack on memory, a task is placed on the instance * with the least amount of remaining memory (but still enough to run the task). * @see PlacementStrategyType */ public void setType(String type) { this.type = type; } /** *

* The type of placement strategy. The random placement strategy randomly places tasks on available * candidates. The spread placement strategy spreads placement across available candidates evenly based * on the field parameter. The binpack strategy places tasks on available candidates that * have the least available amount of the resource that is specified with the field parameter. For * example, if you binpack on memory, a task is placed on the instance with the least amount of remaining memory * (but still enough to run the task). *

* * @return The type of placement strategy. The random placement strategy randomly places tasks on * available candidates. The spread placement strategy spreads placement across available * candidates evenly based on the field parameter. The binpack strategy places * tasks on available candidates that have the least available amount of the resource that is specified with * the field parameter. For example, if you binpack on memory, a task is placed on the instance * with the least amount of remaining memory (but still enough to run the task). * @see PlacementStrategyType */ public String getType() { return this.type; } /** *

* The type of placement strategy. The random placement strategy randomly places tasks on available * candidates. The spread placement strategy spreads placement across available candidates evenly based * on the field parameter. The binpack strategy places tasks on available candidates that * have the least available amount of the resource that is specified with the field parameter. For * example, if you binpack on memory, a task is placed on the instance with the least amount of remaining memory * (but still enough to run the task). *

* * @param type * The type of placement strategy. The random placement strategy randomly places tasks on * available candidates. The spread placement strategy spreads placement across available * candidates evenly based on the field parameter. The binpack strategy places * tasks on available candidates that have the least available amount of the resource that is specified with * the field parameter. For example, if you binpack on memory, a task is placed on the instance * with the least amount of remaining memory (but still enough to run the task). * @return Returns a reference to this object so that method calls can be chained together. * @see PlacementStrategyType */ public PlacementStrategy withType(String type) { setType(type); return this; } /** *

* The type of placement strategy. The random placement strategy randomly places tasks on available * candidates. The spread placement strategy spreads placement across available candidates evenly based * on the field parameter. The binpack strategy places tasks on available candidates that * have the least available amount of the resource that is specified with the field parameter. For * example, if you binpack on memory, a task is placed on the instance with the least amount of remaining memory * (but still enough to run the task). *

* * @param type * The type of placement strategy. The random placement strategy randomly places tasks on * available candidates. The spread placement strategy spreads placement across available * candidates evenly based on the field parameter. The binpack strategy places * tasks on available candidates that have the least available amount of the resource that is specified with * the field parameter. For example, if you binpack on memory, a task is placed on the instance * with the least amount of remaining memory (but still enough to run the task). * @see PlacementStrategyType */ public void setType(PlacementStrategyType type) { withType(type); } /** *

* The type of placement strategy. The random placement strategy randomly places tasks on available * candidates. The spread placement strategy spreads placement across available candidates evenly based * on the field parameter. The binpack strategy places tasks on available candidates that * have the least available amount of the resource that is specified with the field parameter. For * example, if you binpack on memory, a task is placed on the instance with the least amount of remaining memory * (but still enough to run the task). *

* * @param type * The type of placement strategy. The random placement strategy randomly places tasks on * available candidates. The spread placement strategy spreads placement across available * candidates evenly based on the field parameter. The binpack strategy places * tasks on available candidates that have the least available amount of the resource that is specified with * the field parameter. For example, if you binpack on memory, a task is placed on the instance * with the least amount of remaining memory (but still enough to run the task). * @return Returns a reference to this object so that method calls can be chained together. * @see PlacementStrategyType */ public PlacementStrategy withType(PlacementStrategyType type) { this.type = type.toString(); return this; } /** *

* The field to apply the placement strategy against. For the spread placement strategy, valid values * are instanceId (or host, which has the same effect), or any platform or custom * attribute that is applied to a container instance, such as attribute:ecs.availability-zone. For the * binpack placement strategy, valid values are cpu and memory. For the * random placement strategy, this field is not used. *

* * @param field * The field to apply the placement strategy against. For the spread placement strategy, valid * values are instanceId (or host, which has the same effect), or any platform or * custom attribute that is applied to a container instance, such as * attribute:ecs.availability-zone. For the binpack placement strategy, valid * values are cpu and memory. For the random placement strategy, this * field is not used. */ public void setField(String field) { this.field = field; } /** *

* The field to apply the placement strategy against. For the spread placement strategy, valid values * are instanceId (or host, which has the same effect), or any platform or custom * attribute that is applied to a container instance, such as attribute:ecs.availability-zone. For the * binpack placement strategy, valid values are cpu and memory. For the * random placement strategy, this field is not used. *

* * @return The field to apply the placement strategy against. For the spread placement strategy, valid * values are instanceId (or host, which has the same effect), or any platform or * custom attribute that is applied to a container instance, such as * attribute:ecs.availability-zone. For the binpack placement strategy, valid * values are cpu and memory. For the random placement strategy, this * field is not used. */ public String getField() { return this.field; } /** *

* The field to apply the placement strategy against. For the spread placement strategy, valid values * are instanceId (or host, which has the same effect), or any platform or custom * attribute that is applied to a container instance, such as attribute:ecs.availability-zone. For the * binpack placement strategy, valid values are cpu and memory. For the * random placement strategy, this field is not used. *

* * @param field * The field to apply the placement strategy against. For the spread placement strategy, valid * values are instanceId (or host, which has the same effect), or any platform or * custom attribute that is applied to a container instance, such as * attribute:ecs.availability-zone. For the binpack placement strategy, valid * values are cpu and memory. For the random placement strategy, this * field is not used. * @return Returns a reference to this object so that method calls can be chained together. */ public PlacementStrategy withField(String field) { setField(field); return this; } /** * 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 (getType() != null) sb.append("Type: ").append(getType()).append(","); if (getField() != null) sb.append("Field: ").append(getField()); sb.append("}"); return sb.toString(); } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof PlacementStrategy == false) return false; PlacementStrategy other = (PlacementStrategy) obj; if (other.getType() == null ^ this.getType() == null) return false; if (other.getType() != null && other.getType().equals(this.getType()) == false) return false; if (other.getField() == null ^ this.getField() == null) return false; if (other.getField() != null && other.getField().equals(this.getField()) == false) return false; return true; } @Override public int hashCode() { final int prime = 31; int hashCode = 1; hashCode = prime * hashCode + ((getType() == null) ? 0 : getType().hashCode()); hashCode = prime * hashCode + ((getField() == null) ? 0 : getField().hashCode()); return hashCode; } @Override public PlacementStrategy clone() { try { return (PlacementStrategy) 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.PlacementStrategyMarshaller.getInstance().marshall(this, protocolMarshaller); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy