https://github.com/advantageous/lokate
service discovery library
https://github.com/advantageous/lokate
Last synced: 10 months ago
JSON representation
service discovery library
- Host: GitHub
- URL: https://github.com/advantageous/lokate
- Owner: advantageous
- Created: 2016-02-24T20:13:23.000Z (almost 10 years ago)
- Default Branch: master
- Last Pushed: 2017-03-28T19:39:08.000Z (almost 9 years ago)
- Last Synced: 2025-01-22T11:47:57.617Z (12 months ago)
- Language: Java
- Homepage:
- Size: 229 KB
- Stars: 1
- Watchers: 15
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Discovery Service
Vert.x service for service discovery.
## Configuration URIs
DNS
```
dns://localhost:8600/
```
Consul
```
consul:http://192.168.99.100:8500
```
## Query URIs
DNS A Record Query.
```
discovery:dns:A:///admin.rbss-impressions-service-staging.service.consul?port=9090
discovery:dns:A://localhost:8600/admin.rbss-impressions-service-staging.service.consul?port=8080
```
DNS SVR Record Query.
```
discovery:dns:SRV:///admin.rbss-impressions-service-staging.service.consul
discovery:dns:SRV://localhost:8600/admin.rbss-impressions-service-staging.service.consul
```
Consul Query
```
discovery:consul:///impressions-service?name=eventbus&staging
discovery:consul:http://consul.rbmhops.net:3500/impressions-service?name=eventbus&staging
```
## Echo
One service
```
discovery:echo:http://foo.com:8080
```
Many
```
discovery:echo:http://foo.com:9090,http://bar.com:9091
```
You can use echo for testing locally.
## Notes
We used to support Docker, EC2 and Mesos
Docker
```
docker:http://localhost:3500/
```
Docker Query using custom host/port
```
discovery:docker:http://localhost:3500/impressions-service?containerPort=8080
```
Docker Query using default host and port.
```
discovery:docker:///impressions-service?containerPort=8080
```
We dropped the support. We might add it back.
If we add it back, we will do it as a separate jar file.
We use [JDK services](https://docs.oracle.com/javase/7/docs/api/java/util/ServiceLoader.html).
Resources/META-INF.services/io.advantageous.discovery.DiscoveryServiceFactory
```
io.advantageous.discovery.impl.DnsDiscoveryServiceFactory
io.advantageous.discovery.impl.ConsulDiscoveryServiceFactory
```