Skip to main content

NetBox plugin to display Graylog logs in device and VM detail pages

Project description

NetBox Graylog Plugin

NetBox Graylog Plugin

A NetBox plugin that displays recent Graylog logs in Device and VirtualMachine detail pages.

NetBox Version Python Version License CI PyPI

Features

  • Logs Tab: Adds a "Logs" tab to Device and VirtualMachine detail pages
  • Time Range Selection: Quick buttons for 5m, 15m, 1h, 4h, 24h, and 7d time ranges
  • Smart Search: Searches by hostname first, falls back to primary IP if no results
  • Caching: Caches API responses to reduce load on Graylog
  • Error Handling: Graceful degradation when Graylog is unavailable

Screenshots

Settings Page

Configure Graylog connection settings directly in the NetBox UI.

Settings Page

Logs Tab

View Graylog logs directly on Device and VirtualMachine pages.

Logs Tab

Dashboard Widget

Graylog summary widget showing total log volume, errors, and warnings.

Dashboard Widget

Requirements

  • NetBox 4.0 or higher (tested on NetBox 4.x only)
  • Graylog 4.0 or higher with API access
  • Python 3.10+

Note: This plugin is developed and tested exclusively on NetBox 4.x. It is not compatible with NetBox 3.x due to API and model changes.

Installation

From PyPI (when published)

pip install netbox-graylog

From Source

git clone https://github.com/sieteunoseis/netbox-graylog.git
cd netbox-graylog
pip install -e .

Docker Installation

Add to your NetBox Docker requirements file:

# requirements-extra.txt
netbox-graylog

Or for development:

# In docker-compose.override.yml, mount the plugin:
volumes:
  - /path/to/netbox-graylog:/opt/netbox/netbox/netbox_graylog

Configuration

Add the plugin to your NetBox configuration:

# configuration.py or plugins.py

PLUGINS = [
    'netbox_graylog',
]

PLUGINS_CONFIG = {
    'netbox_graylog': {
        # Required: Graylog API URL
        'graylog_url': 'http://graylog:9000',

        # Required: Graylog API token
        'graylog_api_token': 'your-api-token-here',

        # Optional settings with defaults:
        'log_limit': 50,           # Max logs to display
        'time_range': 3600,        # Default time range (1 hour)
        'timeout': 10,             # API timeout in seconds
        'cache_timeout': 60,       # Cache duration in seconds
        'search_field': 'source',  # Field to search (source or gl2_remote_ip)
        'use_fqdn': True,          # Use FQDN for hostname matching
        'fallback_to_ip': True,    # Try primary IP if hostname not found
    }
}

Graylog API Token

  1. Log into Graylog as an admin user
  2. Go to SystemUsers and TeamsYour User
  3. Click Edit Tokens
  4. Create a new token with at least these permissions:
    • searches:relative
    • streams:read (if filtering by stream)

Usage

Once installed and configured:

  1. Navigate to any Device or VirtualMachine in NetBox
  2. Click the Logs tab
  3. View recent logs from Graylog
  4. Use the time range buttons to adjust the search window

Search Behavior

The plugin searches for logs using this strategy:

  1. Hostname search: source:{device.name}
  2. IP fallback (if enabled and no results): gl2_remote_ip:{primary_ip}
  3. Source IP fallback: source:{primary_ip}

Troubleshooting

No logs appearing

  • Verify the device name in NetBox matches the source field in Graylog
  • Check if logs are being sent with FQDN or shortname
  • Try disabling use_fqdn if your devices use shortnames
  • Enable fallback_to_ip to search by IP address

Connection errors

  • Verify graylog_url is accessible from NetBox container
  • Check that the API token has correct permissions
  • For Docker, ensure both containers are on the same network

Authentication errors

  • Verify the API token is valid and not expired
  • Check Graylog user has required permissions

Development

Setup

git clone https://github.com/sieteunoseis/netbox-graylog.git
cd netbox-graylog
pip install -e ".[dev]"

Code Style

black netbox_graylog/
flake8 netbox_graylog/

Documentation

Full documentation is available in the GitHub Wiki.

Changelog

See CHANGELOG.md for release history and breaking changes.

License

Apache License 2.0 - See LICENSE for details.

Contributing

Contributions are welcome! Please:

  1. Fork the repository
  2. Create a feature branch
  3. Submit a pull request

Support

If you find this plugin helpful, consider supporting development:

Buy Me A Coffee

Credits

Inspired by the LibreNMS Graylog integration.

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_graylog-1.1.7.tar.gz (22.1 kB view details)

Uploaded Source

Built Distribution

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

netbox_graylog-1.1.7-py3-none-any.whl (26.8 kB view details)

Uploaded Python 3

File details

Details for the file netbox_graylog-1.1.7.tar.gz.

File metadata

  • Download URL: netbox_graylog-1.1.7.tar.gz
  • Upload date:
  • Size: 22.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for netbox_graylog-1.1.7.tar.gz
Algorithm Hash digest
SHA256 844c87ae08b88945d1f1e921f41f73d6f189c22b0a5cbd40bb60f7259c7e2228
MD5 d5327b4840dd4dc92ecb54b4e096b1ae
BLAKE2b-256 f8686b97c7305e6dd306f6776493152fea8007bd83996264b145331095792fd5

See more details on using hashes here.

Provenance

The following attestation bundles were made for netbox_graylog-1.1.7.tar.gz:

Publisher: release.yml on sieteunoseis/netbox-graylog

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file netbox_graylog-1.1.7-py3-none-any.whl.

File metadata

  • Download URL: netbox_graylog-1.1.7-py3-none-any.whl
  • Upload date:
  • Size: 26.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for netbox_graylog-1.1.7-py3-none-any.whl
Algorithm Hash digest
SHA256 3eb427f484618d3f016b7e3b018aca4736c9c42ed0c6b1e4fe73a221229dfd8d
MD5 a1a9f3cd8eabff590ac0beeaf1f5cddc
BLAKE2b-256 84b470f0102c9c6cee8db2f434841580d03a8d95b6686fddb1f61a79bcfdee4b

See more details on using hashes here.

Provenance

The following attestation bundles were made for netbox_graylog-1.1.7-py3-none-any.whl:

Publisher: release.yml on sieteunoseis/netbox-graylog

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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