vmapi-resolver

2.1.0 • Public • Published

vmapi-resolver

This is a node-cueball Resolver which uses VMAPI to discover backends.

vmapi-resolver periodically polls VMAPI for information about deployed virtual machines. This is meant to be used as a library imported into a program that uses node-cueball to manage connections.

If VMs with the given NIC and VM tags has its state transitioned to 'running', it will be picked up by vmapi-resolver and emitted with an 'added' event. If a VM that was running leaves the 'running' state, vmapi-resolver will emit a 'removed' event.

For more information on Cueball resolvers, see the Cueball documentation.

Install

npm install vmapi-resolver

Example

This is a minimal example of how to use vmapi-resolver:

var mod_resolver = require('vmapi-resolver');
var mod_bunyan = require('bunyan');
 
var log = mod_bunyan.createLogger({name: 'main'});
var resolver = new mod_resolver.VmapiResolver({
    'log': log,
    'url': 'http://vmapi.coal-1.example.com', /* VMAPI url */
    'pollInterval': 600000, /* poll VMAPI every 10 minutes */
    'tags': { /* NIC and VM tags */
        'vm_tag_name': 'manta_role',
        'vm_tag_value': '*postgres', /* VMAPI's wildcard matching */
        'nic_tag': 'manta.*' /* regexp-based match */
    },
    'backend_port': 5432 /* port number of the listening process */
});
 
resolver.on('added', function (key, backend) {
    log.info(backend, 'added');
});
 
resolver.on('removed', function (backend) {
    log.info(backend, 'removed');
});
 
resolver.start();

Each backend has a "tag" object that details the matched tag name and value from the query to VMAPI, but only if an exact match can be found in the tag name (i.e. no wildcard is used in "vm_tag_name").

License

MPL v2. See the LICENSE file.

Contributing

Contributions should be made via the Joyent Gerrit. See the CONTRIBUTING file.

Dependencies (6)

Dev Dependencies (0)

    Package Sidebar

    Install

    npm i vmapi-resolver

    Weekly Downloads

    3

    Version

    2.1.0

    License

    MPL-2.0

    Unpacked Size

    44.8 kB

    Total Files

    8

    Last publish

    Collaborators

    • bahamat
    • todd.whiteman
    • kusor
    • michael.hicks
    • melloc
    • kkantor