Skip to content
/ w-ping Public

A pure python multi-ping program, it's simple and light.

Notifications You must be signed in to change notification settings

day0ng/w-ping

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

39 Commits
 
 
 
 
 
 

Repository files navigation

This is a pure python ping, and it's light and simple. The original code of python ping is from https://github.com/samuel/python-ping/.

2016-09-15:

There's something wrong with pure-python-ping. It gets wrong latency, and I can not fix it. So I set Linux ping as default instead of pure-python-ping. The pure-python-ping can be enabled with --pyping.

Wang Dayong (Email: [email protected]Weibo: wandering997)

[root@TEST w-ping]# ./w-ping.py
usage: w-ping.py [-h] [-b BIND] [-c COUNT] [-d DIR] [-i INTERVAL] [--ip IP] [-f FILE] [-l LOG] [--level LEVEL]
                 [-m MAX] [--pyping] [--shell] [-s] [-t TIMEOUT]

  This is a pure-python-ping, it was designed for pinging a lot of IP addresses.
  But pure-python-ping gets wrong latency and I can not fix it. So I set Linux
  ping as default, and pure-python-ping can be enabled with --pyping.

optional arguments:
  -h, --help            show this help message and exit
  -b BIND, --bind BIND  Source IP address or Interface of Linux ping command.
  -c COUNT, --count COUNT
                        Same to -c of ping, accepts 0 to 1000, default is 1.
  -d DIR, --dir DIR     Default is blank, its where the ping result to be stored only when dir is specified.
                        Example:
                        /var/log/w-ping/$(date "+%Y")/$(date "+%Y%m%d")/
  -i INTERVAL, --interval INTERVAL
                        Same to -i of ping, accepts 0 to 60, default is 0.2s, less than 0.2 needs root privilege.
  --ip IP               Destination IP list.
  -f FILE, --file FILE  Destination IP list file.
  -l LOG, --log LOG     Log file, default is not set, then log to stdout.
  --level LEVEL         Log level, could be 50(critical), 40(error), 30(warning), 20(info) and 10(debug), default is 20.
  -m MAX, --max MAX     The maximum threads/processes could be spread each time, default is 1000.
  --pyping              Use pure python ping instead of Linux ping, default is Linux ping.
  --shell               Use Linux ping output style instead of csv.
  -s, --silence         Silence mode.
  -t TIMEOUT, --timeout TIMEOUT
                        Timeout of each thread, accepts 0.01 to 60s, default is 1s.

Log format:

  yyyy-mm-dd HH:MM:SS, ip, pkt_sent, pkt_recv, loss, rtt_min, rtt_avg, rtt_max, bind_addr/interface

Example:

  w-ping.py --ip 192.168.0.1,192.168.0.2
  w-ping.py -f ip.test -d /tmp/test/ -i 0.1 -t 5
  w-ping.py --file ip.test --dir /tmp/test/ --interval 0.1 --timeout 5

[root@TEST w-ping]#

These are some examples for different options:

[root@TEST w-ping]#
[root@TEST w-ping]# ./w-ping.py --ip 192.168.0.6
2016-09-16 09:31:09 [INFO] [w-ping.py, line:343] 2016-09-16 09:31:09, 192.168.0.6, 1, 1, 0.00%, 1.749, 1.749, 1.749,
[root@TEST w-ping]#
[root@TEST w-ping]# ./w-ping.py --ip 192.168.0.6 -c 5
2016-09-16 09:32:01 [INFO] [w-ping.py, line:343] 2016-09-16 09:32:00, 192.168.0.6, 5, 5, 0.00%, 1.453, 1.587, 1.822,
[root@TEST w-ping]#
[root@TEST w-ping]# ./w-ping.py --ip 192.168.0.6 --shell
2016-09-16 09:32:31 [INFO] [w-ping.py, line:343]
PING 192.168.0.6 (192.168.0.6) 56(84) bytes of data.
64 bytes from 192.168.0.6: icmp_seq=1 ttl=252 time=1.61 ms

--- 192.168.0.6 ping statistics ---
1 packets transmitted, 1 received, 0% packet loss, time 1ms
rtt min/avg/max/mdev = 1.615/1.615/1.615/0.000 ms

[root@TEST w-ping]#
[root@TEST w-ping]# ./w-ping.py --ip 192.168.0.6 --shell -c 5
2016-09-16 09:33:13 [INFO] [w-ping.py, line:343]
PING 192.168.0.6 (192.168.0.6) 56(84) bytes of data.
64 bytes from 192.168.0.6: icmp_seq=1 ttl=252 time=1.94 ms
64 bytes from 192.168.0.6: icmp_seq=2 ttl=252 time=1.90 ms
64 bytes from 192.168.0.6: icmp_seq=3 ttl=252 time=1.97 ms
64 bytes from 192.168.0.6: icmp_seq=4 ttl=252 time=1.47 ms
64 bytes from 192.168.0.6: icmp_seq=5 ttl=252 time=1.51 ms

--- 192.168.0.6 ping statistics ---
5 packets transmitted, 5 received, 0% packet loss, time 804ms
rtt min/avg/max/mdev = 1.470/1.762/1.972/0.225 ms

[root@TEST w-ping]#
[root@TEST w-ping]# cat ip |wc -l
1000
[root@TEST w-ping]#
[root@TEST w-ping]# tail ip
10.168.212.58
10.168.212.60
10.168.212.70
10.168.212.72
10.168.212.74
10.168.212.76
10.168.212.80
10.168.212.84
10.168.212.85
10.168.212.88
[root@TEST w-ping]#
[root@TEST w-ping]# time ./w-ping.py -f ip -d ./test
real	0m10.226s
user	0m2.464s
sys	    0m4.172s
[root@TEST w-ping]#
[root@TEST w-ping]# ls test/ |wc -l
1000
[root@TEST w-ping]#
[root@TEST w-ping]# [root@CT_YF-NMS-2 140.12]# tail test/10.168.212.88
2016-09-16 22:43:18, 10.168.212.88, 1, 1, 0.00%, 1.214, 1.214, 1.214,
[root@TEST w-ping]#
[root@TEST w-ping]#

About

A pure python multi-ping program, it's simple and light.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages