public class ServiceDiscovery extends Object
 The service discovery is an infrastructure that let you publish and find `services`. A `service` is a discoverable
 functionality. It can be qualified by its type, metadata, and location. So a `service` can be a database, a
 service proxy, a HTTP endpoint. It does not have to be a vert.x entity, but can be anything. Each service is
 described by a Record.
 
The service discovery implements the interactions defined in the service-oriented computing. And to some extend, also provides the dynamic service-oriented computing interaction. So, application can react to arrival and departure of services.
A service provider can:
* publish a service record * un-publish a published record * update the status of a published service (down, out of service...)
A service consumer can:
 * lookup for services
 * bind to a selected service (it gets a ServiceReference) and use it
 * release the service once the consumer is done with it
 * listen for arrival, departure and modification of services.
 
 Consumer would 1) lookup for service record matching their need, 2) retrieve the ServiceReference that give access
 to the service, 3) get a service object to access the service, 4) release the service object once done.
 
 A state above, the central piece of information shared by the providers and consumers are Record.
 
 Providers and consumers must create their own ServiceDiscovery instance. These instances are collaborating
 in background (distributed structure) to keep the set of services in sync.
 
original non RX-ified interface using Vert.x codegen.| Modifier and Type | Field and Description | 
|---|---|
| static io.vertx.lang.rx.TypeArg<ServiceDiscovery> | __TYPE_ARG | 
| Constructor and Description | 
|---|
| ServiceDiscovery(Object delegate) | 
| ServiceDiscovery(ServiceDiscovery delegate) | 
| Modifier and Type | Method and Description | 
|---|---|
| Set<ServiceReference> | bindings() | 
| void | close()Closes the service discovery | 
| static ServiceDiscovery | create(Vertx vertx)Creates a new instance of  ServiceDiscoveryusing the default configuration. | 
| static ServiceDiscovery | create(Vertx vertx,
      ServiceDiscoveryOptions options)Creates an instance of  ServiceDiscovery. | 
| boolean | equals(Object o) | 
| ServiceDiscovery | getDelegate() | 
| Maybe<Record> | getRecord(java.util.function.Function<Record,Boolean> filter)Lookups for a single record. | 
| Maybe<Record> | getRecord(java.util.function.Function<Record,Boolean> filter,
         boolean includeOutOfService)Lookups for a single record. | 
| Maybe<Record> | getRecord(JsonObject filter)Lookups for a single record. | 
| Single<List<Record>> | getRecords(java.util.function.Function<Record,Boolean> filter)Lookups for a set of records. | 
| Single<List<Record>> | getRecords(java.util.function.Function<Record,Boolean> filter,
          boolean includeOutOfService)Lookups for a set of records. | 
| Single<List<Record>> | getRecords(JsonObject filter)Lookups for a set of records. | 
| ServiceReference | getReference(Record record)Gets a service reference from the given record. | 
| ServiceReference | getReferenceWithConfiguration(Record record,
                             JsonObject configuration)Gets a service reference from the given record, the reference is configured with the given json object. | 
| int | hashCode() | 
| static ServiceDiscovery | newInstance(ServiceDiscovery arg) | 
| ServiceDiscoveryOptions | options() | 
| Single<Record> | publish(Record record)Publishes a record. | 
| Completable | registerServiceExporter(ServiceExporter exporter,
                       JsonObject configuration)Registers a discovery bridge. | 
| Completable | registerServiceImporter(ServiceImporter importer,
                       JsonObject configuration)Registers a discovery service importer. | 
| boolean | release(ServiceReference reference)Releases the service reference. | 
| static void | releaseServiceObject(ServiceDiscovery discovery,
                    Object svcObject)Release the service object retrieved using  getmethods from the service type interface. | 
| Maybe<Record> | rxGetRecord(java.util.function.Function<Record,Boolean> filter)Lookups for a single record. | 
| Maybe<Record> | rxGetRecord(java.util.function.Function<Record,Boolean> filter,
           boolean includeOutOfService)Lookups for a single record. | 
| Maybe<Record> | rxGetRecord(JsonObject filter)Lookups for a single record. | 
| Single<List<Record>> | rxGetRecords(java.util.function.Function<Record,Boolean> filter)Lookups for a set of records. | 
| Single<List<Record>> | rxGetRecords(java.util.function.Function<Record,Boolean> filter,
            boolean includeOutOfService)Lookups for a set of records. | 
| Single<List<Record>> | rxGetRecords(JsonObject filter)Lookups for a set of records. | 
| Single<Record> | rxPublish(Record record)Publishes a record. | 
| Completable | rxRegisterServiceExporter(ServiceExporter exporter,
                         JsonObject configuration)Registers a discovery bridge. | 
| Completable | rxRegisterServiceImporter(ServiceImporter importer,
                         JsonObject configuration)Registers a discovery service importer. | 
| Completable | rxUnpublish(String id)Un-publishes a record. | 
| Single<Record> | rxUpdate(Record record)Updates the given record. | 
| String | toString() | 
| Completable | unpublish(String id)Un-publishes a record. | 
| Single<Record> | update(Record record)Updates the given record. | 
public static final io.vertx.lang.rx.TypeArg<ServiceDiscovery> __TYPE_ARG
public ServiceDiscovery(ServiceDiscovery delegate)
public ServiceDiscovery(Object delegate)
public ServiceDiscovery getDelegate()
public static ServiceDiscovery create(Vertx vertx, ServiceDiscoveryOptions options)
ServiceDiscovery.vertx - the vert.x instanceoptions - the discovery optionspublic static ServiceDiscovery create(Vertx vertx)
ServiceDiscovery using the default configuration.vertx - the vert.x instancepublic ServiceReference getReference(Record record)
record - the chosen recordpublic ServiceReference getReferenceWithConfiguration(Record record, JsonObject configuration)
record - the chosen recordconfiguration - the configurationpublic boolean release(ServiceReference reference)
reference - the reference to release, must not be nullpublic Completable registerServiceImporter(ServiceImporter importer, JsonObject configuration)
importer - the service importerconfiguration - the optional configurationServiceDiscoverypublic Completable rxRegisterServiceImporter(ServiceImporter importer, JsonObject configuration)
importer - the service importerconfiguration - the optional configurationServiceDiscoverypublic Completable registerServiceExporter(ServiceExporter exporter, JsonObject configuration)
exporter - the service exporterconfiguration - the optional configurationServiceDiscoverypublic Completable rxRegisterServiceExporter(ServiceExporter exporter, JsonObject configuration)
exporter - the service exporterconfiguration - the optional configurationServiceDiscoverypublic void close()
public Single<Record> publish(Record record)
record - the recordpublic Single<Record> rxPublish(Record record)
record - the recordpublic Completable unpublish(String id)
id - the registration idpublic Completable rxUnpublish(String id)
id - the registration idpublic Maybe<Record> getRecord(JsonObject filter)
Filters are expressed using a Json object. Each entry of the given filter will be checked against the record. All entry must match exactly the record. The entry can use the special "*" value to denotes a requirement on the key, but not on the value.
Let's take some example:
   { "name" = "a" } => matches records with name set fo "a"
   { "color" = "*" } => matches records with "color" set
   { "color" = "red" } => only matches records with "color" set to "red"
   { "color" = "red", "name" = "a"} => only matches records with name set to "a", and color set to "red"
 
 
 If the filter is not set (null or empty), it accepts all records.
 
This method returns the first matching record.
filter - the filter.public Maybe<Record> rxGetRecord(JsonObject filter)
Filters are expressed using a Json object. Each entry of the given filter will be checked against the record. All entry must match exactly the record. The entry can use the special "*" value to denotes a requirement on the key, but not on the value.
Let's take some example:
   { "name" = "a" } => matches records with name set fo "a"
   { "color" = "*" } => matches records with "color" set
   { "color" = "red" } => only matches records with "color" set to "red"
   { "color" = "red", "name" = "a"} => only matches records with name set to "a", and color set to "red"
 
 
 If the filter is not set (null or empty), it accepts all records.
 
This method returns the first matching record.
filter - the filter.public Maybe<Record> getRecord(java.util.function.Function<Record,Boolean> filter)
 The filter is a  taking a Record as argument and returning a boolean. You should see it
 as an accept method of a filter. This method return a record passing the filter.
 
 This method only looks for records with a UP status.
filter - the filter, must not be null. To return all records, use a function accepting all recordspublic Maybe<Record> rxGetRecord(java.util.function.Function<Record,Boolean> filter)
 The filter is a  taking a Record as argument and returning a boolean. You should see it
 as an accept method of a filter. This method return a record passing the filter.
 
 This method only looks for records with a UP status.
filter - the filter, must not be null. To return all records, use a function accepting all recordspublic Maybe<Record> getRecord(java.util.function.Function<Record,Boolean> filter, boolean includeOutOfService)
 The filter is a  taking a Record as argument and returning a boolean. You should see it
 as an accept method of a filter. This method return a record passing the filter.
 
 Unlike getRecord(io.vertx.core.json.JsonObject), this method may accept records with a OUT OF SERVICE
 status, if the includeOutOfService parameter is set to true.
filter - the filter, must not be null. To return all records, use a function accepting all recordsincludeOutOfService - whether or not the filter accepts OUT OF SERVICE recordspublic Maybe<Record> rxGetRecord(java.util.function.Function<Record,Boolean> filter, boolean includeOutOfService)
 The filter is a  taking a Record as argument and returning a boolean. You should see it
 as an accept method of a filter. This method return a record passing the filter.
 
 Unlike getRecord(io.vertx.core.json.JsonObject), this method may accept records with a OUT OF SERVICE
 status, if the includeOutOfService parameter is set to true.
filter - the filter, must not be null. To return all records, use a function accepting all recordsincludeOutOfService - whether or not the filter accepts OUT OF SERVICE recordspublic Single<List<Record>> getRecords(JsonObject filter)
getRecord(io.vertx.core.json.JsonObject), this method returns all matching
 records.filter - the filter - see getRecord(io.vertx.core.json.JsonObject)public Single<List<Record>> rxGetRecords(JsonObject filter)
getRecord(io.vertx.core.json.JsonObject), this method returns all matching
 records.filter - the filter - see getRecord(io.vertx.core.json.JsonObject)public Single<List<Record>> getRecords(java.util.function.Function<Record,Boolean> filter)
getRecord(io.vertx.core.json.JsonObject), this method returns all matching
 records.
 
 The filter is a  taking a Record as argument and returning a boolean. You should see it
 as an accept method of a filter. This method return a record passing the filter.
 
 This method only looks for records with a UP status.
filter - the filter, must not be null. To return all records, use a function accepting all recordspublic Single<List<Record>> rxGetRecords(java.util.function.Function<Record,Boolean> filter)
getRecord(io.vertx.core.json.JsonObject), this method returns all matching
 records.
 
 The filter is a  taking a Record as argument and returning a boolean. You should see it
 as an accept method of a filter. This method return a record passing the filter.
 
 This method only looks for records with a UP status.
filter - the filter, must not be null. To return all records, use a function accepting all recordspublic Single<List<Record>> getRecords(java.util.function.Function<Record,Boolean> filter, boolean includeOutOfService)
getRecord(io.vertx.core.json.JsonObject), this method returns all matching
 records.
 
 The filter is a  taking a Record as argument and returning a boolean. You should see it
 as an accept method of a filter. This method return a record passing the filter.
 
 Unlike getRecords(io.vertx.core.json.JsonObject), this method may accept records with a OUT OF SERVICE
 status, if the includeOutOfService parameter is set to true.
filter - the filter, must not be null. To return all records, use a function accepting all recordsincludeOutOfService - whether or not the filter accepts OUT OF SERVICE recordspublic Single<List<Record>> rxGetRecords(java.util.function.Function<Record,Boolean> filter, boolean includeOutOfService)
getRecord(io.vertx.core.json.JsonObject), this method returns all matching
 records.
 
 The filter is a  taking a Record as argument and returning a boolean. You should see it
 as an accept method of a filter. This method return a record passing the filter.
 
 Unlike getRecords(io.vertx.core.json.JsonObject), this method may accept records with a OUT OF SERVICE
 status, if the includeOutOfService parameter is set to true.
filter - the filter, must not be null. To return all records, use a function accepting all recordsincludeOutOfService - whether or not the filter accepts OUT OF SERVICE recordspublic Single<Record> update(Record record)
record - the updated recordpublic Single<Record> rxUpdate(Record record)
record - the updated recordpublic Set<ServiceReference> bindings()
public ServiceDiscoveryOptions options()
public static void releaseServiceObject(ServiceDiscovery discovery, Object svcObject)
get methods from the service type interface.
 It searches for the reference associated with the given object and release it.discovery - the service discoverysvcObject - the service objectpublic static ServiceDiscovery newInstance(ServiceDiscovery arg)
Copyright © 2021 Eclipse. All rights reserved.