netbox-docker

@Tobias Genannt Tobias Genannt authored on 31 Aug 2022
.github Update docker/setup-buildx-action action to v2 3 years ago
build-functions Build ARM64 images 3 years ago
configuration Removed CSRF_TRUSTED_ORIGINS from extra.py 3 years ago
docker Initializers are now a plugin 3 years ago
env Initializers are now a plugin 3 years ago
reports Fixed devices.py.example report 5 years ago
scripts Add support for custom scripts 6 years ago
test-configuration Removed unnecessary logging from tests 3 years ago
.dockerignore inlude docs in container 6 years ago
.ecrc Lint the syntax of changes 5 years ago
.editorconfig Use black as formatter for python files 5 years ago
.flake8 Lint the syntax of changes 5 years ago
.gitignore Add expample logging configuration 4 years ago
.hadolint.yaml Changed the ignored warnings 3 years ago
.markdown-lint.yml Lint the syntax of changes 5 years ago
.yamllint.yaml Build ARM64 images 3 years ago
Dockerfile Initializers are now a plugin 3 years ago
LICENSE add license 7 years ago
README.md Improved README.md 3 years ago
VERSION Preparation for 2.1.0 3 years ago
build-latest.sh Shellcheck errors 4 years ago
build.sh Using Ubuntu 22.04 because Debian has old packages 3 years ago
docker-compose.override.yml.example Don't publish Netbox on random port 4 years ago
docker-compose.test.yml Removed unnecessary logging from tests 3 years ago
docker-compose.yml Initializers are now a plugin 3 years ago
pyproject.toml Lint the syntax of changes 5 years ago
release.sh Fix DEFAULT_REPO in release.sh 5 years ago
renovate.json Disable Renovate's "Dependency Dashboard" 4 years ago
requirements-container.txt Merge pull request #831 from tobiasge/remove-initializers 3 years ago
test.sh Initializers are now a plugin 3 years ago
README.md

netbox-docker

GitHub release (latest by date)
GitHub stars
GitHub closed pull requests
Github release workflow
Docker Pulls
GitHub license

The GitHub repository houses the components needed to build NetBox as a container.
Images are built regularly using the code in that repository and are pushed to Docker Hub, Quay.io and GitHub Container Registry.

Do you have any questions?
Before opening an issue on Github,
please join our Slack and ask for help in the #netbox-docker channel.

Quickstart

To get NetBox Docker up and running run the following commands.
There is a more complete Getting Started guide on our wiki which explains every step.

git clone -b release https://github.com/netbox-community/netbox-docker.git
cd netbox-docker
tee docker-compose.override.yml <<EOF
version: '3.4'
services:
  netbox:
    ports:
      - 8000:8080
EOF
docker-compose pull
docker-compose up

The whole application will be available after a few minutes.
Open the URL http://0.0.0.0:8000/ in a web-browser.
You should see the NetBox homepage.
In the top-right corner you can login.
The default credentials are:

  • Username: admin
  • Password: admin
  • API Token: 0123456

Container Image Tags

New container images are built and published automatically every ~24h.

We recommend to use either the vX.Y.Z-a.b.c tags or the vX.Y-a.b.c tags in production!

  • vX.Y.Z-a.b.c, vX.Y-a.b.c:
    These are release builds containing NetBox version vX.Y.Z.
    They contain the support files of NetBox Docker version a.b.c.
    You must use NetBox Docker version a.b.c to guarantee the compatibility.
    These images are automatically built from the corresponding releases of NetBox.
  • latest-a.b.c:
    These are release builds, containing the latest stable version of NetBox.
    They contain the support files of NetBox Docker version a.b.c.
    You must use NetBox Docker version a.b.c to guarantee the compatibility.
    These images are automatically built from the master branch of NetBox.
  • snapshot-a.b.c:
    These are prerelease builds.
    They contain the support files of NetBox Docker version a.b.c.
    You must use NetBox Docker version a.b.c to guarantee the compatibility.
    These images are automatically built from the develop branch of NetBox.

For each of the above tag, there is an extra tag:

  • vX.Y.Z, vX.Y:
    This is the same version as vX.Y.Z-a.b.c (or vX.Y-a.b.c, respectively).
    It always points to the latest version of NetBox Docker.
  • latest
    This is the same version as latest-a.b.c.
    It always points to the latest version of NetBox Docker.
  • snapshot
    This is the same version as snapshot-a.b.c.
    It always points to the latest version of NetBox Docker.

Documentation

Please refer to our wiki on GitHub for further information on how to use the NetBox Docker image properly.
The wiki covers advanced topics such as using files for secrets, configuring TLS, deployment to Kubernetes, monitoring and configuring NAPALM and LDAP.

Our wiki is a community effort.
Feel free to correct errors, update outdated information or provide additional guides and insights.

Getting Help

Feel free to ask questions in our GitHub Community
or join our Slack and ask in our channel #netbox-docker,
which is free to use and where there are almost always people online that can help you in the Slack channel.

If you need help with using NetBox or developing for it or against it's API
you may find the #netbox channel on the same Slack instance very helpful.

Dependencies

This project relies only on Docker and docker-compose meeting these requirements:

  • The Docker version must be at least 20.10.10.
  • The containerd version must be at least 1.5.6.
  • The docker-compose version must be at least 1.28.0.

To check the version installed on your system run docker --version and docker-compose --version.

Updating

Please read the release notes carefully when updating to a new image version.
Note that the version of the NetBox Docker container image must stay in sync with the code.

If you update for the first time, be sure to follow our How To Update NetBox Docker guide in the wiki.

Rebuilding the Image

./build.sh can be used to rebuild the container image. See ./build.sh --help for more information.

For more details on custom builds consult our wiki.

Tests

We have a test script.
It runs NetBox's own unit tests and ensures that all initializers work:

IMAGE=netboxcommunity/netbox:latest ./test.sh

Support

This repository is currently maintained by the community.
Please consider sponsoring the maintainers of this project.