Skip to content

Interactively ping multiple hosts from one location

License

Notifications You must be signed in to change notification settings

famzah/ping-multi

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

58 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Note: I recommend that you switch to the newer implementation: ping-multi-ext


ping-multi

Interactively ping one or multiple hosts from a single location.

Screenshot 1:

Ping-multi Screenshot 1

Screenshot 2:

Ping-multi Screenshot 2

Motivation

A Perl implementation which is easy to install and is also cross-platform.

Description

Ping-multi reads hosts from a file and sends ICMP ECHO_REQUEST to them. This is the same as the standard "ping", only executed in parallel for many hosts.

The results are displayed in an interactive curses text console which features the following:

  • "Hostname" or "Resolved IP" view of the hosts
  • Statistics about the ping results of each host:
    • Last round-trip-time (RTT)
    • Packet loss %
    • Average RTT
    • Minimum RTT
    • Maximum RTT
    • Standard deviation of the RTT
    • Received and Transmitted packets count
  • Ping history:
    • simple view showing received (.) and lost (X) reply packets
    • scaled view which additionally visualizes the RTT value using the numbers between 0 and 9

You can select the statistics forwards and backwards using the lower "s" and upper "S" keys, similar to the "Vim" behavior.

The host status changes can be logged to a file. This allows you to review the time of each event.

Installation

The program depends on the following additional Perl modules:

  • Curses
  • JSON
  • Statistics::Descriptive

On Debian/Ubuntu you can install them using the following command:

sudo apt-get install libcurses-perl libjson-perl libstatistics-descriptive-perl

Example

Ping multiple hosts specified directly on the command-line; you can also provide just one host:

sudo ./ping-multi google.com github.com

Ping multiple hosts specified in a file; you can also add more single hosts directly as additional command-line arguments:

sudo ./ping-multi -f sample.list

Ping and log up/down events to a file:

sudo ./ping-multi -l events.log google.com github.com

Ping hosts synchronously; this comment explains when this ping method is useful:

sudo ./ping-multi -S 192.168.0.1 192.168.0.2 192.168.0.15

Required privileges

Making ICMP ping requests requires "root" privileges on Linux.

Alternatively, you can and you should get advantage of the Linux capabilities and execute "ping-multi" with an unprivileged user who only has the CAP_NET_RAW capability. In such a case you need to define the environment variable PING_MULTI_NO_ROOT_CHECK, because the Perl module Net::Ping doesn't detect Linux capabilities. Here is a quick example, but do you own research on how to assign capabilities to a process:

sudo setpriv --reuid nobody --regid nogroup --init-groups \
	--inh-caps -all,+net_raw --ambient-caps -all,+net_raw \
	env PING_MULTI_NO_ROOT_CHECK=1 \
	./ping-multi google.com github.com

Docker

You can also use Docker to run ping-multi:

docker run --rm -it chrislwade/ping-multi
docker run --rm -it chrislwade/ping-multi google.com github.com
docker run --rm -it chrislwade/ping-multi -f sample.list
docker run --rm -it chrislwade/ping-multi -l events.log google.com github.com
docker run --rm -it chrislwade/ping-multi -S 192.168.0.1 192.168.0.2 192.168.0.15

The Docker image is maintainted by @chrislwade.

About

Interactively ping multiple hosts from one location

Topics

Resources

License

Stars

Watchers

Forks

Contributors 4

  •  
  •  
  •  
  •