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

com.oracle.bmc.loadbalancer.model.CreateBackendDetails Maven / Gradle / Ivy

/**
 * Copyright (c) 2016, 2024, Oracle and/or its affiliates.  All rights reserved.
 * This software is dual-licensed to you under the Universal Permissive License (UPL) 1.0 as shown at https://oss.oracle.com/licenses/upl or Apache License 2.0 as shown at http://www.apache.org/licenses/LICENSE-2.0. You may choose either license.
 */
package com.oracle.bmc.loadbalancer.model;

/**
 * The configuration details for creating a backend server in a backend set. For more information on
 * backend server configuration, see [Managing Backend
 * Servers](https://docs.cloud.oracle.com/Content/Balance/Tasks/managingbackendservers.htm). 
* Note: Objects should always be created or deserialized using the {@link Builder}. This model * distinguishes fields that are {@code null} because they are unset from fields that are explicitly * set to {@code null}. This is done in the setter methods of the {@link Builder}, which maintain a * set of all explicitly set fields called {@link Builder#__explicitlySet__}. The {@link * #hashCode()} and {@link #equals(Object)} methods are implemented to take the explicitly set * fields into account. The constructor, on the other hand, does not take the explicitly set fields * into account (since the constructor cannot distinguish explicit {@code null} from unset {@code * null}). */ @jakarta.annotation.Generated(value = "OracleSDKGenerator", comments = "API Version: 20170115") @com.fasterxml.jackson.databind.annotation.JsonDeserialize( builder = CreateBackendDetails.Builder.class) @com.fasterxml.jackson.annotation.JsonFilter( com.oracle.bmc.http.client.internal.ExplicitlySetBmcModel.EXPLICITLY_SET_FILTER_NAME) public final class CreateBackendDetails extends com.oracle.bmc.http.client.internal.ExplicitlySetBmcModel { @Deprecated @java.beans.ConstructorProperties({ "ipAddress", "port", "weight", "maxConnections", "backup", "drain", "offline" }) public CreateBackendDetails( String ipAddress, Integer port, Integer weight, Integer maxConnections, Boolean backup, Boolean drain, Boolean offline) { super(); this.ipAddress = ipAddress; this.port = port; this.weight = weight; this.maxConnections = maxConnections; this.backup = backup; this.drain = drain; this.offline = offline; } @com.fasterxml.jackson.databind.annotation.JsonPOJOBuilder(withPrefix = "") public static class Builder { /** * The IP address of the backend server. * *

Example: {@code 10.0.0.3} */ @com.fasterxml.jackson.annotation.JsonProperty("ipAddress") private String ipAddress; /** * The IP address of the backend server. * *

Example: {@code 10.0.0.3} * * @param ipAddress the value to set * @return this builder */ public Builder ipAddress(String ipAddress) { this.ipAddress = ipAddress; this.__explicitlySet__.add("ipAddress"); return this; } /** * The communication port for the backend server. * *

Example: {@code 8080} */ @com.fasterxml.jackson.annotation.JsonProperty("port") private Integer port; /** * The communication port for the backend server. * *

Example: {@code 8080} * * @param port the value to set * @return this builder */ public Builder port(Integer port) { this.port = port; this.__explicitlySet__.add("port"); return this; } /** * The load balancing policy weight assigned to the server. Backend servers with a higher * weight receive a larger proportion of incoming traffic. For example, a server weighted * '3' receives 3 times the number of new connections as a server weighted '1'. For more * information on load balancing policies, see [How Load Balancing Policies * Work](https://docs.cloud.oracle.com/Content/Balance/Reference/lbpolicies.htm). * *

Example: {@code 3} */ @com.fasterxml.jackson.annotation.JsonProperty("weight") private Integer weight; /** * The load balancing policy weight assigned to the server. Backend servers with a higher * weight receive a larger proportion of incoming traffic. For example, a server weighted * '3' receives 3 times the number of new connections as a server weighted '1'. For more * information on load balancing policies, see [How Load Balancing Policies * Work](https://docs.cloud.oracle.com/Content/Balance/Reference/lbpolicies.htm). * *

Example: {@code 3} * * @param weight the value to set * @return this builder */ public Builder weight(Integer weight) { this.weight = weight; this.__explicitlySet__.add("weight"); return this; } /** * The maximum number of simultaneous connections the load balancer can make to the backend. * If this is not set then number of simultaneous connections the load balancer can make to * the backend is unlimited. * *

Example: {@code 300} */ @com.fasterxml.jackson.annotation.JsonProperty("maxConnections") private Integer maxConnections; /** * The maximum number of simultaneous connections the load balancer can make to the backend. * If this is not set then number of simultaneous connections the load balancer can make to * the backend is unlimited. * *

Example: {@code 300} * * @param maxConnections the value to set * @return this builder */ public Builder maxConnections(Integer maxConnections) { this.maxConnections = maxConnections; this.__explicitlySet__.add("maxConnections"); return this; } /** * Whether the load balancer should treat this server as a backup unit. If {@code true}, the * load balancer forwards no ingress traffic to this backend server unless all other backend * servers not marked as "backup" fail the health check policy. * *

*Note:** You cannot add a backend server marked as {@code backup} to a backend set * that uses the IP Hash policy. * *

Example: {@code false} */ @com.fasterxml.jackson.annotation.JsonProperty("backup") private Boolean backup; /** * Whether the load balancer should treat this server as a backup unit. If {@code true}, the * load balancer forwards no ingress traffic to this backend server unless all other backend * servers not marked as "backup" fail the health check policy. * *

*Note:** You cannot add a backend server marked as {@code backup} to a backend set * that uses the IP Hash policy. * *

Example: {@code false} * * @param backup the value to set * @return this builder */ public Builder backup(Boolean backup) { this.backup = backup; this.__explicitlySet__.add("backup"); return this; } /** * Whether the load balancer should drain this server. Servers marked "drain" receive no new * incoming traffic. * *

Example: {@code false} */ @com.fasterxml.jackson.annotation.JsonProperty("drain") private Boolean drain; /** * Whether the load balancer should drain this server. Servers marked "drain" receive no new * incoming traffic. * *

Example: {@code false} * * @param drain the value to set * @return this builder */ public Builder drain(Boolean drain) { this.drain = drain; this.__explicitlySet__.add("drain"); return this; } /** * Whether the load balancer should treat this server as offline. Offline servers receive no * incoming traffic. * *

Example: {@code false} */ @com.fasterxml.jackson.annotation.JsonProperty("offline") private Boolean offline; /** * Whether the load balancer should treat this server as offline. Offline servers receive no * incoming traffic. * *

Example: {@code false} * * @param offline the value to set * @return this builder */ public Builder offline(Boolean offline) { this.offline = offline; this.__explicitlySet__.add("offline"); return this; } @com.fasterxml.jackson.annotation.JsonIgnore private final java.util.Set __explicitlySet__ = new java.util.HashSet(); public CreateBackendDetails build() { CreateBackendDetails model = new CreateBackendDetails( this.ipAddress, this.port, this.weight, this.maxConnections, this.backup, this.drain, this.offline); for (String explicitlySetProperty : this.__explicitlySet__) { model.markPropertyAsExplicitlySet(explicitlySetProperty); } return model; } @com.fasterxml.jackson.annotation.JsonIgnore public Builder copy(CreateBackendDetails model) { if (model.wasPropertyExplicitlySet("ipAddress")) { this.ipAddress(model.getIpAddress()); } if (model.wasPropertyExplicitlySet("port")) { this.port(model.getPort()); } if (model.wasPropertyExplicitlySet("weight")) { this.weight(model.getWeight()); } if (model.wasPropertyExplicitlySet("maxConnections")) { this.maxConnections(model.getMaxConnections()); } if (model.wasPropertyExplicitlySet("backup")) { this.backup(model.getBackup()); } if (model.wasPropertyExplicitlySet("drain")) { this.drain(model.getDrain()); } if (model.wasPropertyExplicitlySet("offline")) { this.offline(model.getOffline()); } return this; } } /** Create a new builder. */ public static Builder builder() { return new Builder(); } public Builder toBuilder() { return new Builder().copy(this); } /** * The IP address of the backend server. * *

Example: {@code 10.0.0.3} */ @com.fasterxml.jackson.annotation.JsonProperty("ipAddress") private final String ipAddress; /** * The IP address of the backend server. * *

Example: {@code 10.0.0.3} * * @return the value */ public String getIpAddress() { return ipAddress; } /** * The communication port for the backend server. * *

Example: {@code 8080} */ @com.fasterxml.jackson.annotation.JsonProperty("port") private final Integer port; /** * The communication port for the backend server. * *

Example: {@code 8080} * * @return the value */ public Integer getPort() { return port; } /** * The load balancing policy weight assigned to the server. Backend servers with a higher weight * receive a larger proportion of incoming traffic. For example, a server weighted '3' receives * 3 times the number of new connections as a server weighted '1'. For more information on load * balancing policies, see [How Load Balancing Policies * Work](https://docs.cloud.oracle.com/Content/Balance/Reference/lbpolicies.htm). * *

Example: {@code 3} */ @com.fasterxml.jackson.annotation.JsonProperty("weight") private final Integer weight; /** * The load balancing policy weight assigned to the server. Backend servers with a higher weight * receive a larger proportion of incoming traffic. For example, a server weighted '3' receives * 3 times the number of new connections as a server weighted '1'. For more information on load * balancing policies, see [How Load Balancing Policies * Work](https://docs.cloud.oracle.com/Content/Balance/Reference/lbpolicies.htm). * *

Example: {@code 3} * * @return the value */ public Integer getWeight() { return weight; } /** * The maximum number of simultaneous connections the load balancer can make to the backend. If * this is not set then number of simultaneous connections the load balancer can make to the * backend is unlimited. * *

Example: {@code 300} */ @com.fasterxml.jackson.annotation.JsonProperty("maxConnections") private final Integer maxConnections; /** * The maximum number of simultaneous connections the load balancer can make to the backend. If * this is not set then number of simultaneous connections the load balancer can make to the * backend is unlimited. * *

Example: {@code 300} * * @return the value */ public Integer getMaxConnections() { return maxConnections; } /** * Whether the load balancer should treat this server as a backup unit. If {@code true}, the * load balancer forwards no ingress traffic to this backend server unless all other backend * servers not marked as "backup" fail the health check policy. * *

*Note:** You cannot add a backend server marked as {@code backup} to a backend set that * uses the IP Hash policy. * *

Example: {@code false} */ @com.fasterxml.jackson.annotation.JsonProperty("backup") private final Boolean backup; /** * Whether the load balancer should treat this server as a backup unit. If {@code true}, the * load balancer forwards no ingress traffic to this backend server unless all other backend * servers not marked as "backup" fail the health check policy. * *

*Note:** You cannot add a backend server marked as {@code backup} to a backend set that * uses the IP Hash policy. * *

Example: {@code false} * * @return the value */ public Boolean getBackup() { return backup; } /** * Whether the load balancer should drain this server. Servers marked "drain" receive no new * incoming traffic. * *

Example: {@code false} */ @com.fasterxml.jackson.annotation.JsonProperty("drain") private final Boolean drain; /** * Whether the load balancer should drain this server. Servers marked "drain" receive no new * incoming traffic. * *

Example: {@code false} * * @return the value */ public Boolean getDrain() { return drain; } /** * Whether the load balancer should treat this server as offline. Offline servers receive no * incoming traffic. * *

Example: {@code false} */ @com.fasterxml.jackson.annotation.JsonProperty("offline") private final Boolean offline; /** * Whether the load balancer should treat this server as offline. Offline servers receive no * incoming traffic. * *

Example: {@code false} * * @return the value */ public Boolean getOffline() { return offline; } @Override public String toString() { return this.toString(true); } /** * Return a string representation of the object. * * @param includeByteArrayContents true to include the full contents of byte arrays * @return string representation */ public String toString(boolean includeByteArrayContents) { java.lang.StringBuilder sb = new java.lang.StringBuilder(); sb.append("CreateBackendDetails("); sb.append("super=").append(super.toString()); sb.append("ipAddress=").append(String.valueOf(this.ipAddress)); sb.append(", port=").append(String.valueOf(this.port)); sb.append(", weight=").append(String.valueOf(this.weight)); sb.append(", maxConnections=").append(String.valueOf(this.maxConnections)); sb.append(", backup=").append(String.valueOf(this.backup)); sb.append(", drain=").append(String.valueOf(this.drain)); sb.append(", offline=").append(String.valueOf(this.offline)); sb.append(")"); return sb.toString(); } @Override public boolean equals(Object o) { if (this == o) { return true; } if (!(o instanceof CreateBackendDetails)) { return false; } CreateBackendDetails other = (CreateBackendDetails) o; return java.util.Objects.equals(this.ipAddress, other.ipAddress) && java.util.Objects.equals(this.port, other.port) && java.util.Objects.equals(this.weight, other.weight) && java.util.Objects.equals(this.maxConnections, other.maxConnections) && java.util.Objects.equals(this.backup, other.backup) && java.util.Objects.equals(this.drain, other.drain) && java.util.Objects.equals(this.offline, other.offline) && super.equals(other); } @Override public int hashCode() { final int PRIME = 59; int result = 1; result = (result * PRIME) + (this.ipAddress == null ? 43 : this.ipAddress.hashCode()); result = (result * PRIME) + (this.port == null ? 43 : this.port.hashCode()); result = (result * PRIME) + (this.weight == null ? 43 : this.weight.hashCode()); result = (result * PRIME) + (this.maxConnections == null ? 43 : this.maxConnections.hashCode()); result = (result * PRIME) + (this.backup == null ? 43 : this.backup.hashCode()); result = (result * PRIME) + (this.drain == null ? 43 : this.drain.hashCode()); result = (result * PRIME) + (this.offline == null ? 43 : this.offline.hashCode()); result = (result * PRIME) + super.hashCode(); return result; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy