Skip to content

Latest commit

 

History

History
93 lines (72 loc) · 3.3 KB

README.md

File metadata and controls

93 lines (72 loc) · 3.3 KB

Build Status

ServiceRegistry

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.

Connect to etcd

var Registry = require('etcd-service-registry');

var registry = new Registry();
var registry = new Registry('127.0.0.1', '4001');

Register a service

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(...);

Discover a service

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']
// }

Discover several services at once

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' ]
//     }
// }

Service Sidekick

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]