On this page
junipernetworks.junos.junos_ping – Tests reachability using ping from devices running Juniper JUNOS
Note
This plugin is part of the junipernetworks.junos collection (version 2.6.0).
You might already have this collection installed if you are using the ansible package. It is not included in ansible-core. To check whether it is installed, run ansible-galaxy collection list.
To install it, use: ansible-galaxy collection install junipernetworks.junos.
To use it in a playbook, specify: junipernetworks.junos.junos_ping.
New in version 1.0.0: of junipernetworks.junos
Synopsis
- Tests reachability using ping from devices running Juniper JUNOS to a remote destination.
 - Tested against Junos (17.3R1.10)
 - For a general purpose network module, see the ansible.netcommon.net_ping module.
 - For Windows targets, use the ansible.windows.win_ping module instead.
 - For targets running Python, use the ansible.builtin.ping module instead.
 
Note
This module has a corresponding action plugin.
Parameters
| Parameter | Choices/Defaults | Comments | |
|---|---|---|---|
| count
        
        integer
         | 
      Default: 
        5
         | 
      
        
        Number of packets to send to check reachability.
         | 
     |
| dest
        
        string / required
         | 
      
        
        The IP Address or hostname (resolvable by the device) of the remote node.
         | 
     ||
| df_bit
        
        boolean
         | 
      
       
  | 
      
        
        Determines whether to set the DF bit.
         | 
     |
| interface
        
        string
         | 
      
        
        The source interface to use while sending the ping packet(s).
         | 
     ||
| interval
        
        integer
         | 
      
        
        Determines the interval (in seconds) between consecutive pings.
         | 
     ||
| provider
        
        dictionary
         | 
      
        Deprecated
        
       
        Starting with Ansible 2.5 we recommend using  
       connection: network_cli or connection: netconf.
       
        For more information please see the Junos OS Platform Options guide.
        
       
        A dict object containing connection details.
         | 
     ||
| host
        
        string
         | 
      
        
        Specifies the DNS host name or address for connecting to the remote device over the specified transport. The value of host is used as the destination address for the transport.
         | 
     ||
| password
        
        string
         | 
      
        
        Specifies the password to use to authenticate the connection to the remote device. This value is used to authenticate the SSH session. If the value is not specified in the task, the value of environment variable  ANSIBLE_NET_PASSWORD will be used instead.
        | 
     ||
| port
        
        integer
         | 
      
        
        Specifies the port to use when building the connection to the remote device. The port value will default to the well known SSH port of 22 (for  transport=cli) or port 830 (for transport=netconf) device.
        | 
     ||
| ssh_keyfile
        
        path
         | 
      
        
        Specifies the SSH key to use to authenticate the connection to the remote device. This value is the path to the key used to authenticate the SSH session. If the value is not specified in the task, the value of environment variable  ANSIBLE_NET_SSH_KEYFILE will be used instead.
        | 
     ||
| timeout
        
        integer
         | 
      
        
        Specifies the timeout in seconds for communicating with the network device for either connecting or sending commands. If the timeout is exceeded before the operation is completed, the module will error.
         | 
     ||
| transport
        
        string
         | 
      
       
  | 
      
        
        Configures the transport connection to use when connecting to the remote device.
         | 
     |
| username
        
        string
         | 
      
        
        Configures the username to use to authenticate the connection to the remote device. This value is used to authenticate the SSH session. If the value is not specified in the task, the value of environment variable  ANSIBLE_NET_USERNAME will be used instead.
        | 
     ||
| rapid
        
        boolean
         | 
      
       
  | 
      
        
        Determines whether to send the packets rapidly.
         | 
     |
| size
        
        integer
         | 
      
        
        Determines the size (in bytes) of the ping packet(s).
         | 
     ||
| source
        
        string
         | 
      
        
        The IP Address to use while sending the ping packet(s).
         | 
     ||
| state
        
        string
         | 
      
       
  | 
      
        
        Determines if the expected result is success or fail.
         | 
     |
| ttl
        
        integer
         | 
      
        
        The time-to-live value for the ICMP packet(s).
         | 
     ||
Notes
Note
- For a general purpose network module, see the ansible.netcommon..net_ping module.
 - For Windows targets, use the ansible.windows.win_ping module instead.
 - For targets running Python, use the ansible.builtin.ping module instead.
 - This module works only with connection 
network_cli. - For information on using CLI and netconf see the Junos OS Platform Options guide
 - For more information on using Ansible to manage network devices see the Ansible Network Guide
 - For more information on using Ansible to manage Juniper network devices see https://www.ansible.com/ansible-juniper.
 
Examples
- name: Test reachability to 10.10.10.10
  junipernetworks.junos.junos_ping:
    dest: 10.10.10.10
- name: Test reachability to 10.20.20.20 using source and size set
  junipernetworks.junos.junos_ping:
    dest: 10.20.20.20
    size: 1024
    ttl: 128
- name: Test unreachability to 10.30.30.30 using interval
  junipernetworks.junos.junos_ping:
    dest: 10.30.30.30
    interval: 3
    state: absent
- name: Test reachability to 10.40.40.40 setting count and interface
  junipernetworks.junos.junos_ping:
    dest: 10.40.40.40
    interface: fxp0
    count: 20
    size: 512
- name: Test reachability to 10.50.50.50 using do-not-fragment and rapid
  junipernetworks.junos.junos_ping:
    dest: 10.50.50.50
    df_bit: True
    rapid: True
  Return Values
Common return values are documented here, the following are the fields unique to this module:
| Key | Returned | Description | 
|---|---|---|
| commands
        
        list / elements=string
         | 
      always | 
        
        List of commands sent.
         Sample:
        
       
        ['ping 10.8.38.44 count 10 source 10.8.38.38 ttl 128']
         | 
     
| packet_loss
        
        string
         | 
      always | 
        
        Percentage of packets lost.
         Sample:
        
       
        0%
         | 
     
| packets_rx
        
        integer
         | 
      always | 
        
        Packets successfully received.
         Sample:
        
       
        20
         | 
     
| packets_tx
        
        integer
         | 
      always | 
        
        Packets successfully transmitted.
         Sample:
        
       
        20
         | 
     
| rtt
        
        dictionary
         | 
      when ping succeeds | 
        
        The round trip time (RTT) stats.
         Sample:
        
       
        {'avg': 2, 'max': 8, 'min': 1, 'stddev': 24}
         | 
     
Authors
- Nilashish Chakraborty (@NilashishC)
 
© 2012–2018 Michael DeHaan
© 2018–2021 Red Hat, Inc.
Licensed under the GNU General Public License version 3.
 https://docs.ansible.com/ansible/latest/collections/junipernetworks/junos/junos_ping_module.html