node_mdns

mdns/zeroconf/bonjour service discovery add-on for node.js

  • Owner: agnat/node_mdns
  • Platform:
  • License:: MIT License
  • Category::
  • Topic:
  • Like:
    0
      Compare:

Github stars Tracking Chart

mdns -- node.js Service Discovery

  • Package: mdns
  • Description: multicast DNS service discovery
  • Installation: npm install mdns (see below)
  • Documentation: mdns user guide
  • License: MIT
  • Donations: Flattr this git repository

mdns adds multicast DNS service discovery, also known as zeroconf or bonjour to Node.js. It provides an object based interface to announce and browse services on the local network.

Synopsis

// import the module
const mdns = require('mdns');

// advertise a http server on port 4321
const ad = mdns.createAdvertisement(mdns.tcp('http'), 4321);
ad.start();

// watch all http servers
const browser = mdns.createBrowser(mdns.tcp('http'));
browser.on('serviceUp', service => {
  console.log("service up: ", service);
});
browser.on('serviceDown', service => {
  console.log("service down: ", service);
});
browser.start();

// discover all available service types
const all_the_types = mdns.browseThemAll(); // all_the_types is just another browser...

Installation

On Linux and other systems using the avahi daemon the avahi dns_sd compat library and its header files are required. On debianesque systems the package name is libavahi-compat-libdnssd-dev, on fedoraesque systems the package is avahi-compat-libdns_sd-devel. On other platforms Apple's mDNSResponder is recommended. Care should be taken not to install more than one mDNS stack on a system.

On Windows you are going to need Apples "Bonjour SDK for Windows". You can download it either from Apple (registration required) or various unofficial sources. Take your pick. After installing the SDK restart your computer and make sure the BONJOUR_SDK_HOME environment variable is set. You'll also need a compiler. Microsoft Visual Studio Express will do. On Windows node >=0.7.9 is required.

mdns is available as a npm package:

npm install mdns

If you want to play with the latest source code, here is a more manual approach:

git clone http://github.com/agnat/node_mdns
cd node_mdns
npm link && npm test

In case you want to run or even publish your package using the development version of mdns you may set the version field to a tarball URL:

{ "name": "discomvobulator"
, "version": "0.0.1"
, "description": "covers all your discomvobulation needs"
, "dependencies":
  { "mdns": "https://github.com/agnat/node_mdns/tarball/master"
  }
}

Documentation

See the user guide.

Contributors

In random order:

Your name is missing on the list? Shame on me. Please open an issue.

Bugs and Contributions

If you find a bug, please report it using the issue tracker.

Main metrics

Overview
Name With Owneragnat/node_mdns
Primary LanguageJavaScript
Program languageMakefile (Language Count: 5)
Platform
License:MIT License
所有者活动
Created At2010-05-01 20:48:42
Pushed At2024-02-23 12:35:18
Last Commit At2021-04-19 22:03:05
Release Count24
Last Release Namev2.7.2 (Posted on )
First Release Namev0.0.4 (Posted on 2012-01-12 14:24:31)
用户参与
Stargazers Count874
Watchers Count23
Fork Count147
Commits Count631
Has Issues Enabled
Issues Count205
Issue Open Count35
Pull Requests Count40
Pull Requests Open Count8
Pull Requests Close Count16
项目设置
Has Wiki Enabled
Is Archived
Is Fork
Is Locked
Is Mirror
Is Private