A library to manage service registry and discover over etcd.
You will need a connection to etcd. If you're registering services, you will additionally need the public ip of your host.
In the common use case where your service is a docker container on top of CoreOS/Fleet, you will need to connect to the etcd endpoint at 172.17.42.1. You will determine your own ip/port by passing them as parameters in your fleet service definition.
var Registry = require('etcd-service-registry');
var registry = new Registry();
var registry = new Registry('127.0.0.1', '4001');
registry.Register('MyServiceName', // Name that will be used by your clients
'10.244.1.105', // IP that the service is bound to
'8080', // Port that the service is bound to
['Testing', 'V1.1']) // Some metadata tags
.then(...);
A call to Discover will not fulfill until the required service has been registered into etcd.
registry.Discover('MyServiceName')
.then(function(service) {
console.log(util.inspect(service))
})
.then(...);
// {
// name: 'MyServiceName',
// ip: '10.244.1.105',
// port: '8080'
// tags: ['Testing', 'V1.1']
// }
A call to DiscoverAll will not fulfill until all the services specified have been registered into etcd.
registry.DiscoverAll(['ServiceA', 'ServiceB'])
.then(function(services) {
console.log(util.inspect(services));
})
.then(...);
// {
// ServiceA:
// {
// name: 'ServiceA',
// ip: '192.168.1.1',
// port: '80',
// tags: [ 'Production', 'Version-1.12.3' ]
// },
// ServiceB:
// {
// name: 'ServiceB',
// ip: '192.168.1.2',
// port: '81',
// tags: [ 'Production', 'Version-1.12.4' ]
// }
// }
A sidekick is a component external to your service that monitors its health and based on this health check registers your service into etcd.
Sidekick-CLI under example/sidekick-cli is a CLI implementation of a sidekick service that you can instantly consume with very little effort. It offers inbuilt health check by polling the TCP socket of your service.
Why TCP instead of HTTP? TCP is more generic so it supports a broader array of services. What you lose by doing TCP polling is the ability to monitor a specific path such as /health - since the TCP poll only checks if the socket is open and is accepting connections.
Sidekick.js: Register and monitor a service on etcd via CLI.
Options:
-n, --name Name of the service you wish to register [required]
-i, --ip Publicly accesible ip of your service [required]
-p, --port Port of your service [required]
-e, --expiry Expiry interval for registration on etcd [default: 15]
-t, --poll Polling interval for health check [default: 5]
--ei, --etcdip Etcd service ip [default: "localhost"]
--ep, --etcdport Etcd service port [default: 4001]