From sh run | i ^interface|^_ip address parses subnets and pings all host. Populates switch's arp table.
NOTE: This script works best on Linux/MAC. You can also use the Windows Subsystem for Linux. On Windows it returns "Active" even for hosts that don't exist. It still updates ARP table which is the purpose. If I get time, I will add the code need to make it work correcly on Windows.
I use the Ubuntu 18.04 version but I would think any Linux subsystem would work. Microsoft has an FAQ on WSL.
I was tasked with replacing the core and edge switches for a customer. They had added a SCADA network which wasn't well documented and had many HP/Ricoh printers, three SANs, many Ubiquti wireless bridges connecting remote sites and four VWare ESXi hosts.
The edge switches didn't have port descriptions on a lot of the ports and the patch cables going to the servers were zipped tied into several bundles. I wanted to document what device was on each port before replacing the switches so that I could compare afterwards and make sure everything was moved correctly.
Initially I wrote a quick Python script that would convert the ouput of "show mac add inter x/x | i Gi" into an easy to read format showing only ports that had MAC addresses. The script also looks up the MAC using the Wireshark OUI database and includes the manufacture of the NIC. You can grab that script here Convert Interface MAC addresses to manufacturer name.
The problem here is that devices go to sleep and the switch times the mac address out of the table. Since I was doing the upgrade on a holiday, a lot of devices had timed out. I had been thinking about writing a script to parse the SVI interfaces and then ping the hosts to refresh the MAC and arp tables. This finally gave me the motivation to do it.
Usage
From the core switch run
show run | i ^interface|^_ip address
to output the SVIs and their subnets. The output will look like this:
sh run | i ^interface|^_ip address
interface Vlan1
# ip address 10.23.128.129 255.255.255.248 secondary
# ip address 10.23.159.1 255.255.255.248 secondary
# ip address 10.132.0.1 255.255.255.248
ip address 192.168.10.1 255.255.255.240
interface Vlan2
ip address 10.132.2.1 255.255.255.248
interface Vlan4
# ip address 10.132.4.1 255.255.255.248
interface Vlan5
# ip address 10.23.129.1 255.255.255.248 secondary
ip address 10.132.5.1 255.255.255.248
interface Vlan10
ip address 10.132.10.1 255.255.255.248
Save this to a file named vlans.txt
Linux is case sensitve so you must use all lowercase in the file name.
Run the script: `python3 pinger.py'
It will do the following:
Read vlans.txt
Parse the file and drop blank lines and any lines that contain a # or the word interface. This allows you to comment out subnets that you don't want to ping
Print out the number of subnets found
Print out the hosts for each subnet
Ping the hosts
Print out "Active" for hosts that are alive and "no response" for hosts that don't respond.
Here is the output. I didn't have access to the customer's network when I ran this for documentation so all the hosts are "no response". The 192.168.10.0 subnet is my home lab.
python3 pinger.py
Number of Subnets: 3
Pinging hosts in Subnet 10.175.0.0/23
------ Results from the Pings ------
10.175.0.2 active
10.175.0.4 active
10.175.0.3 active
10.175.0.5 active
10.175.0.6 active
...
10.175.1.1 active
10.175.1.10 active
10.175.1.11 active
10.175.1.21 active
10.175.1.30 active
...
10.175.0.1 no response
10.175.0.39 no response
10.175.0.46 no response
10.175.1.0 no response
10.175.1.2 no response
...
Pinging hosts in Subnet 10.175.2.0/23
------ Results from the Pings ------
10.175.2.1 active
10.175.2.2 no response
10.175.2.3 no response
10.175.2.4 no response
...
10.175.3.254 no response
Pinging hosts in Subnet 10.175.4.0/24
------ Results from the Pings ------
10.175.4.1 active
10.175.4.2 no response
...
10.175.4.254 no response
Here is an "asciicinema" recording of the script in action: python3 pinger.py
asciicinema is a cool little terminal recording tool. It can be found on github at asciicinema