/* * 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; /** *
* Details on the network bindings between a container and its host container instance. After a task reaches the
* RUNNING
status, manual and automatic host and container port assignments are visible in the
* networkBindings
section of DescribeTasks API responses.
*
* The IP address that the container is bound to on the container instance. *
*/ private String bindIP; /** ** The port number on the container that's used with the network binding. *
*/ private Integer containerPort; /** ** The port number on the host that's used with the network binding. *
*/ private Integer hostPort; /** ** The protocol used for the network binding. *
*/ private String protocol; /** ** The port number range on the container that's bound to the dynamically mapped host port range. *
*
* The following rules apply when you specify a containerPortRange
:
*
* You must use either the bridge
network mode or the awsvpc
network mode.
*
* This parameter is available for both the EC2 and Fargate launch types. *
** This parameter is available for both the Linux and Windows operating systems. *
*
* The container instance must have at least version 1.67.0 of the container agent and at least version 1.67.0-1 of
* the ecs-init
package
*
* You can specify a maximum of 100 port ranges per container. *
*
* You do not specify a hostPortRange
. The value of the hostPortRange
is set as follows:
*
* For containers in a task with the awsvpc
network mode, the hostPort
is set to the same
* value as the containerPort
. This is a static mapping strategy.
*
* For containers in a task with the bridge
network mode, the Amazon ECS agent finds open host ports
* from the default ephemeral range and passes it to docker to bind them to the container ports.
*
* The containerPortRange
valid values are between 1 and 65535.
*
* A port can only be included in one port mapping per container. *
** You cannot specify overlapping port ranges. *
** The first port in the range must be less than last port in the range. *
** Docker recommends that you turn off the docker-proxy in the Docker daemon config file when you have a large * number of ports. *
** For more information, see Issue #11185 on the Github * website. *
** For information about how to turn off the docker-proxy in the Docker daemon config file, see Docker daemon in the Amazon ECS Developer Guide. *
*
* You can call
* DescribeTasks
to view the hostPortRange
which are the host ports that are bound to
* the container ports.
*
* The port number range on the host that's used with the network binding. This is assigned is assigned by Docker * and delivered by the Amazon ECS agent. *
*/ private String hostPortRange; /** ** The IP address that the container is bound to on the container instance. *
* * @param bindIP * The IP address that the container is bound to on the container instance. */ public void setBindIP(String bindIP) { this.bindIP = bindIP; } /** ** The IP address that the container is bound to on the container instance. *
* * @return The IP address that the container is bound to on the container instance. */ public String getBindIP() { return this.bindIP; } /** ** The IP address that the container is bound to on the container instance. *
* * @param bindIP * The IP address that the container is bound to on the container instance. * @return Returns a reference to this object so that method calls can be chained together. */ public NetworkBinding withBindIP(String bindIP) { setBindIP(bindIP); return this; } /** ** The port number on the container that's used with the network binding. *
* * @param containerPort * The port number on the container that's used with the network binding. */ public void setContainerPort(Integer containerPort) { this.containerPort = containerPort; } /** ** The port number on the container that's used with the network binding. *
* * @return The port number on the container that's used with the network binding. */ public Integer getContainerPort() { return this.containerPort; } /** ** The port number on the container that's used with the network binding. *
* * @param containerPort * The port number on the container that's used with the network binding. * @return Returns a reference to this object so that method calls can be chained together. */ public NetworkBinding withContainerPort(Integer containerPort) { setContainerPort(containerPort); return this; } /** ** The port number on the host that's used with the network binding. *
* * @param hostPort * The port number on the host that's used with the network binding. */ public void setHostPort(Integer hostPort) { this.hostPort = hostPort; } /** ** The port number on the host that's used with the network binding. *
* * @return The port number on the host that's used with the network binding. */ public Integer getHostPort() { return this.hostPort; } /** ** The port number on the host that's used with the network binding. *
* * @param hostPort * The port number on the host that's used with the network binding. * @return Returns a reference to this object so that method calls can be chained together. */ public NetworkBinding withHostPort(Integer hostPort) { setHostPort(hostPort); return this; } /** ** The protocol used for the network binding. *
* * @param protocol * The protocol used for the network binding. * @see TransportProtocol */ public void setProtocol(String protocol) { this.protocol = protocol; } /** ** The protocol used for the network binding. *
* * @return The protocol used for the network binding. * @see TransportProtocol */ public String getProtocol() { return this.protocol; } /** ** The protocol used for the network binding. *
* * @param protocol * The protocol used for the network binding. * @return Returns a reference to this object so that method calls can be chained together. * @see TransportProtocol */ public NetworkBinding withProtocol(String protocol) { setProtocol(protocol); return this; } /** ** The protocol used for the network binding. *
* * @param protocol * The protocol used for the network binding. * @see TransportProtocol */ public void setProtocol(TransportProtocol protocol) { withProtocol(protocol); } /** ** The protocol used for the network binding. *
* * @param protocol * The protocol used for the network binding. * @return Returns a reference to this object so that method calls can be chained together. * @see TransportProtocol */ public NetworkBinding withProtocol(TransportProtocol protocol) { this.protocol = protocol.toString(); return this; } /** ** The port number range on the container that's bound to the dynamically mapped host port range. *
*
* The following rules apply when you specify a containerPortRange
:
*
* You must use either the bridge
network mode or the awsvpc
network mode.
*
* This parameter is available for both the EC2 and Fargate launch types. *
** This parameter is available for both the Linux and Windows operating systems. *
*
* The container instance must have at least version 1.67.0 of the container agent and at least version 1.67.0-1 of
* the ecs-init
package
*
* You can specify a maximum of 100 port ranges per container. *
*
* You do not specify a hostPortRange
. The value of the hostPortRange
is set as follows:
*
* For containers in a task with the awsvpc
network mode, the hostPort
is set to the same
* value as the containerPort
. This is a static mapping strategy.
*
* For containers in a task with the bridge
network mode, the Amazon ECS agent finds open host ports
* from the default ephemeral range and passes it to docker to bind them to the container ports.
*
* The containerPortRange
valid values are between 1 and 65535.
*
* A port can only be included in one port mapping per container. *
** You cannot specify overlapping port ranges. *
** The first port in the range must be less than last port in the range. *
** Docker recommends that you turn off the docker-proxy in the Docker daemon config file when you have a large * number of ports. *
** For more information, see Issue #11185 on the Github * website. *
** For information about how to turn off the docker-proxy in the Docker daemon config file, see Docker daemon in the Amazon ECS Developer Guide. *
*
* You can call
* DescribeTasks
to view the hostPortRange
which are the host ports that are bound to
* the container ports.
*
* The following rules apply when you specify a containerPortRange
:
*
* You must use either the bridge
network mode or the awsvpc
network mode.
*
* This parameter is available for both the EC2 and Fargate launch types. *
** This parameter is available for both the Linux and Windows operating systems. *
*
* The container instance must have at least version 1.67.0 of the container agent and at least version
* 1.67.0-1 of the ecs-init
package
*
* You can specify a maximum of 100 port ranges per container. *
*
* You do not specify a hostPortRange
. The value of the hostPortRange
is set as
* follows:
*
* For containers in a task with the awsvpc
network mode, the hostPort
is set to
* the same value as the containerPort
. This is a static mapping strategy.
*
* For containers in a task with the bridge
network mode, the Amazon ECS agent finds open host
* ports from the default ephemeral range and passes it to docker to bind them to the container ports.
*
* The containerPortRange
valid values are between 1 and 65535.
*
* A port can only be included in one port mapping per container. *
** You cannot specify overlapping port ranges. *
** The first port in the range must be less than last port in the range. *
** Docker recommends that you turn off the docker-proxy in the Docker daemon config file when you have a * large number of ports. *
** For more information, see Issue #11185 on the * Github website. *
** For information about how to turn off the docker-proxy in the Docker daemon config file, see Docker daemon in the Amazon ECS Developer Guide. *
*
* You can call
* DescribeTasks
to view the hostPortRange
which are the host ports that are
* bound to the container ports.
*/
public void setContainerPortRange(String containerPortRange) {
this.containerPortRange = containerPortRange;
}
/**
*
* The port number range on the container that's bound to the dynamically mapped host port range. *
*
* The following rules apply when you specify a containerPortRange
:
*
* You must use either the bridge
network mode or the awsvpc
network mode.
*
* This parameter is available for both the EC2 and Fargate launch types. *
** This parameter is available for both the Linux and Windows operating systems. *
*
* The container instance must have at least version 1.67.0 of the container agent and at least version 1.67.0-1 of
* the ecs-init
package
*
* You can specify a maximum of 100 port ranges per container. *
*
* You do not specify a hostPortRange
. The value of the hostPortRange
is set as follows:
*
* For containers in a task with the awsvpc
network mode, the hostPort
is set to the same
* value as the containerPort
. This is a static mapping strategy.
*
* For containers in a task with the bridge
network mode, the Amazon ECS agent finds open host ports
* from the default ephemeral range and passes it to docker to bind them to the container ports.
*
* The containerPortRange
valid values are between 1 and 65535.
*
* A port can only be included in one port mapping per container. *
** You cannot specify overlapping port ranges. *
** The first port in the range must be less than last port in the range. *
** Docker recommends that you turn off the docker-proxy in the Docker daemon config file when you have a large * number of ports. *
** For more information, see Issue #11185 on the Github * website. *
** For information about how to turn off the docker-proxy in the Docker daemon config file, see Docker daemon in the Amazon ECS Developer Guide. *
*
* You can call
* DescribeTasks
to view the hostPortRange
which are the host ports that are bound to
* the container ports.
*
* The following rules apply when you specify a containerPortRange
:
*
* You must use either the bridge
network mode or the awsvpc
network mode.
*
* This parameter is available for both the EC2 and Fargate launch types. *
** This parameter is available for both the Linux and Windows operating systems. *
*
* The container instance must have at least version 1.67.0 of the container agent and at least version
* 1.67.0-1 of the ecs-init
package
*
* You can specify a maximum of 100 port ranges per container. *
*
* You do not specify a hostPortRange
. The value of the hostPortRange
is set as
* follows:
*
* For containers in a task with the awsvpc
network mode, the hostPort
is set to
* the same value as the containerPort
. This is a static mapping strategy.
*
* For containers in a task with the bridge
network mode, the Amazon ECS agent finds open host
* ports from the default ephemeral range and passes it to docker to bind them to the container ports.
*
* The containerPortRange
valid values are between 1 and 65535.
*
* A port can only be included in one port mapping per container. *
** You cannot specify overlapping port ranges. *
** The first port in the range must be less than last port in the range. *
** Docker recommends that you turn off the docker-proxy in the Docker daemon config file when you have a * large number of ports. *
** For more information, see Issue #11185 on the * Github website. *
** For information about how to turn off the docker-proxy in the Docker daemon config file, see Docker daemon in the Amazon ECS Developer Guide. *
*
* You can call
* DescribeTasks
to view the hostPortRange
which are the host ports that are
* bound to the container ports.
*/
public String getContainerPortRange() {
return this.containerPortRange;
}
/**
*
* The port number range on the container that's bound to the dynamically mapped host port range. *
*
* The following rules apply when you specify a containerPortRange
:
*
* You must use either the bridge
network mode or the awsvpc
network mode.
*
* This parameter is available for both the EC2 and Fargate launch types. *
** This parameter is available for both the Linux and Windows operating systems. *
*
* The container instance must have at least version 1.67.0 of the container agent and at least version 1.67.0-1 of
* the ecs-init
package
*
* You can specify a maximum of 100 port ranges per container. *
*
* You do not specify a hostPortRange
. The value of the hostPortRange
is set as follows:
*
* For containers in a task with the awsvpc
network mode, the hostPort
is set to the same
* value as the containerPort
. This is a static mapping strategy.
*
* For containers in a task with the bridge
network mode, the Amazon ECS agent finds open host ports
* from the default ephemeral range and passes it to docker to bind them to the container ports.
*
* The containerPortRange
valid values are between 1 and 65535.
*
* A port can only be included in one port mapping per container. *
** You cannot specify overlapping port ranges. *
** The first port in the range must be less than last port in the range. *
** Docker recommends that you turn off the docker-proxy in the Docker daemon config file when you have a large * number of ports. *
** For more information, see Issue #11185 on the Github * website. *
** For information about how to turn off the docker-proxy in the Docker daemon config file, see Docker daemon in the Amazon ECS Developer Guide. *
*
* You can call
* DescribeTasks
to view the hostPortRange
which are the host ports that are bound to
* the container ports.
*
* The following rules apply when you specify a containerPortRange
:
*
* You must use either the bridge
network mode or the awsvpc
network mode.
*
* This parameter is available for both the EC2 and Fargate launch types. *
** This parameter is available for both the Linux and Windows operating systems. *
*
* The container instance must have at least version 1.67.0 of the container agent and at least version
* 1.67.0-1 of the ecs-init
package
*
* You can specify a maximum of 100 port ranges per container. *
*
* You do not specify a hostPortRange
. The value of the hostPortRange
is set as
* follows:
*
* For containers in a task with the awsvpc
network mode, the hostPort
is set to
* the same value as the containerPort
. This is a static mapping strategy.
*
* For containers in a task with the bridge
network mode, the Amazon ECS agent finds open host
* ports from the default ephemeral range and passes it to docker to bind them to the container ports.
*
* The containerPortRange
valid values are between 1 and 65535.
*
* A port can only be included in one port mapping per container. *
** You cannot specify overlapping port ranges. *
** The first port in the range must be less than last port in the range. *
** Docker recommends that you turn off the docker-proxy in the Docker daemon config file when you have a * large number of ports. *
** For more information, see Issue #11185 on the * Github website. *
** For information about how to turn off the docker-proxy in the Docker daemon config file, see Docker daemon in the Amazon ECS Developer Guide. *
*
* You can call
* DescribeTasks
to view the hostPortRange
which are the host ports that are
* bound to the container ports.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public NetworkBinding withContainerPortRange(String containerPortRange) {
setContainerPortRange(containerPortRange);
return this;
}
/**
*
* The port number range on the host that's used with the network binding. This is assigned is assigned by Docker * and delivered by the Amazon ECS agent. *
* * @param hostPortRange * The port number range on the host that's used with the network binding. This is assigned is assigned by * Docker and delivered by the Amazon ECS agent. */ public void setHostPortRange(String hostPortRange) { this.hostPortRange = hostPortRange; } /** ** The port number range on the host that's used with the network binding. This is assigned is assigned by Docker * and delivered by the Amazon ECS agent. *
* * @return The port number range on the host that's used with the network binding. This is assigned is assigned by * Docker and delivered by the Amazon ECS agent. */ public String getHostPortRange() { return this.hostPortRange; } /** ** The port number range on the host that's used with the network binding. This is assigned is assigned by Docker * and delivered by the Amazon ECS agent. *
* * @param hostPortRange * The port number range on the host that's used with the network binding. This is assigned is assigned by * Docker and delivered by the Amazon ECS agent. * @return Returns a reference to this object so that method calls can be chained together. */ public NetworkBinding withHostPortRange(String hostPortRange) { setHostPortRange(hostPortRange); 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 (getBindIP() != null) sb.append("BindIP: ").append(getBindIP()).append(","); if (getContainerPort() != null) sb.append("ContainerPort: ").append(getContainerPort()).append(","); if (getHostPort() != null) sb.append("HostPort: ").append(getHostPort()).append(","); if (getProtocol() != null) sb.append("Protocol: ").append(getProtocol()).append(","); if (getContainerPortRange() != null) sb.append("ContainerPortRange: ").append(getContainerPortRange()).append(","); if (getHostPortRange() != null) sb.append("HostPortRange: ").append(getHostPortRange()); sb.append("}"); return sb.toString(); } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof NetworkBinding == false) return false; NetworkBinding other = (NetworkBinding) obj; if (other.getBindIP() == null ^ this.getBindIP() == null) return false; if (other.getBindIP() != null && other.getBindIP().equals(this.getBindIP()) == false) return false; if (other.getContainerPort() == null ^ this.getContainerPort() == null) return false; if (other.getContainerPort() != null && other.getContainerPort().equals(this.getContainerPort()) == false) return false; if (other.getHostPort() == null ^ this.getHostPort() == null) return false; if (other.getHostPort() != null && other.getHostPort().equals(this.getHostPort()) == false) return false; if (other.getProtocol() == null ^ this.getProtocol() == null) return false; if (other.getProtocol() != null && other.getProtocol().equals(this.getProtocol()) == false) return false; if (other.getContainerPortRange() == null ^ this.getContainerPortRange() == null) return false; if (other.getContainerPortRange() != null && other.getContainerPortRange().equals(this.getContainerPortRange()) == false) return false; if (other.getHostPortRange() == null ^ this.getHostPortRange() == null) return false; if (other.getHostPortRange() != null && other.getHostPortRange().equals(this.getHostPortRange()) == false) return false; return true; } @Override public int hashCode() { final int prime = 31; int hashCode = 1; hashCode = prime * hashCode + ((getBindIP() == null) ? 0 : getBindIP().hashCode()); hashCode = prime * hashCode + ((getContainerPort() == null) ? 0 : getContainerPort().hashCode()); hashCode = prime * hashCode + ((getHostPort() == null) ? 0 : getHostPort().hashCode()); hashCode = prime * hashCode + ((getProtocol() == null) ? 0 : getProtocol().hashCode()); hashCode = prime * hashCode + ((getContainerPortRange() == null) ? 0 : getContainerPortRange().hashCode()); hashCode = prime * hashCode + ((getHostPortRange() == null) ? 0 : getHostPortRange().hashCode()); return hashCode; } @Override public NetworkBinding clone() { try { return (NetworkBinding) 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.NetworkBindingMarshaller.getInstance().marshall(this, protocolMarshaller); } }