Skip to main content

A NetBox plugin for pinging and discovering IPs

Project description

NetBox Ping

Python NetBox License PyPI

A NetBox plugin for pinging, discovering, and monitoring IP addresses directly from your NetBox instance.

Other plugins: NetBox Map · Website · Demo

Features

  • Ping individual IPs — one-click ping from any IP address detail page
  • Scan prefixes — ping all existing IPs in a prefix at once
  • Discover new hosts — scan entire subnets to find and add active IPs not yet in NetBox
  • Bulk operations — select multiple prefixes from the list view and scan/discover in bulk
  • Auto-scan scheduling — configure recurring scans and discovery globally or per-prefix
  • Per-prefix schedule overrides — three modes: Follow Global, Custom On, or Custom Off
  • DNS resolution — automatic reverse DNS lookups with configurable DNS servers
  • Ping Status columns — sortable status columns injected into the core IP Address and Prefix tables
  • Status panels — ping results shown on IP Address and Prefix detail pages
  • Background jobs — all scan/discover operations run as NetBox background jobs
  • Dark mode compatible

Requirements

  • NetBox 4.5.0 or later
  • Python 3.12 or later
  • ping command available on the NetBox server
  • NetBox background worker running (netbox-rq)

Installation

From PyPI

source /opt/netbox/venv/bin/activate
pip install netbox-ping

From source

source /opt/netbox/venv/bin/activate
pip install git+https://github.com/DenDanskeMine/netbox-ping.git

Enable the plugin

Add netbox_ping to your NetBox configuration.py:

PLUGINS = [
    'netbox_ping',
]

Apply migrations

cd /opt/netbox/netbox
python3 manage.py migrate

Restart services

sudo systemctl restart netbox netbox-rq

INFO

If you are upgrading from V1 and getting migration errors, please run the following:

sudo -u postgres psql netbox -c "DELETE FROM django_migrations WHERE app = 'netbox_ping';"
sudo /opt/netbox/venv/bin/python manage.py migrate netbox_ping

Usage

New settings Page

image

Ping a single IP

Navigate to any IP address in NetBox. Click the Ping Now button to ping it immediately. Results appear in the side panel showing reachability, response time, DNS name, and last seen time.

image

Scan a prefix

Navigate to a prefix and click the Ping Subnet button to ping all existing IPs in that prefix. Or click Discover IPs to scan the entire subnet range and automatically create new IP addresses for any responding hosts.

image

Bulk operations

From the prefix list view, select one or more prefixes using the checkboxes, then click Ping Selected or Discover Selected to scan them all.

image

Custom Status badge

image image

View results

  • Plugins > Ping > Ping Results — table of all individual IP ping results
  • Plugins > Ping > Scan Results — table of all prefix scan summaries
  • Ping Status column — enable the "Ping Status" column in the IP Address or Prefix table column configuration

Auto-scan scheduling

  1. Go to Plugins > Ping > Settings
  2. Enable Auto-Scan and/or Auto-Discover and choose an interval
  3. Set the Minimum Prefix Length to control which prefixes are scanned (default: /24)
  4. The system job runs every minute and dispatches scans for prefixes that are due

Per-prefix schedule overrides

From a prefix's Ping Status tab, you can override the global schedule:

Mode Behavior
Follow Global Uses whatever the global setting is (default)
Custom On Always scans at a custom interval, regardless of global setting
Custom Off Never auto-scans, even if global is enabled

Configuration

DNS settings

Configure up to three DNS servers for reverse lookups in Plugins > Ping > Settings. DNS lookups are performed on reachable IPs to resolve their hostname.

Auto-scan intervals

Available intervals: 5 minutes, 15 minutes, 30 minutes, hourly, every 6 hours, every 12 hours, daily, weekly.

Performance Tuning

Concurrent pings per job

Each scan job pings multiple hosts in parallel. The thread count is configurable in Plugins > Ping > Settings under Concurrent Pings (default: 100).

To go above ~240, you need to raise the file descriptor limit for the netbox-rq service. Add LimitNOFILE=65535 to /etc/systemd/system/netbox-rq.service:

[Service]
LimitNOFILE=65535

Then reload, restart, and increase the setting in the UI:

sudo systemctl daemon-reload
sudo systemctl restart netbox-rq

RQ worker count

By default NetBox runs a single background worker. To process multiple scan jobs in parallel, increase the worker count in /etc/systemd/system/netbox-rq.service:

ExecStart=/opt/netbox/venv/bin/python3 /opt/netbox/netbox/manage.py rqworker high default low --worker-count 3

Then reload and restart:

sudo systemctl daemon-reload
sudo systemctl restart netbox-rq

Development

git clone https://github.com/DenDanskeMine/netbox-ping.git
cd netbox-ping
pip install -e .

License

This project is licensed under the Apache License 2.0 — see the LICENSE file for details.

Support

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

netbox_ping-2.1.0.tar.gz (28.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

netbox_ping-2.1.0-py3-none-any.whl (38.2 kB view details)

Uploaded Python 3

File details

Details for the file netbox_ping-2.1.0.tar.gz.

File metadata

  • Download URL: netbox_ping-2.1.0.tar.gz
  • Upload date:
  • Size: 28.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.12

File hashes

Hashes for netbox_ping-2.1.0.tar.gz
Algorithm Hash digest
SHA256 e41ff6da51e76390ac45ef11bb3b5ee8d8fb2c5aa0a13a51f72850db66806afc
MD5 40bf8b86268fc23f7e206f614e3cc85e
BLAKE2b-256 90d4b867ae87e49b5bbe064af9e00a989ad39d5cdd44bbb9cb81cceca40c3f4a

See more details on using hashes here.

File details

Details for the file netbox_ping-2.1.0-py3-none-any.whl.

File metadata

  • Download URL: netbox_ping-2.1.0-py3-none-any.whl
  • Upload date:
  • Size: 38.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.12

File hashes

Hashes for netbox_ping-2.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 f4c5b76cb1bc96f8b14b2178cb7efa9131b1e0e589a26e4a358ecacd3531ce24
MD5 11d60e234b7fe0c92343eb1d929006dc
BLAKE2b-256 3449afb69269ea6b276ffbbd439909b73eef48bb6ca1aac479a0b771930648e6

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page