Skip to content

Latest commit

 

History

History
533 lines (323 loc) · 14.6 KB

2-functions.md

File metadata and controls

533 lines (323 loc) · 14.6 KB

Built-in functions

ping

Send ICMP Echo Request packets to a network host.

ping(address, count=4, interval=1, timeout=2, id=None, source=None, family=None, privileged=True, **kwargs)

Parameters

  • address

    The IP address, hostname or FQDN of the host to which messages should be sent. For deterministic behavior, prefer to use an IP address.

    • Type: str
  • count

    The number of ping to perform.

    • Type: int
    • Default: 4
  • interval

    The interval in seconds between sending each packet.

    • Type: int or float
    • Default: 1
  • timeout

    The maximum waiting time for receiving a reply in seconds.

    • Type: int or float
    • Default: 2
  • id

    The identifier of ICMP requests. Used to match the responses with requests. In practice, a unique identifier should be used for every ping process. On Linux, this identifier is ignored when the privileged parameter is disabled. The library handles this identifier itself by default.

    • Type: int
    • Default: None
  • source

    The IP address from which you want to send packets. By default, the interface is automatically chosen according to the specified destination.

    • Type: str
    • Default: None
  • family

    The address family if a hostname or FQDN is specified. Can be set to 4 for IPv4 or 6 for IPv6 addresses. By default, this function searches for IPv4 addresses first before searching for IPv6 addresses.

    • Type: int
    • Default: None
  • privileged

    When this option is enabled, this library fully manages the exchanges and the structure of ICMP packets. Disable this option if you want to use this function without root privileges and let the kernel handle ICMP headers.

    Learn more about the privileged parameter.

    Only available on Unix systems. Ignored on Windows.

    • Type: bool
    • Default: True
  • payload

    The payload content in bytes. A random payload is used by default.

    • Type: bytes
    • Default: None
  • payload_size

    The payload size. Ignored when the payload parameter is set.

    • Type: int
    • Default: 56
  • traffic_class

    The traffic class of ICMP packets. Provides a defined level of service to packets by setting the DS Field (formerly TOS) or the Traffic Class field of IP headers. Packets are delivered with the minimum priority by default (Best-effort delivery). Intermediate routers must be able to support this feature.

    Only available on Unix systems. Ignored on Windows.

    • Type: int
    • Default: 0

Return value

  • A Host object containing statistics about the desired destination:
    address, min_rtt, avg_rtt, max_rtt, rtts, packets_sent, packets_received, packet_loss, jitter, is_alive

Exceptions

Example

>>> from icmplib import ping

>>> host = ping('1.1.1.1', count=10, interval=0.2)

>>> host.address              # The IP address of the host that responded
'1.1.1.1'                     # to the request

>>> host.min_rtt              # The minimum round-trip time in milliseconds
5.761

>>> host.avg_rtt              # The average round-trip time in milliseconds
12.036

>>> host.max_rtt              # The maximum round-trip time in milliseconds
16.207

>>> host.rtts                 # The list of round-trip times expressed in
[ 11.595, 13.135, 9.614,      # milliseconds
  16.018, 11.960, 5.761,      # The results are not rounded unlike other
  16.207, 11.937, 12.098 ]    # properties

>>> host.packets_sent         # The number of requests transmitted to the
10                            # remote host

>>> host.packets_received     # The number of ICMP responses received from
9                             # the remote host

>>> host.packet_loss          # Packet loss occurs when packets fail to
0.1                           # reach their destination. Returns a float
                              # between 0 and 1 (all packets are lost)

>>> host.jitter               # The jitter in milliseconds, defined as the
4.575                         # variance of the latency of packets flowing
                              # through the network

>>> host.is_alive             # Indicates whether the host is reachable
True

multiping

Send ICMP Echo Request packets to several network hosts.

multiping(addresses, count=2, interval=0.5, timeout=2, concurrent_tasks=50, source=None, family=None, privileged=True, **kwargs)

Parameters

  • addresses

    The IP addresses of the hosts to which messages should be sent. Hostnames and FQDNs are allowed but not recommended. You can easily retrieve their IP address by calling the built-in resolve function.

    • Type: list[str]
  • count

    The number of ping to perform per address.

    • Type: int
    • Default: 2
  • interval

    The interval in seconds between sending each packet.

    • Type: int or float
    • Default: 0.5
  • timeout

    The maximum waiting time for receiving a reply in seconds.

    • Type: int or float
    • Default: 2
  • concurrent_tasks

    The maximum number of concurrent tasks to speed up processing. This value cannot exceed the maximum number of file descriptors configured on the operating system.

    • Type: int
    • Default: 50
  • source

    The IP address from which you want to send packets. By default, the interface is automatically chosen according to the specified destinations. This parameter should not be used if you are passing both IPv4 and IPv6 addresses to this function.

    • Type: str
    • Default: None
  • family

    The address family if a hostname or FQDN is specified. Can be set to 4 for IPv4 or 6 for IPv6 addresses. By default, this function searches for IPv4 addresses first before searching for IPv6 addresses.

    • Type: int
    • Default: None
  • privileged

    When this option is enabled, this library fully manages the exchanges and the structure of ICMP packets. Disable this option if you want to use this function without root privileges and let the kernel handle ICMP headers.

    Learn more about the privileged parameter.

    Only available on Unix systems. Ignored on Windows.

    • Type: bool
    • Default: True
  • payload

    The payload content in bytes. A random payload is used by default.

    • Type: bytes
    • Default: None
  • payload_size

    The payload size. Ignored when the payload parameter is set.

    • Type: int
    • Default: 56
  • traffic_class

    The traffic class of ICMP packets. Provides a defined level of service to packets by setting the DS Field (formerly TOS) or the Traffic Class field of IP headers. Packets are delivered with the minimum priority by default (Best-effort delivery). Intermediate routers must be able to support this feature.

    Only available on Unix systems. Ignored on Windows.

    • Type: int
    • Default: 0

Return value

  • A list of Host objects containing statistics about the desired destinations:
    address, min_rtt, avg_rtt, max_rtt, rtts, packets_sent, packets_received, packet_loss, jitter, is_alive

    The list is sorted in the same order as the addresses passed in parameters.

Exceptions

Example

>>> from icmplib import multiping

>>> hosts = multiping(['10.0.0.5', '127.0.0.1', '::1'])

>>> for host in hosts:
...     if host.is_alive:
...         # See the Host class for details
...         print(f'{host.address} is up!')
...     else:
...         print(f'{host.address} is down!')

# 10.0.0.5 is down!
# 127.0.0.1 is up!
# ::1 is up!

traceroute

Determine the route to a destination host.

The Internet is a large and complex aggregation of network hardware, connected together by gateways. Tracking the route one's packets follow can be difficult. This function uses the IP protocol time to live field and attempts to elicit an ICMP Time Exceeded response from each gateway along the path to some host.

This function requires root privileges to run.

traceroute(address, count=2, interval=0.05, timeout=2, first_hop=1, max_hops=30, fast=False, id=None, source=None, family=None, **kwargs)

Parameters

  • address

    The IP address, hostname or FQDN of the host to reach. For deterministic behavior, prefer to use an IP address.

    • Type: str
  • count

    The number of ping to perform per hop.

    • Type: int
    • Default: 2
  • interval

    The interval in seconds between sending each packet.

    • Type: int or float
    • Default: 0.05
  • timeout

    The maximum waiting time for receiving a reply in seconds.

    • Type: int or float
    • Default: 2
  • first_hop

    The initial time to live value used in outgoing probe packets.

    • Type: int
    • Default: 1
  • max_hops

    The maximum time to live (max number of hops) used in outgoing probe packets.

    • Type: int
    • Default: 30
  • fast

    When this option is enabled and an intermediate router has been reached, skip to the next hop rather than perform additional requests. The count parameter then becomes the maximum number of requests in the event of no response.

    • Type: bool
    • Default: False
  • id

    The identifier of ICMP requests. Used to match the responses with requests. In practice, a unique identifier should be used for every traceroute process. The library handles this identifier itself by default.

    • Type: int
    • Default: None
  • source

    The IP address from which you want to send packets. By default, the interface is automatically chosen according to the specified destination.

    • Type: str
    • Default: None
  • family

    The address family if a hostname or FQDN is specified. Can be set to 4 for IPv4 or 6 for IPv6 addresses. By default, this function searches for IPv4 addresses first before searching for IPv6 addresses.

    • Type: int
    • Default: None
  • payload

    The payload content in bytes. A random payload is used by default.

    • Type: bytes
    • Default: None
  • payload_size

    The payload size. Ignored when the payload parameter is set.

    • Type: int
    • Default: 56
  • traffic_class

    The traffic class of ICMP packets. Provides a defined level of service to packets by setting the DS Field (formerly TOS) or the Traffic Class field of IP headers. Packets are delivered with the minimum priority by default (Best-effort delivery). Intermediate routers must be able to support this feature.

    Only available on Unix systems. Ignored on Windows.

    • Type: int
    • Default: 0

Return value

  • A list of Hop objects representing the route to the desired destination. A Hop has the same properties as a Host object but it also has a distance:
    address, min_rtt, avg_rtt, max_rtt, rtts, packets_sent, packets_received, packet_loss, jitter, is_alive, distance

    The list is sorted in ascending order according to the distance, in terms of hops, that separates the remote host from the current machine. Gateways that do not respond to requests are not added to this list.

Exceptions

Example

>>> from icmplib import traceroute

>>> hops = traceroute('1.1.1.1')

>>> print('Distance/TTL    Address    Average round-trip time')
>>> last_distance = 0

>>> for hop in hops:
...     if last_distance + 1 != hop.distance:
...         print('Some gateways are not responding')
...
...     # See the Hop class for details
...     print(f'{hop.distance}    {hop.address}    {hop.avg_rtt} ms')
...
...     last_distance = hop.distance

# Distance/TTL    Address                 Average round-trip time
# 1               10.0.0.1                5.196 ms
# 2               194.149.169.49          7.552 ms
# 3               194.149.166.54          12.21 ms
# *               Some gateways are not responding
# 5               212.73.205.22           22.15 ms
# 6               1.1.1.1                 13.59 ms

async_ping

Send ICMP Echo Request packets to a network host.

This function is non-blocking.

async_ping(address, count=4, interval=1, timeout=2, id=None, source=None, family=None, privileged=True, **kwargs)

Parameters, return value and exceptions

The same parameters, return value and exceptions as for the ping function.

Example

>>> import asyncio
>>> from icmplib import async_ping

>>> async def is_alive(address):
...     host = await async_ping(address, count=10, interval=0.2)
...     return host.is_alive

>>> asyncio.run(is_alive('1.1.1.1'))
True

async_multiping

Send ICMP Echo Request packets to several network hosts.

This function is non-blocking.

async_multiping(addresses, count=2, interval=0.5, timeout=2, concurrent_tasks=50, source=None, family=None, privileged=True, **kwargs)

Parameters, return value and exceptions

The same parameters, return values and exceptions as for the multiping function.

Example

>>> import asyncio
>>> from icmplib import async_multiping

>>> async def are_alive(*addresses):
...     hosts = await async_multiping(addresses)
...     
...     for host in hosts:
...         if not host.is_alive:
...             return False
...
...     return True

>>> asyncio.run(are_alive('10.0.0.5', '127.0.0.1', '::1'))
False