org.infinispan.configuration.cache.XSiteStateTransferConfiguration Maven / Gradle / Ivy
package org.infinispan.configuration.cache;
import java.util.concurrent.TimeUnit;
import org.infinispan.commons.configuration.attributes.Attribute;
import org.infinispan.commons.configuration.attributes.AttributeDefinition;
import org.infinispan.commons.configuration.attributes.AttributeSet;
/**
* Configuration needed for State Transfer between different sites.
*
* @author Pedro Ruivo
* @since 7.0
*/
public class XSiteStateTransferConfiguration {
public static final int DEFAULT_CHUNK_SIZE = 512;
public static final long DEFAULT_TIMEOUT = TimeUnit.MINUTES.toMillis(20);
public static final int DEFAULT_MAX_RETRIES = 30;
public static final long DEFAULT_WAIT_TIME = TimeUnit.SECONDS.toMillis(2);
public static final AttributeDefinition CHUNK_SIZE = AttributeDefinition.builder("chunkSize", DEFAULT_CHUNK_SIZE).immutable().build();
public static final AttributeDefinition TIMEOUT = AttributeDefinition.builder("timeout", DEFAULT_TIMEOUT).build();
public static final AttributeDefinition MAX_RETRIES = AttributeDefinition.builder("maxRetries", DEFAULT_MAX_RETRIES).build();
public static final AttributeDefinition WAIT_TIME = AttributeDefinition.builder("waitTime", DEFAULT_WAIT_TIME).build();
static AttributeSet attributeDefinitionSet() {
return new AttributeSet(XSiteStateTransferConfiguration.class, CHUNK_SIZE, TIMEOUT, MAX_RETRIES, WAIT_TIME);
}
private final Attribute chunkSize;
private final Attribute timeout;
private final Attribute maxRetries;
private final Attribute waitTime;
private final AttributeSet attributes;
public XSiteStateTransferConfiguration(AttributeSet attributes) {
this.attributes = attributes.checkProtection();
chunkSize = attributes.attribute(CHUNK_SIZE);
timeout = attributes.attribute(TIMEOUT);
maxRetries = attributes.attribute(MAX_RETRIES);
waitTime = attributes.attribute(WAIT_TIME);
}
public int chunkSize() {
return chunkSize.get();
}
public long timeout() {
return timeout.get();
}
public int maxRetries() {
return maxRetries.get();
}
public long waitTime() {
return waitTime.get();
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (getClass() != obj.getClass())
return false;
XSiteStateTransferConfiguration other = (XSiteStateTransferConfiguration) obj;
if (attributes == null) {
if (other.attributes != null)
return false;
} else if (!attributes.equals(other.attributes))
return false;
return true;
}
@Override
public int hashCode() {
final int prime = 31;
int result = 1;
result = prime * result + ((attributes == null) ? 0 : attributes.hashCode());
return result;
}
@Override
public String toString() {
return "XSiteStateTransferConfiguration [attributes=" + attributes + "]";
}
public AttributeSet attributes() {
return attributes;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy