All Downloads are FREE. Search and download functionalities are using the official Maven repository.
Please wait. This can take some minutes ...
Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance.
Project price only 1 $
You can buy this project and download/modify it how often you want.
org.apache.activemq.artemis.core.config.ClusterConnectionConfiguration Maven / Gradle / Ivy
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License 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 org.apache.activemq.artemis.core.config;
import java.io.Serializable;
import java.net.URI;
import java.util.Collections;
import java.util.LinkedList;
import java.util.List;
import org.apache.activemq.artemis.api.config.ActiveMQDefaultConfiguration;
import org.apache.activemq.artemis.api.core.DiscoveryGroupConfiguration;
import org.apache.activemq.artemis.api.core.TransportConfiguration;
import org.apache.activemq.artemis.api.core.client.ActiveMQClient;
import org.apache.activemq.artemis.core.server.ActiveMQServerLogger;
import org.apache.activemq.artemis.core.server.cluster.impl.MessageLoadBalancingType;
import org.apache.activemq.artemis.uri.ClusterConnectionConfigurationParser;
import org.apache.activemq.artemis.utils.uri.URISupport;
public final class ClusterConnectionConfiguration implements Serializable {
private static final long serialVersionUID = 8948303813427795935L;
private String name;
private String address = ActiveMQDefaultConfiguration.getDefaultClusterAddress();
private String connectorName;
private long clientFailureCheckPeriod = ActiveMQDefaultConfiguration.getDefaultClusterFailureCheckPeriod();
private long connectionTTL = ActiveMQDefaultConfiguration.getDefaultClusterConnectionTtl();
private long retryInterval = ActiveMQDefaultConfiguration.getDefaultClusterRetryInterval();
private double retryIntervalMultiplier = ActiveMQDefaultConfiguration.getDefaultClusterRetryIntervalMultiplier();
private long maxRetryInterval = ActiveMQDefaultConfiguration.getDefaultClusterMaxRetryInterval();
private int initialConnectAttempts = ActiveMQDefaultConfiguration.getDefaultClusterInitialConnectAttempts();
private int reconnectAttempts = ActiveMQDefaultConfiguration.getDefaultClusterReconnectAttempts();
private long callTimeout = ActiveMQDefaultConfiguration.getDefaultClusterCallTimeout();
private long callFailoverTimeout = ActiveMQDefaultConfiguration.getDefaultClusterCallFailoverTimeout();
private boolean duplicateDetection = ActiveMQDefaultConfiguration.isDefaultClusterDuplicateDetection();
private MessageLoadBalancingType messageLoadBalancingType = Enum.valueOf(MessageLoadBalancingType.class, ActiveMQDefaultConfiguration.getDefaultClusterMessageLoadBalancingType());
private URISupport.CompositeData compositeMembers;
private List staticConnectors = Collections.emptyList();
private String discoveryGroupName = null;
private int maxHops = ActiveMQDefaultConfiguration.getDefaultClusterMaxHops();
private int confirmationWindowSize = ActiveMQDefaultConfiguration.getDefaultClusterConfirmationWindowSize();
private int producerWindowSize = ActiveMQDefaultConfiguration.getDefaultBridgeProducerWindowSize();
private boolean allowDirectConnectionsOnly = false;
private int minLargeMessageSize = ActiveMQClient.DEFAULT_MIN_LARGE_MESSAGE_SIZE;
private long clusterNotificationInterval = ActiveMQDefaultConfiguration.getDefaultClusterNotificationInterval();
private int clusterNotificationAttempts = ActiveMQDefaultConfiguration.getDefaultClusterNotificationAttempts();
public ClusterConnectionConfiguration() {
}
public ClusterConnectionConfiguration(URI uri) throws Exception {
ClusterConnectionConfigurationParser parser = new ClusterConnectionConfigurationParser();
parser.populateObject(uri, this);
}
public String getName() {
return name;
}
public ClusterConnectionConfiguration setName(String name) {
this.name = name;
return this;
}
public String getAddress() {
return address;
}
public ClusterConnectionConfiguration setAddress(String address) {
this.address = address;
return this;
}
public URISupport.CompositeData getCompositeMembers() {
return compositeMembers;
}
public ClusterConnectionConfiguration setCompositeMembers(URISupport.CompositeData members) {
this.compositeMembers = members;
return this;
}
/**
* @return the clientFailureCheckPeriod
*/
public long getClientFailureCheckPeriod() {
return clientFailureCheckPeriod;
}
/**
* @param clientFailureCheckPeriod the clientFailureCheckPeriod to set
*/
public ClusterConnectionConfiguration setClientFailureCheckPeriod(long clientFailureCheckPeriod) {
this.clientFailureCheckPeriod = clientFailureCheckPeriod;
return this;
}
/**
* @return the connectionTTL
*/
public long getConnectionTTL() {
return connectionTTL;
}
/**
* @param connectionTTL the connectionTTL to set
*/
public ClusterConnectionConfiguration setConnectionTTL(long connectionTTL) {
this.connectionTTL = connectionTTL;
return this;
}
/**
* @return the retryIntervalMultiplier
*/
public double getRetryIntervalMultiplier() {
return retryIntervalMultiplier;
}
/**
* @param retryIntervalMultiplier the retryIntervalMultiplier to set
*/
public ClusterConnectionConfiguration setRetryIntervalMultiplier(double retryIntervalMultiplier) {
this.retryIntervalMultiplier = retryIntervalMultiplier;
return this;
}
/**
* @return the maxRetryInterval
*/
public long getMaxRetryInterval() {
return maxRetryInterval;
}
/**
* @param maxRetryInterval the maxRetryInterval to set
*/
public ClusterConnectionConfiguration setMaxRetryInterval(long maxRetryInterval) {
this.maxRetryInterval = maxRetryInterval;
return this;
}
/**
* @return the initialConnectAttempts
*/
public int getInitialConnectAttempts() {
return initialConnectAttempts;
}
/**
* @param initialConnectAttempts the reconnectAttempts to set
*/
public ClusterConnectionConfiguration setInitialConnectAttempts(int initialConnectAttempts) {
this.initialConnectAttempts = initialConnectAttempts;
return this;
}
/**
* @return the reconnectAttempts
*/
public int getReconnectAttempts() {
return reconnectAttempts;
}
/**
* @param reconnectAttempts the reconnectAttempts to set
*/
public ClusterConnectionConfiguration setReconnectAttempts(int reconnectAttempts) {
this.reconnectAttempts = reconnectAttempts;
return this;
}
public long getCallTimeout() {
return callTimeout;
}
/**
* @param callTimeout the callTimeout to set
*/
public ClusterConnectionConfiguration setCallTimeout(long callTimeout) {
this.callTimeout = callTimeout;
return this;
}
public long getCallFailoverTimeout() {
return callFailoverTimeout;
}
/**
* @param callFailoverTimeout the callTimeout to set
*/
public ClusterConnectionConfiguration setCallFailoverTimeout(long callFailoverTimeout) {
this.callFailoverTimeout = callFailoverTimeout;
return this;
}
public String getConnectorName() {
return connectorName;
}
public ClusterConnectionConfiguration setConnectorName(String connectorName) {
this.connectorName = connectorName;
return this;
}
public boolean isDuplicateDetection() {
return duplicateDetection;
}
/**
* @param duplicateDetection the duplicateDetection to set
*/
public ClusterConnectionConfiguration setDuplicateDetection(boolean duplicateDetection) {
this.duplicateDetection = duplicateDetection;
return this;
}
public MessageLoadBalancingType getMessageLoadBalancingType() {
return messageLoadBalancingType;
}
/**
* @param messageLoadBalancingType
* @return
*/
public ClusterConnectionConfiguration setMessageLoadBalancingType(MessageLoadBalancingType messageLoadBalancingType) {
this.messageLoadBalancingType = messageLoadBalancingType;
return this;
}
public int getMaxHops() {
return maxHops;
}
public ClusterConnectionConfiguration setMaxHops(int maxHops) {
this.maxHops = maxHops;
return this;
}
public int getConfirmationWindowSize() {
return confirmationWindowSize;
}
public ClusterConnectionConfiguration setConfirmationWindowSize(int confirmationWindowSize) {
this.confirmationWindowSize = confirmationWindowSize;
return this;
}
public int getProducerWindowSize() {
return producerWindowSize;
}
public ClusterConnectionConfiguration setProducerWindowSize(int producerWindowSize) {
this.producerWindowSize = producerWindowSize;
return this;
}
public List getStaticConnectors() {
return staticConnectors;
}
public ClusterConnectionConfiguration setStaticConnectors(List staticConnectors) {
this.staticConnectors = staticConnectors;
return this;
}
public String getDiscoveryGroupName() {
return discoveryGroupName;
}
public ClusterConnectionConfiguration setDiscoveryGroupName(String discoveryGroupName) {
this.discoveryGroupName = discoveryGroupName;
return this;
}
public long getRetryInterval() {
return retryInterval;
}
/**
* @param retryInterval the retryInterval to set
*/
public ClusterConnectionConfiguration setRetryInterval(long retryInterval) {
this.retryInterval = retryInterval;
return this;
}
public boolean isAllowDirectConnectionsOnly() {
return allowDirectConnectionsOnly;
}
public ClusterConnectionConfiguration setAllowDirectConnectionsOnly(boolean allowDirectConnectionsOnly) {
this.allowDirectConnectionsOnly = allowDirectConnectionsOnly;
return this;
}
/**
* @return the minLargeMessageSize
*/
public int getMinLargeMessageSize() {
return minLargeMessageSize;
}
/**
* @param minLargeMessageSize the minLargeMessageSize to set
*/
public ClusterConnectionConfiguration setMinLargeMessageSize(final int minLargeMessageSize) {
this.minLargeMessageSize = minLargeMessageSize;
return this;
}
/*
* returns the cluster update interval
* */
public long getClusterNotificationInterval() {
return clusterNotificationInterval;
}
public ClusterConnectionConfiguration setClusterNotificationInterval(long clusterNotificationInterval) {
this.clusterNotificationInterval = clusterNotificationInterval;
return this;
}
public int getClusterNotificationAttempts() {
return clusterNotificationAttempts;
}
public ClusterConnectionConfiguration setClusterNotificationAttempts(int clusterNotificationAttempts) {
this.clusterNotificationAttempts = clusterNotificationAttempts;
return this;
}
/**
* This method will match the configuration and return the proper TransportConfiguration for the Configuration
*/
public TransportConfiguration[] getTransportConfigurations(Configuration configuration) throws Exception {
if (getCompositeMembers() != null) {
URI[] members = getCompositeMembers().getComponents();
List list = new LinkedList<>();
for (URI member : members) {
list.addAll(ConfigurationUtils.parseConnectorURI(null, member));
}
return list.toArray(new TransportConfiguration[list.size()]);
} else {
return staticConnectors != null ? configuration.getTransportConfigurations(staticConnectors) : null;
}
}
/**
* This method will return the proper discovery configuration from the main configuration
*/
public DiscoveryGroupConfiguration getDiscoveryGroupConfiguration(Configuration configuration) {
if (discoveryGroupName != null) {
DiscoveryGroupConfiguration dg = configuration.getDiscoveryGroupConfigurations().get(discoveryGroupName);
if (dg == null) {
ActiveMQServerLogger.LOGGER.clusterConnectionNoDiscoveryGroup(discoveryGroupName);
return null;
}
return dg;
} else {
return null;
}
}
public TransportConfiguration getTransportConfiguration(Configuration configuration) {
TransportConfiguration connector = configuration.getConnectorConfigurations().get(getConnectorName());
if (connector == null) {
ActiveMQServerLogger.LOGGER.clusterConnectionNoConnector(connectorName);
return null;
}
return connector;
}
public boolean validateConfiguration() {
if (getName() == null) {
ActiveMQServerLogger.LOGGER.clusterConnectionNotUnique();
return false;
}
return true;
}
@Override
public int hashCode() {
final int prime = 31;
int result = 1;
result = prime * result + ((address == null) ? 0 : address.hashCode());
result = prime * result + (allowDirectConnectionsOnly ? 1231 : 1237);
result = prime * result + (int) (callFailoverTimeout ^ (callFailoverTimeout >>> 32));
result = prime * result + (int) (callTimeout ^ (callTimeout >>> 32));
result = prime * result + (int) (clientFailureCheckPeriod ^ (clientFailureCheckPeriod >>> 32));
result = prime * result + clusterNotificationAttempts;
result = prime * result + (int) (clusterNotificationInterval ^ (clusterNotificationInterval >>> 32));
result = prime * result + confirmationWindowSize;
result = prime * result + (int) (connectionTTL ^ (connectionTTL >>> 32));
result = prime * result + ((connectorName == null) ? 0 : connectorName.hashCode());
result = prime * result + ((discoveryGroupName == null) ? 0 : discoveryGroupName.hashCode());
result = prime * result + (duplicateDetection ? 1231 : 1237);
result = prime * result + (messageLoadBalancingType == null ? 0 : messageLoadBalancingType.hashCode());
result = prime * result + maxHops;
result = prime * result + (int) (maxRetryInterval ^ (maxRetryInterval >>> 32));
result = prime * result + minLargeMessageSize;
result = prime * result + ((name == null) ? 0 : name.hashCode());
result = prime * result + initialConnectAttempts;
result = prime * result + reconnectAttempts;
result = prime * result + (int) (retryInterval ^ (retryInterval >>> 32));
long temp;
temp = Double.doubleToLongBits(retryIntervalMultiplier);
result = prime * result + (int) (temp ^ (temp >>> 32));
result = prime * result + ((staticConnectors == null) ? 0 : staticConnectors.hashCode());
return result;
}
@Override
public boolean equals(Object obj) {
if (this == obj) {
return true;
}
if (obj == null) {
return false;
}
if (getClass() != obj.getClass()) {
return false;
}
ClusterConnectionConfiguration other = (ClusterConnectionConfiguration) obj;
if (address == null) {
if (other.address != null) {
return false;
}
} else if (!address.equals(other.address)) {
return false;
}
if (allowDirectConnectionsOnly != other.allowDirectConnectionsOnly) {
return false;
}
if (callFailoverTimeout != other.callFailoverTimeout) {
return false;
}
if (callTimeout != other.callTimeout) {
return false;
}
if (clientFailureCheckPeriod != other.clientFailureCheckPeriod) {
return false;
}
if (clusterNotificationAttempts != other.clusterNotificationAttempts) {
return false;
}
if (clusterNotificationInterval != other.clusterNotificationInterval) {
return false;
}
if (confirmationWindowSize != other.confirmationWindowSize) {
return false;
}
if (connectionTTL != other.connectionTTL) {
return false;
}
if (connectorName == null) {
if (other.connectorName != null) {
return false;
}
} else if (!connectorName.equals(other.connectorName)) {
return false;
}
if (discoveryGroupName == null) {
if (other.discoveryGroupName != null) {
return false;
}
} else if (!discoveryGroupName.equals(other.discoveryGroupName)) {
return false;
}
if (duplicateDetection != other.duplicateDetection) {
return false;
}
if (messageLoadBalancingType != other.messageLoadBalancingType) {
return false;
}
if (maxHops != other.maxHops) {
return false;
}
if (maxRetryInterval != other.maxRetryInterval) {
return false;
}
if (minLargeMessageSize != other.minLargeMessageSize) {
return false;
}
if (name == null) {
if (other.name != null) {
return false;
}
} else if (!name.equals(other.name)) {
return false;
}
if (initialConnectAttempts != other.initialConnectAttempts) {
return false;
}
if (reconnectAttempts != other.reconnectAttempts) {
return false;
}
if (retryInterval != other.retryInterval) {
return false;
}
if (Double.doubleToLongBits(retryIntervalMultiplier) != Double.doubleToLongBits(other.retryIntervalMultiplier)) {
return false;
}
if (staticConnectors == null) {
if (other.staticConnectors != null) {
return false;
}
} else if (!staticConnectors.equals(other.staticConnectors)) {
return false;
}
return true;
}
@Override
public String toString() {
return "ClusterConnectionConfiguration{" +
"name='" + name + '\'' +
", address='" + address + '\'' +
", connectorName='" + connectorName + '\'' +
", clientFailureCheckPeriod=" + clientFailureCheckPeriod +
", connectionTTL=" + connectionTTL +
", retryInterval=" + retryInterval +
", retryIntervalMultiplier=" + retryIntervalMultiplier +
", maxRetryInterval=" + maxRetryInterval +
", initialConnectAttempts=" + initialConnectAttempts +
", reconnectAttempts=" + reconnectAttempts +
", callTimeout=" + callTimeout +
", callFailoverTimeout=" + callFailoverTimeout +
", duplicateDetection=" + duplicateDetection +
", messageLoadBalancingType=" + messageLoadBalancingType +
", compositeMembers=" + compositeMembers +
", staticConnectors=" + staticConnectors +
", discoveryGroupName='" + discoveryGroupName + '\'' +
", maxHops=" + maxHops +
", confirmationWindowSize=" + confirmationWindowSize +
", allowDirectConnectionsOnly=" + allowDirectConnectionsOnly +
", minLargeMessageSize=" + minLargeMessageSize +
", clusterNotificationInterval=" + clusterNotificationInterval +
", clusterNotificationAttempts=" + clusterNotificationAttempts +
'}';
}
}