public interface ServiceDiscovery
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 records
.
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.
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
ServiceDiscovery using the default configuration. |
static ServiceDiscovery |
create(Vertx vertx,
ServiceDiscoveryOptions options)
Creates an instance of
ServiceDiscovery . |
Future<Record> |
getRecord(java.util.function.Function<Record,Boolean> filter)
Like
getRecord(Function, Handler) but returns a Future of the asynchronous result |
Future<Record> |
getRecord(java.util.function.Function<Record,Boolean> filter,
boolean includeOutOfService)
Like
getRecords(Function, boolean, Handler) but returns a Future of the asynchronous result |
void |
getRecord(java.util.function.Function<Record,Boolean> filter,
boolean includeOutOfService,
Handler<AsyncResult<Record>> resultHandler)
Lookups for a single record.
|
void |
getRecord(java.util.function.Function<Record,Boolean> filter,
Handler<AsyncResult<Record>> resultHandler)
Lookups for a single record.
|
Future<Record> |
getRecord(JsonObject filter)
Like
getRecord(JsonObject, Handler) but returns a Future of the asynchronous result |
void |
getRecord(JsonObject filter,
Handler<AsyncResult<Record>> resultHandler)
Lookups for a single record.
|
Future<List<Record>> |
getRecords(java.util.function.Function<Record,Boolean> filter)
Like
getRecords(Function, Handler) but returns a Future of the asynchronous result |
Future<List<Record>> |
getRecords(java.util.function.Function<Record,Boolean> filter,
boolean includeOutOfService)
Like
getRecords(Function, boolean, Handler) but returns a Future of the asynchronous result |
void |
getRecords(java.util.function.Function<Record,Boolean> filter,
boolean includeOutOfService,
Handler<AsyncResult<List<Record>>> resultHandler)
Lookups for a set of records.
|
void |
getRecords(java.util.function.Function<Record,Boolean> filter,
Handler<AsyncResult<List<Record>>> resultHandler)
Lookups for a set of records.
|
Future<List<Record>> |
getRecords(JsonObject filter)
Like
getRecords(JsonObject, Handler) but returns a Future of the asynchronous result |
void |
getRecords(JsonObject filter,
Handler<AsyncResult<List<Record>>> resultHandler)
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.
|
ServiceDiscoveryOptions |
options() |
Future<Record> |
publish(Record record)
Like
publish(Record, Handler) but returns a Future of the asynchronous result |
void |
publish(Record record,
Handler<AsyncResult<Record>> resultHandler)
Publishes a record.
|
Future<Void> |
registerServiceExporter(ServiceExporter exporter,
JsonObject configuration)
Like
registerServiceExporter(ServiceExporter, JsonObject, Handler) but returns a Future of the asynchronous result |
ServiceDiscovery |
registerServiceExporter(ServiceExporter exporter,
JsonObject configuration,
Handler<AsyncResult<Void>> completionHandler)
Registers a discovery bridge.
|
Future<Void> |
registerServiceImporter(ServiceImporter importer,
JsonObject configuration)
Like
registerServiceImporter(ServiceImporter, JsonObject, Handler) but returns a Future of the asynchronous result |
ServiceDiscovery |
registerServiceImporter(ServiceImporter importer,
JsonObject configuration,
Handler<AsyncResult<Void>> completionHandler)
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
get methods from the service type interface. |
Future<Void> |
unpublish(String id)
Like
unpublish(String, Handler) but returns a Future of the asynchronous result |
void |
unpublish(String id,
Handler<AsyncResult<Void>> resultHandler)
Un-publishes a record.
|
Future<Record> |
update(Record record)
Like
update(Record, Handler) but returns a Future of the asynchronous result |
void |
update(Record record,
Handler<AsyncResult<Record>> resultHandler)
Updates the given record.
|
static ServiceDiscovery create(Vertx vertx, ServiceDiscoveryOptions options)
ServiceDiscovery
.vertx
- the vert.x instanceoptions
- the discovery optionsstatic ServiceDiscovery create(Vertx vertx)
ServiceDiscovery
using the default configuration.vertx
- the vert.x instanceServiceReference getReference(Record record)
record
- the chosen recordServiceReference getReferenceWithConfiguration(Record record, JsonObject configuration)
record
- the chosen recordconfiguration
- the configurationboolean release(ServiceReference reference)
reference
- the reference to release, must not be null
Future<Void> registerServiceImporter(ServiceImporter importer, JsonObject configuration)
registerServiceImporter(ServiceImporter, JsonObject, Handler)
but returns a Future
of the asynchronous resultServiceDiscovery registerServiceImporter(ServiceImporter importer, JsonObject configuration, Handler<AsyncResult<Void>> completionHandler)
importer
- the service importerconfiguration
- the optional configurationcompletionHandler
- handler call when the importer has finished its initialization and
initial importsServiceDiscovery
Future<Void> registerServiceExporter(ServiceExporter exporter, JsonObject configuration)
registerServiceExporter(ServiceExporter, JsonObject, Handler)
but returns a Future
of the asynchronous resultServiceDiscovery registerServiceExporter(ServiceExporter exporter, JsonObject configuration, Handler<AsyncResult<Void>> completionHandler)
exporter
- the service exporterconfiguration
- the optional configurationcompletionHandler
- handler notified when the exporter has been correctly initialized.ServiceDiscovery
void close()
void publish(Record record, Handler<AsyncResult<Record>> resultHandler)
record
- the recordresultHandler
- handler called when the operation has completed (successfully or not). In case of success,
the passed record has a registration id required to modify and un-register the service.Future<Record> publish(Record record)
publish(Record, Handler)
but returns a Future
of the asynchronous resultvoid unpublish(String id, Handler<AsyncResult<Void>> resultHandler)
id
- the registration idresultHandler
- handler called when the operation has completed (successfully or not).Future<Void> unpublish(String id)
unpublish(String, Handler)
but returns a Future
of the asynchronous resultvoid getRecord(JsonObject filter, Handler<AsyncResult<Record>> resultHandler)
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.resultHandler
- handler called when the lookup has been completed. When there are no matching record, the
operation succeeds, but the async result has no result (null
).Future<Record> getRecord(JsonObject filter)
getRecord(JsonObject, Handler)
but returns a Future
of the asynchronous resultvoid getRecord(java.util.function.Function<Record,Boolean> filter, Handler<AsyncResult<Record>> resultHandler)
The filter is a Function
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 recordsresultHandler
- the result handler called when the lookup has been completed. When there are no matching
record, the operation succeed, but the async result has no result.Future<Record> getRecord(java.util.function.Function<Record,Boolean> filter)
getRecord(Function, Handler)
but returns a Future
of the asynchronous resultvoid getRecord(java.util.function.Function<Record,Boolean> filter, boolean includeOutOfService, Handler<AsyncResult<Record>> resultHandler)
The filter is a Function
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(Function, Handler)
, 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
recordsresultHandler
- the result handler called when the lookup has been completed. When there are no matching
record, the operation succeed, but the async result has no result.Future<Record> getRecord(java.util.function.Function<Record,Boolean> filter, boolean includeOutOfService)
getRecords(Function, boolean, Handler)
but returns a Future
of the asynchronous resultvoid getRecords(JsonObject filter, Handler<AsyncResult<List<Record>>> resultHandler)
getRecord(JsonObject, Handler)
, this method returns all matching
records.filter
- the filter - see getRecord(JsonObject, Handler)
resultHandler
- handler called when the lookup has been completed. When there are no matching record, the
operation succeed, but the async result has an empty list as result.Future<List<Record>> getRecords(JsonObject filter)
getRecords(JsonObject, Handler)
but returns a Future
of the asynchronous resultvoid getRecords(java.util.function.Function<Record,Boolean> filter, Handler<AsyncResult<List<Record>>> resultHandler)
getRecord(Function, Handler)
, this method returns all matching
records.
The filter is a Function
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 recordsresultHandler
- handler called when the lookup has been completed. When there are no matching record, the
operation succeed, but the async result has an empty list as result.Future<List<Record>> getRecords(java.util.function.Function<Record,Boolean> filter)
getRecords(Function, Handler)
but returns a Future
of the asynchronous resultvoid getRecords(java.util.function.Function<Record,Boolean> filter, boolean includeOutOfService, Handler<AsyncResult<List<Record>>> resultHandler)
getRecord(Function, Handler)
, this method returns all matching
records.
The filter is a Function
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(Function, Handler)
, 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
recordsresultHandler
- handler called when the lookup has been completed. When there are no matching record, the
operation succeed, but the async result has an empty list as result.Future<List<Record>> getRecords(java.util.function.Function<Record,Boolean> filter, boolean includeOutOfService)
getRecords(Function, boolean, Handler)
but returns a Future
of the asynchronous resultvoid update(Record record, Handler<AsyncResult<Record>> resultHandler)
record
- the updated recordresultHandler
- handler called when the lookup has been completed.Future<Record> update(Record record)
update(Record, Handler)
but returns a Future
of the asynchronous resultSet<ServiceReference> bindings()
ServiceDiscoveryOptions options()
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 objectCopyright © 2020 Eclipse. All rights reserved.