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

com.hazelcast.spi.discovery.DiscoveryStrategy Maven / Gradle / Ivy

There is a newer version: 5.5.0
Show newest version
/*
 * Copyright (c) 2008-2016, 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.spi.discovery;

import com.hazelcast.spi.annotation.Beta;
import com.hazelcast.spi.partitiongroup.PartitionGroupStrategy;

import java.util.Map;

/**
 * The DiscoveryStrategy itself is the actual implementation to discover
 * nodes based on whatever environment is used to run the Hazelcast cloud. The
 * internal implementation is completely vendor specific and might use external Java
 * libraries to query APIs or send requests to a external REST service.
 * 

* DiscoveryStrategies are also free to define any kind of properties that might * be necessary to discover eligible nodes based on configured attributes, tags or any * other kind of metadata. *

* Using the simple lifecycle management strategies like multicast discovery is able to * register and destroy sockets based on Hazelcast’s lifecycle. Deactivated services will * also never be started. *

* Attention: Instead of implementing this interface directly, implementors should consider * using the abstract class {@link AbstractDiscoveryStrategy} instead for easier upgradeability * while this interface evolves. * * @since 3.6 */ @Beta public interface DiscoveryStrategy { /** * The start method is used to initialize internal state and perform any kind of * startup procedure like multicast socket creation. The behavior of this method might * change based on the {@link DiscoveryNode} instance passed to the {@link DiscoveryStrategyFactory}. */ void start(); /** * Returns a set of all discovered nodes based on the defined properties that were used * to create the DiscoveryStrategy instance. * * @return a set of all discovered nodes */ Iterable discoverNodes(); /** * The stop method is used to stop internal services, sockets or to destroy any * kind of internal state. */ void destroy(); /** * Returns a custom implementation of a {@link PartitionGroupStrategy} to override * default behavior of zone aware backup strategies {@link com.hazelcast.spi.partitiongroup.PartitionGroupMetaData} * or to provide a specific behavior in case the discovery environment does not provide * information about the infrastructure to be used for automatic configuration. * * @return a custom implementation of a PartitionGroupStrategy otherwise null * in case of the default implementation is to be used * @since 3.7 */ PartitionGroupStrategy getPartitionGroupStrategy(); /** * Returns a map with discovered metadata provided by the runtime environment. Those information * may include, but are not limited, to location information like datacenter, rack, host or additional * tags to be used for custom purpose. *

* Information discovered from this method are shaded into the {@link com.hazelcast.core.Member}s * attributes. Existing attributes will not be overridden, that way local attribute configuration * overrides provided metadata. *

* The default implementation provides an empty map with no further metadata configured. Returning * null is not permitted and will most probably result in an {@link NullPointerException} * inside the cluster system. * * @return a map of discovered metadata as provided by the runtime environment * @since 3.7 */ Map discoverLocalMetadata(); }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy