com.hazelcast.eureka.one.EurekaOneProperties Maven / Gradle / Ivy
/*
* Copyright (c) 2008-2017, Hazelcast, Inc. 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.
* 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 com.hazelcast.eureka.one;
import java.util.Collection;
import com.google.common.collect.Lists;
import com.hazelcast.config.properties.PropertyDefinition;
import com.hazelcast.config.properties.PropertyTypeConverter;
import com.hazelcast.config.properties.SimplePropertyDefinition;
import com.hazelcast.core.TypeConverter;
import static com.hazelcast.config.properties.PropertyTypeConverter.BOOLEAN;
import static com.hazelcast.config.properties.PropertyTypeConverter.STRING;
import static com.hazelcast.eureka.one.PropertyBasedEurekaClientConfigConstants.*;
/**
* Configuration class of the Hazelcast Discovery Plugin for Eureka 1.
* For possible configuration properties please refer to the public constants of this class.
*/
public final class EurekaOneProperties {
/**
* Configuration System Environment Prefix: hazelcast.eurekaone.
* Defines the prefix for system environment variables and JVM command line parameters.
* Defining or overriding properties as JVM parameters or using the system environment, those
* properties need to be prefixed to prevent collision on property names.
* Example: {@link #SELF_REGISTRATION} will be:
*
* -Dhazelcast.eurekaone.self-registration=value
*
* Example: {@link #NAMESPACE} will be:
*
* -Dhazelcast.eurekaone.namespace=value
*
*/
public static final String EUREKA_ONE_SYSTEM_PREFIX = "hazelcast.eurekaone";
/**
* Configuration key: use-classpath-eureka-client-props
* Defines if the Discovery SPI plugin will use the standard Eureka eureka.client.props
* If true, the classpath-based Eureka properties file will be used,
* otherwise the plugin will use properties defined in the discovery-strategy config itself.
* The default value is: true
*/
public static final PropertyDefinition USE_CLASSPATH_EUREKA_CLIENT_PROPS =
property("use-classpath-eureka-client-props", BOOLEAN);
/**
* Configuration key: self-registration
* Defines if the Discovery SPI plugin will register itself with the Eureka 1 service discovery.
* The default value is: true
*/
public static final PropertyDefinition SELF_REGISTRATION = property("self-registration", BOOLEAN);
/**
*
* Configuration key: use-metadata-for-host-and-port
*
*
* Defines if the Discovery SPI plugin will use Eureka metadata map to store host and port of Hazelcast
* instance, and when it looks for other nodes it will use the metadata as well.
*
*
* The default value is: false
*
*/
public static final PropertyDefinition USE_METADATA_FOR_HOST_AND_PORT = property("use-metadata-for-host-and-port", BOOLEAN);
/**
*
* Configuration key: skip-eureka-registration-verification
*
*
* When first node starts, it takes some time to do self-registration with
* Eureka Server. Until Eureka data is updated it make no sense to verify
* registration. See
* https://github.com/Netflix/eureka/wiki/Understanding-eureka-client-server-communication#time-lag
* This option will speed up startup when starting first cluster node.
*
*
* The default value is: false
*
*/
public static final PropertyDefinition SKIP_EUREKA_REGISTRATION_VERIFICATION =
property("skip-eureka-registration-verification", BOOLEAN);
/**
* Configuration key: namespace
* Definition for providing different namespaces in order to not collide with other service registry clients in
* eureka-client.properties file.
* The default value is: hazelcast
*/
public static final PropertyDefinition NAMESPACE = property("namespace", STRING);
static final Collection HZ_PROPERTY_DEFINITIONS = Lists.newArrayList(
USE_CLASSPATH_EUREKA_CLIENT_PROPS,
SELF_REGISTRATION,
NAMESPACE,
USE_METADATA_FOR_HOST_AND_PORT,
SKIP_EUREKA_REGISTRATION_VERIFICATION
);
static final Collection EUREKA_CLIENT_PROPERTY_DEFINITIONS = Lists.newArrayList(
property(REGISTRY_REFRESH_INTERVAL_KEY, PropertyTypeConverter.INTEGER),
property(REGISTRATION_REPLICATION_INTERVAL_KEY, PropertyTypeConverter.INTEGER),
property(INITIAL_REGISTRATION_REPLICATION_DELAY_KEY, PropertyTypeConverter.INTEGER),
property(EUREKA_SERVER_URL_POLL_INTERVAL_KEY, PropertyTypeConverter.INTEGER),
property(EUREKA_SERVER_PROXY_HOST_KEY, PropertyTypeConverter.STRING),
property(EUREKA_SERVER_PROXY_PORT_KEY, PropertyTypeConverter.STRING),
property(EUREKA_SERVER_PROXY_USERNAME_KEY, PropertyTypeConverter.STRING),
property(EUREKA_SERVER_PROXY_PASSWORD_KEY, PropertyTypeConverter.STRING),
property(EUREKA_SERVER_GZIP_CONTENT_KEY, PropertyTypeConverter.BOOLEAN),
property(EUREKA_SERVER_READ_TIMEOUT_KEY, PropertyTypeConverter.INTEGER),
property(EUREKA_SERVER_CONNECT_TIMEOUT_KEY, PropertyTypeConverter.INTEGER),
property(BACKUP_REGISTRY_CLASSNAME_KEY, PropertyTypeConverter.STRING),
property(EUREKA_SERVER_MAX_CONNECTIONS_KEY, PropertyTypeConverter.INTEGER),
property(EUREKA_SERVER_MAX_CONNECTIONS_PER_HOST_KEY, PropertyTypeConverter.INTEGER),
property(EUREKA_SERVER_URL_CONTEXT_KEY, PropertyTypeConverter.STRING),
property(EUREKA_SERVER_FALLBACK_URL_CONTEXT_KEY, PropertyTypeConverter.STRING),
property(EUREKA_SERVER_PORT_KEY, PropertyTypeConverter.STRING),
property(EUREKA_SERVER_FALLBACK_PORT_KEY, PropertyTypeConverter.STRING),
property(EUREKA_SERVER_DNS_NAME_KEY, PropertyTypeConverter.STRING),
property(EUREKA_SERVER_FALLBACK_DNS_NAME_KEY, PropertyTypeConverter.STRING),
property(SHOULD_USE_DNS_KEY, PropertyTypeConverter.BOOLEAN),
property(REGISTRATION_ENABLED_KEY, PropertyTypeConverter.BOOLEAN),
property(SHOULD_PREFER_SAME_ZONE_SERVER_KEY, PropertyTypeConverter.BOOLEAN),
property(SHOULD_ALLOW_REDIRECTS_KEY, PropertyTypeConverter.BOOLEAN),
property(SHOULD_LOG_DELTA_DIFF_KEY, PropertyTypeConverter.BOOLEAN),
property(SHOULD_DISABLE_DELTA_KEY, PropertyTypeConverter.BOOLEAN),
property(SHOULD_FETCH_REMOTE_REGION_KEY, PropertyTypeConverter.STRING),
property(CLIENT_REGION_KEY, PropertyTypeConverter.STRING),
property(CLIENT_REGION_FALLBACK_KEY, PropertyTypeConverter.STRING),
property(CONFIG_EUREKA_SERVER_SERVICE_URL_PREFIX + ".default", PropertyTypeConverter.STRING),
property(SHOULD_FILTER_ONLY_UP_INSTANCES_KEY, PropertyTypeConverter.BOOLEAN),
property(EUREKA_SERVER_CONNECTION_IDLE_TIMEOUT_KEY, PropertyTypeConverter.INTEGER),
property(FETCH_REGISTRY_ENABLED_KEY, PropertyTypeConverter.BOOLEAN),
property(FETCH_SINGLE_VIP_ONLY_KEY, PropertyTypeConverter.STRING),
property(HEARTBEAT_THREADPOOL_SIZE_KEY, PropertyTypeConverter.INTEGER),
property(HEARTBEAT_BACKOFF_BOUND_KEY, PropertyTypeConverter.INTEGER),
property(CACHEREFRESH_THREADPOOL_SIZE_KEY, PropertyTypeConverter.INTEGER),
property(CACHEREFRESH_BACKOFF_BOUND_KEY, PropertyTypeConverter.INTEGER),
property(CONFIG_DOLLAR_REPLACEMENT_KEY, PropertyTypeConverter.STRING),
property(CONFIG_ESCAPE_CHAR_REPLACEMENT_KEY, PropertyTypeConverter.STRING),
property(SHOULD_ONDEMAND_UPDATE_STATUS_KEY, PropertyTypeConverter.BOOLEAN),
property(CLIENT_ENCODER_NAME_KEY, PropertyTypeConverter.STRING),
property(CLIENT_DECODER_NAME_KEY, PropertyTypeConverter.STRING),
property(CLIENT_DATA_ACCEPT_KEY, PropertyTypeConverter.STRING)
);
// Prevent instantiation
private EurekaOneProperties() {
}
private static PropertyDefinition property(String key, TypeConverter typeConverter) {
return new SimplePropertyDefinition(key, true, typeConverter);
}
}