netbox-docker/README.md

127 lines
4.5 KiB
Markdown
Raw Normal View History

# netbox-docker
2019-02-07 02:49:11 -06:00
[The Github repository](netbox-docker-github) houses the components needed to build Netbox as a Docker container.
2019-07-30 06:45:08 -05:00
Images are built using this code and are released to [Docker Hub][netbox-dockerhub] once a day.
2019-07-30 06:45:08 -05:00
Do you have any questions? Before opening an issue on Github, please join the [Network To Code][ntc-slack] Slack and ask for help in our `#netbox-docker` channel.
2018-09-27 02:44:14 -05:00
2019-02-06 04:24:01 -06:00
[netbox-dockerhub]: https://hub.docker.com/r/netboxcommunity/netbox/tags/
2019-02-07 02:49:11 -06:00
[netbox-docker-github]: https://github.com/netbox-community/netbox-docker/
2018-09-27 02:44:14 -05:00
[ntc-slack]: http://slack.networktocode.com/
## Quickstart
2019-02-06 04:24:01 -06:00
To get Netbox up and running:
```bash
git clone -b master https://github.com/netbox-community/netbox-docker.git
cd netbox-docker
docker-compose pull
docker-compose up -d
```
The application will be available after a few minutes.
2017-12-26 16:03:02 -06:00
Use `docker-compose port nginx 8080` to find out where to connect to.
```bash
2017-12-26 16:03:02 -06:00
$ echo "http://$(docker-compose port nginx 8080)/"
http://0.0.0.0:32768/
# Open netbox in your default browser on macOS:
2017-12-26 16:03:02 -06:00
$ open "http://$(docker-compose port nginx 8080)/"
# Open netbox in your default browser on (most) linuxes:
2017-12-26 16:03:02 -06:00
$ xdg-open "http://$(docker-compose port nginx 8080)/" &>/dev/null &
```
2018-03-08 02:52:35 -06:00
Alternatively, use something like [Reception][docker-reception] to connect to _docker-compose_ projects.
Default credentials:
* Username: **admin**
* Password: **admin**
* API Token: **0123456789abcdef0123456789abcdef01234567**
2019-02-06 04:24:01 -06:00
[docker-reception]: https://github.com/nxt-engineering/reception
2017-10-16 06:09:17 -05:00
## Dependencies
2017-10-16 06:13:12 -05:00
This project relies only on *Docker* and *docker-compose* meeting this requirements:
2017-10-16 06:09:17 -05:00
* The *Docker version* must be at least `1.13.0`.
* The *docker-compose version* must be at least `1.10.0`.
To ensure this, compare the output of `docker --version` and `docker-compose --version` with the requirements above.
## Reference Documentation
Please refer [to the wiki][wiki] for further information on how to use this Netbox Docker image properly.
It covers advanced topics such as using secret files, deployment to Kubernetes as well as NAPALM and LDAP configuration.
[wiki]: https://github.com/netbox-community/netbox-docker/wiki/
2018-04-04 02:50:17 -05:00
## Netbox Version
2017-10-16 06:33:12 -05:00
2019-02-06 04:24:01 -06:00
The `docker-compose.yml` file is prepared to run a specific version of Netbox.
2017-10-16 06:33:12 -05:00
To use this feature, set the environment-variable `VERSION` before launching `docker-compose`, as shown below.
`VERSION` may be set to the name of
2019-02-06 04:24:01 -06:00
[any tag of the `netboxcommunity/netbox` Docker image on Docker Hub][netbox-dockerhub].
2017-10-16 06:33:12 -05:00
```bash
export VERSION=v2.2.6
docker-compose pull netbox
docker-compose up -d
2017-10-16 06:33:12 -05:00
```
2019-02-06 04:24:01 -06:00
You can also build a specific version of the Netbox image. This time, `VERSION` indicates any valid
[Git Reference][git-ref] declared on [the 'netbox-community/netbox' Github repository][netbox-github].
Most commonly you will specify a tag or branch name.
2017-10-16 06:33:12 -05:00
```bash
export VERSION=develop
docker-compose build --no-cache netbox
docker-compose up -d
2017-10-16 06:33:12 -05:00
```
Hint: If you're building a specific version by tag name, the `--no-cache` argument is not strictly necessary.
This can increase the build speed if you're just adjusting the config, for example.
[git-ref]: https://git-scm.com/book/en/v2/Git-Internals-Git-References
[netbox-github]: https://github.com/netbox-community/netbox/releases
2019-05-08 04:43:29 -05:00
## Breaking Changes
From time to time it might become necessary to re-engineer the structure of this setup.
Things like the `docker-compose.yml` file or your Kubernetes or OpenShift configurations have to be adjusted as a consequence.
Since April 2018 each image built from this repo contains a `NETBOX_DOCKER_PROJECT_VERSION` label.
2019-02-06 04:24:01 -06:00
You can check the label of your local image by running `docker inspect netboxcommunity/netbox:v2.3.1 --format "{{json .ContainerConfig.Labels}}"`.
Please read [the release notes][releases] carefully when updating to a new image version.
[releases]: https://github.com/netbox-community/netbox-docker/releases
2019-02-06 04:46:20 -06:00
## Rebuilding & Publishing images
2019-02-06 04:24:01 -06:00
`./build.sh` can be used to rebuild the Docker image. See `./build.sh --help` for more information.
### Publishing Docker Images
2019-02-06 04:46:20 -06:00
New Docker images are built and published every 24h on the [Docker Build Infrastructure][docker-build-infra].
2019-02-06 04:24:01 -06:00
`DOCKER_HUB.md` contains more information about the build infrastructure.
2019-02-06 04:46:20 -06:00
[docker-build-infra]: https://hub.docker.com/r/netboxcommunity/netbox/builds/
## Tests
2019-02-06 04:24:01 -06:00
To run the tests coming with Netbox, use the `docker-compose.yml` file as such:
```bash
docker-compose run netbox ./manage.py test
```
## About
2019-02-06 04:46:20 -06:00
This repository is currently maintained and funded by [nxt][nxt].
[nxt]: https://nxt.engineering/en/