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

io.scalecube.services.discovery.api.ServiceDiscovery Maven / Gradle / Ivy

package io.scalecube.services.discovery.api;

import io.scalecube.services.ServiceEndpoint;
import io.scalecube.services.ServiceLoaderUtil;
import io.scalecube.transport.Address;
import java.util.ServiceLoader;
import reactor.core.publisher.Flux;
import reactor.core.publisher.Mono;

public interface ServiceDiscovery {

  Address address();

  ServiceEndpoint endpoint();

  /**
   * Get the discovery. Uses the {@link ServiceLoader#load(Class)} in order to select the service
   *
   * @return a Service Discovery implementation.
   */
  static ServiceDiscovery getDiscovery() {
    return ServiceLoaderUtil.findFirst(ServiceDiscovery.class)
        .orElseThrow(() -> new IllegalStateException("ServiceDiscovery not configured"));
  }

  Mono start(DiscoveryConfig discoveryConfig);

  Mono shutdown();

  Flux listen();
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy