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

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.2.tar.gz (18.7 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.2-py3-none-any.whl (21.1 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: netbox_graylog-1.1.2.tar.gz
  • Upload date:
  • Size: 18.7 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.2.tar.gz
Algorithm Hash digest
SHA256 84d1c2b13082d1fd32b372d2c0063d56847463086da68f5412731be2bcc54f3d
MD5 c1bb04670ef6e63ab2b189b73faf2dd9
BLAKE2b-256 b488e921c9295c7bad4e90698ea1e659bd954e17edda1a00956bd25fd70cf216

See more details on using hashes here.

Provenance

The following attestation bundles were made for netbox_graylog-1.1.2.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.2-py3-none-any.whl.

File metadata

  • Download URL: netbox_graylog-1.1.2-py3-none-any.whl
  • Upload date:
  • Size: 21.1 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.2-py3-none-any.whl
Algorithm Hash digest
SHA256 355463c5b8b488d76cd461b4496128b9f24cec6eacea6b29640fb5fc29630bbc
MD5 be2218d7a9ab888a417f5f04a2ce8d8d
BLAKE2b-256 e8ec439d733d5088158e1295bb3d5556fe97960822baeb70095bca5ad48d9db1

See more details on using hashes here.

Provenance

The following attestation bundles were made for netbox_graylog-1.1.2-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