ping (networking utility)






























ping
Original author(s) Mike Muuss
Developer(s) Erick Engelke, Microsoft, ReactOS Contributors
Initial release 1983; 36 years ago (1983)
Platform
Unix, Unix-like systems, FreeDOS, Microsoft Windows, ReactOS
Type Command

Ping is a computer network administration software utility used to test the reachability of a host on an Internet Protocol (IP) network. It measures the round-trip time for messages sent from the originating host to a destination computer that are echoed back to the source. The name comes from active sonar terminology that sends a pulse of sound and listens for the echo to detect objects under water,[1] although it is sometimes interpreted as a backronym to packet Internet groper.[2]


The command is available for Unix and Unix-like operating systems, DOS (e.g. FreeDOS), Microsoft Windows, and ReactOS.


Ping operates by sending Internet Control Message Protocol (ICMP) echo request packets to the target host and waiting for an ICMP echo reply. The program reports errors, packet loss, and a statistical summary of the results, typically including the minimum, maximum, the mean round-trip times, and standard deviation of the mean.


The command-line options of the ping utility and its output vary between the numerous implementations. Options may include the size of the payload, count of tests, limits for the number of network hops (TTL) that probes traverse, and interval between the requests. Many systems provide a companion utility ping6, for testing on Internet Protocol version 6 (IPv6) networks, which implement ICMPv6.




Contents






  • 1 History


  • 2 Sample ping test


  • 3 Error indications


  • 4 Message format


    • 4.1 ICMP packet


    • 4.2 Echo request


    • 4.3 Echo reply


    • 4.4 Payload




  • 5 Security considerations


  • 6 See also


  • 7 References


  • 8 External links





History


The ping utility was written by Mike Muuss in December 1983 during his employment at the Ballistic Research Laboratory, now the US Army Research Laboratory. Created as a tool to troubleshoot problems in an IP network, Mike Muuss was inspired by a remark by David Mills on using ICMP echo packets for IP network diagnosis and measurements.[3] The author named it after the sound that sonar makes, since its methodology is analogous to sonar's echo location.[1][4] The first released version was public domain software while all subsequent versions were licensed under the BSD license. Ping was first included in 4.3BSD [5].


RFC 1122 prescribes that any host must process ICMP echo requests and issue echo replies in return.[6] However, as a security consideration, this is often disabled.[7]


The FreeDOS version was developed by Erick Engelke.[8]



Sample ping test


The following is the output of running ping on Linux for sending five probes to the target host www.example.com:


$ ping -c 5 www.example.com
PING www.example.com (93.184.216.34): 56 data bytes
64 bytes from 93.184.216.34: icmp_seq=0 ttl=56 time=11.632 ms
64 bytes from 93.184.216.34: icmp_seq=1 ttl=56 time=11.726 ms
64 bytes from 93.184.216.34: icmp_seq=2 ttl=56 time=10.683 ms
64 bytes from 93.184.216.34: icmp_seq=3 ttl=56 time=9.674 ms
64 bytes from 93.184.216.34: icmp_seq=4 ttl=56 time=11.127 ms

--- www.example.com ping statistics ---
5 packets transmitted, 5 packets received, 0.0% packet loss
round-trip min/avg/max/stddev = 9.674/10.968/11.726/0.748 ms

The output lists each probe message and the results obtained. Finally it lists the statistics of the entire test. In this example, the shortest round trip time was 9.674 ms, the average was 10.968 ms, and the maximum value was 11.726 ms. The measurement had a standard deviation of 0.748 ms.



Error indications


In cases of no response from the target host, most implementations display either nothing or periodically print notifications about timing out. Possible ping results indicating a problem include the following:




  • .mw-parser-output .monospaced{font-family:monospace,monospace}
    H,
    !N or
    !P – host, network or protocol unreachable



  • S – source route failed



  • F – fragmentation needed



  • U or
    !W – destination network/host unknown



  • I – source host is isolated



  • A – communication with destination network administratively prohibited



  • Z – communication with destination host administratively prohibited



  • Q – for this ToS the destination network is unreachable



  • T – for this ToS the destination host is unreachable



  • X – communication administratively prohibited



  • V – host precedence violation



  • C – precedence cutoff in effect


In case of error, the target host or an intermediate router sends back an ICMP error message, for example "host unreachable" or "TTL exceeded in transit". In addition, these messages include the first eight bytes of the original message (in this case header of the ICMP echo request, including the quench value), so the ping utility can match responses to originating queries.[9]



Message format



ICMP packet









































IPv4 Datagram
 
Bits 0–7
Bits 8–15
Bits 16–23
Bits 24–31

Header
(20 bytes)
Version/IHL
Type of service
Length
Identification

flags and offset
Time To Live (TTL)
Protocol
Header Checksum
Source IP address
Destination IP address
ICMP Header
(8 bytes)
Type of message
Code
Checksum
Header Data
ICMP Payload
(optional)
Payload Data






































IPv6 Datagram
 
Bits 0–3
Bits 4–7
Bits 8–11
Bits 12–15
Bits 16–23
Bits 24–31
Header
(40 bytes)
Version
Traffic Class
Flow Label
Payload Length
Next Header
Hop Limit
Source Address
Destination Address
ICMP6 Header
(8 bytes)
Type of message
Code
Checksum
Header Data
ICMP6 Payload
(optional)
Payload Data


Generic composition of an ICMP packet:[10]



  • IPv4 Header (in blue): protocol set to 1 (ICMP) and Type of Service set to 0.

  • IPv6 Header (in blue): Next Header set to 58 (ICMP6)

  • ICMP Header (in red):

    • Type of ICMP message (8 bits)

    • Code (8 bits)

    • Checksum (16 bits), calculated with the ICMP part of the packet (the IP header is not used). It is the 16-bit one's complement of the one's complement sum of the ICMP message starting with the Type field[11]

    • Header Data (32 bits) field, which in this case (ICMP echo request and replies), will be composed of identifier (16 bits) and sequence number (16 bits).



  • ICMP Payload: payload for the different kind of answers; can be an arbitrary length, left to implementation detail. However, the packet including IP and ICMP headers must be less than the maximum transmission unit of the network or risk being fragmented.



Echo request


The echo request ("ping") is an ICMP/ICMP6 message.















































00 01 02 03 04 05 06 07
08 09 10 11 12 13 14 15
16 17 18 19 20 21 22 23
24 25 26 27 28 29 30 31
Type = 8(IPv4, ICMP) 128(IPv6,ICMP6)
Code = 0
Header Checksum
Identifier
Sequence Number
Payload

The Identifier and Sequence Number can be used by the client to match the reply with the request that caused the reply. In practice, most Linux systems use a unique identifier for every ping process, and sequence number is an increasing number within that process. Windows uses a fixed identifier, which varies between Windows versions, and a sequence number that is only reset at boot time.



Echo reply


The echo reply is an ICMP message generated in response to an echo request; it is mandatory for all hosts, and must include the exact payload received in the request.















































00 01 02 03 04 05 06 07
08 09 10 11 12 13 14 15
16 17 18 19 20 21 22 23
24 25 26 27 28 29 30 31
Type = 0(IPv4,ICMP) 129(IPv6,ICMP6)
Code = 0
Header Checksum
Identifier
Sequence Number
Payload

  • The identifier and sequence number can be used by the client to associate each echo request with its reply.


Payload


The payload of the packet is generally filled with ASCII characters, as the output of the tcpdump utility shows in the last 32 bytes of the following example (after the eight-byte ICMP header starting with 0x0800):


16:24:47.966461 IP (tos 0x0, ttl 128, id 15103, offset 0, flags [none],
proto: ICMP (1), length: 60) 192.168.146.22 > 192.168.144.5: ICMP echo request,
id 1, seq 38, length 40
0x0000: 4500 003c 3aff 0000 8001 5c55 c0a8 9216 E..<:.....U....
0x0010: c0a8 9005 0800 4d35 0001 0026 6162 6364 ......M5...&abcd
0x0020: 6566 6768 696a 6b6c 6d6e 6f70 7172 7374 efghijklmnopqrst
0x0030: 7576 7761 6263 6465 6667 6869 uvwabcdefghi

The payload may include a timestamp indicating the time of transmission and a sequence number, which are not found in this example. This allows ping to compute the round trip time in a stateless manner without needing to record the time of transmission of each packet.


The payload may also include a magic packet for the Wake-on-LAN protocol, but the minimum payload in that case is longer than shown. The Echo Request typically does not receive any reply if the host was sleeping in hibernation state, but the host still wakes up from sleep state if its interface is configured to accept wakeup requests. If the host is already active and configured to allow replies to incoming ICMP Echo Request packets, the returned reply should include the same payload. This may be used to detect that the remote host was effectively woken up, by repeating a new request after some delay to allow the host to resume its network services. If the host was just sleeping in low power active state, a single request wakes up that host just enough to allow its Echo Reply service to reply instantly if that service was enabled. The host does not need to completely wake up all devices, and may return to low power mode after a short delay. Such configuration may be used to avoid a host to enter in hibernation state, with much longer wake up delay, after some time passed in low power active mode.[citation needed]



Security considerations


The "flood" ping option exists in many implementations, sending requests as fast as possible in an attempt to determine the response of the network under high-load conditions. That option is restricted to users having administrative privileges, but may be used in denial-of-service attacks to induce a ping flood, in which the attacker attempts to overwhelm the victim with ICMP echo requests.


Ping has been considered a security risk because merely acknowledging a host's presence turns it into a potential target. For these reasons, many systems provide means to disable the reply,[7][12] despite the fact that RFC 1122 mandates hosts to always send a reply. Additionally, round-trip times calculated by ping often lack integrity checking and thus cannot be relied upon in hostile environments. An adversary could elongate or shorten the calculated delays in most ping implementations.[13]


Host discovery, scanning or ping sweep is a feature of network scanning tools such as nmap, working by utilising ICMP echo packets. Other tools such as fping can also execute parallel ping to multiple host.



See also






  • fping [14]

  • Keepalive

  • List of DOS commands#PING

  • List of Unix utilities

  • Traceroute

  • Ping of death

  • Ping-pong scheme

  • Security through obscurity

  • Smurf attack




References





  1. ^ ab Mike Muuss. "The Story of the PING Program". U.S. Army Research Laboratory. Archived from the original on 8 September 2010. Retrieved 8 September 2010. I named it after the sound that a sonar makes, inspired by the whole principle of echo-location..mw-parser-output cite.citation{font-style:inherit}.mw-parser-output q{quotes:"""""""'""'"}.mw-parser-output code.cs1-code{color:inherit;background:inherit;border:inherit;padding:inherit}.mw-parser-output .cs1-lock-free a{background:url("//upload.wikimedia.org/wikipedia/commons/thumb/6/65/Lock-green.svg/9px-Lock-green.svg.png")no-repeat;background-position:right .1em center}.mw-parser-output .cs1-lock-limited a,.mw-parser-output .cs1-lock-registration a{background:url("//upload.wikimedia.org/wikipedia/commons/thumb/d/d6/Lock-gray-alt-2.svg/9px-Lock-gray-alt-2.svg.png")no-repeat;background-position:right .1em center}.mw-parser-output .cs1-lock-subscription a{background:url("//upload.wikimedia.org/wikipedia/commons/thumb/a/aa/Lock-red-alt-2.svg/9px-Lock-red-alt-2.svg.png")no-repeat;background-position:right .1em center}.mw-parser-output .cs1-subscription,.mw-parser-output .cs1-registration{color:#555}.mw-parser-output .cs1-subscription span,.mw-parser-output .cs1-registration span{border-bottom:1px dotted;cursor:help}.mw-parser-output .cs1-hidden-error{display:none;font-size:100%}.mw-parser-output .cs1-visible-error{font-size:100%}.mw-parser-output .cs1-subscription,.mw-parser-output .cs1-registration,.mw-parser-output .cs1-format{font-size:95%}.mw-parser-output .cs1-kern-left,.mw-parser-output .cs1-kern-wl-left{padding-left:0.2em}.mw-parser-output .cs1-kern-right,.mw-parser-output .cs1-kern-wl-right{padding-right:0.2em}


  2. ^ Mills, D.L. (December 1983). Internet Delay Experiments. IETF. p. 1. doi:10.17487/RFC0889. STD 8. RFC 889. https://tools.ietf.org/html/rfc889#page-1. Retrieved June 26, 2015. 


  3. ^ "The Story of the PING Program", Mike Muuss


  4. ^ Salus, Peter (1994). A Quarter Century of UNIX. Addison-Wesley. ISBN 0-201-54777-5.


  5. ^ http://www.manpagez.com/man/8/ping/


  6. ^ "RFC 1122 - Requirements for Internet Hosts -- Communication Layers". p. 42. Retrieved 2012-03-19. Every host MUST implement an ICMP Echo server function that receives Echo Requests and sends corresponding Echo Replies.


  7. ^ ab "Windows firewall: how block ICMP (echo response)".


  8. ^ http://www.ibiblio.org/pub/micro/pc-stuff/freedos/files/distributions/1.2/repos/pkg-html/ping.html


  9. ^ "ICMP: Internet Control Message Protocol". repo.hackerzvoice.net. January 13, 2000. Retrieved December 4, 2014.


  10. ^ "RFC 792 - Internet Control Message Protocol". Tools.ietf.org. Retrieved 2014-02-02.


  11. ^ "RFC Sourcebook's page on ICMP". Retrieved 20 December 2010.


  12. ^ "redhat linux /proc/sys/net/ipv4 parameters".


  13. ^ Abdou, AbdelRahman; Matrawy, Ashraf; van Oorschot, Paul (April 2017). Accurate Manipulation of Delay-based Internet Geolocation. ACM AsiaCCS. doi:10.1145/3052973.3052993.


  14. ^ https://github.com/schweikert/fping




External links




  • ping(1M) – Solaris 10 System Administration Commands Reference Manual


  • ping(8) – FreeBSD System Manager's Manual


  • Linux – Reference, The Single UNIX Specification, Issue 7 from The Open Group












Popular posts from this blog

Italian cuisine

Bulgarian cuisine

Carrot