a ping wrapper for nodejs
@last-modified: 2025-09-29
(C) Daniel Zelisko
http://github.com/danielzzz/node-ping
node-ping is a simple wrapper for the system ping utility.
npm install ping
Notes:
- Although it is marked with node >=22, it should technially working in all node version for production purpose. The version is marked for development point of view
Below are examples extracted from examples
var ping = require('ping');
var hosts = ['192.168.1.1', 'google.com', 'yahoo.com'];
hosts.forEach(function(host){
ping.sys.probe(host, function(isAlive){
var msg = isAlive ? 'host ' + host + ' is alive' : 'host ' + host + ' is dead';
console.log(msg);
});
});
var cfg = {
timeout: 10,
// WARNING: -i 2 may not work in other platform like windows
extra: ['-i', '2'],
};
hosts.forEach(function(host){
ping.sys.probe(host, function(isAlive){
var msg = isAlive ? 'host ' + host + ' is alive' : 'host ' + host + ' is dead';
console.log(msg);
}, cfg);
});
var ping = require('ping');
var hosts = ['192.168.1.1', 'google.com', 'yahoo.com'];
hosts.forEach(function (host) {
ping.promise.probe(host)
.then(function (res) {
console.log(res);
});
});
hosts.forEach(function (host) {
// WARNING: -i 2 argument may not work in other platform like windows
ping.promise.probe(host, {
timeout: 10,
extra: ['-i', '2'],
}).then(function (res) {
console.log(res);
});
});
var ping = require('ping');
var hosts = ['192.168.1.1', 'google.com', 'yahoo.com'];
for(let host of hosts){
let res = await ping.promise.probe(host);
console.log(res);
}
var ping = require('ping');
var hosts = ['192.168.1.1', 'google.com', 'yahoo.com'];
for(let host of hosts){
// WARNING: -i 2 argument may not work in other platform like windows
let res = await ping.promise.probe(host, {
timeout: 10,
extra: ['-i', '2'],
});
console.log(res);
}
See PingConfig
in types/index.d.ts
- For callback based implementation:
See probeCallback
in types/ping-sys.d.ts
- For promise based implementation
See PingResponse
in types/ping-promise.d.ts
-
Since
ping
in this module relies on theping
from underlying platform, arguments inPingConfig.extra
will definitely be varied across different platforms. -
However,
numeric
,timeout
andmin_reply
have been abstracted. Values for them are expected to be cross platform. -
By setting
numeric
,timeout
ormin_reply
to false, you can runping
without corresponding arguments.
- It does not work with busybox's ping implemetation #89
Try to install package iputils
. For example, running apk add iputils
-
For questions regarding to the implementation of
timeout
, anddeadline
, please checkout discussions in #101 -
For questions regarding to the defintions of
host
,inputHost
, andnumeric_host
, please checkout discussions in #133
Before opening a pull request please make sure your changes follow the contribution guidelines.
Made with contrib.rocks.