mirror of
https://github.com/netbox-community/netbox-docker.git
synced 2025-04-04 04:20:53 +02:00
commit
0b70f722f9
@ -5,6 +5,9 @@ docker-compose*
|
|||||||
env
|
env
|
||||||
test-configuration
|
test-configuration
|
||||||
.netbox/.git*
|
.netbox/.git*
|
||||||
|
.netbox/.pre-commit-config.yaml
|
||||||
|
.netbox/.readthedocs.yaml
|
||||||
|
.netbox/.tx
|
||||||
.netbox/contrib
|
.netbox/contrib
|
||||||
.netbox/scripts
|
.netbox/scripts
|
||||||
.netbox/upgrade.sh
|
.netbox/upgrade.sh
|
||||||
|
3
.github/ISSUE_TEMPLATE/bug_report.yml
vendored
3
.github/ISSUE_TEMPLATE/bug_report.yml
vendored
@ -48,7 +48,7 @@ body:
|
|||||||
id: docker-compose-version
|
id: docker-compose-version
|
||||||
attributes:
|
attributes:
|
||||||
label: Docker Compose Version
|
label: Docker Compose Version
|
||||||
description: Please paste the output of `docker-compose version`
|
description: Please paste the output of `docker-compose version` (or `docker compose version`)
|
||||||
placeholder: Docker Compose version vX.Y.Z
|
placeholder: Docker Compose version vX.Y.Z
|
||||||
validations:
|
validations:
|
||||||
required: true
|
required: true
|
||||||
@ -139,7 +139,6 @@ body:
|
|||||||
description: Please paste the output of `cat docker-compose.override.yml`
|
description: Please paste the output of `cat docker-compose.override.yml`
|
||||||
render: yaml
|
render: yaml
|
||||||
placeholder: |
|
placeholder: |
|
||||||
version: '3.4'
|
|
||||||
services:
|
services:
|
||||||
netbox:
|
netbox:
|
||||||
ports:
|
ports:
|
||||||
|
24
.github/workflows/push.yml
vendored
24
.github/workflows/push.yml
vendored
@ -16,19 +16,20 @@ concurrency:
|
|||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
lint:
|
lint:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-24.04
|
||||||
name: Checks syntax of our code
|
name: Checks syntax of our code
|
||||||
|
permissions:
|
||||||
|
contents: read
|
||||||
|
packages: read
|
||||||
|
statuses: write
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v4
|
- uses: actions/checkout@v4
|
||||||
with:
|
with:
|
||||||
# Full git history is needed to get a proper
|
# Full git history is needed to get a proper
|
||||||
# list of changed files within `super-linter`
|
# list of changed files within `super-linter`
|
||||||
fetch-depth: 0
|
fetch-depth: 0
|
||||||
- uses: actions/setup-python@v5
|
|
||||||
with:
|
|
||||||
python-version: "3.9"
|
|
||||||
- name: Lint Code Base
|
- name: Lint Code Base
|
||||||
uses: github/super-linter@v7
|
uses: super-linter/super-linter@v7
|
||||||
env:
|
env:
|
||||||
DEFAULT_BRANCH: develop
|
DEFAULT_BRANCH: develop
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||||
@ -57,8 +58,8 @@ jobs:
|
|||||||
- ./build.sh feature
|
- ./build.sh feature
|
||||||
- ./build.sh main
|
- ./build.sh main
|
||||||
os:
|
os:
|
||||||
- ubuntu-latest
|
- ubuntu-24.04
|
||||||
- self-hosted
|
- ubuntu-24.04-arm
|
||||||
fail-fast: false
|
fail-fast: false
|
||||||
env:
|
env:
|
||||||
GH_ACTION: enable
|
GH_ACTION: enable
|
||||||
@ -73,9 +74,14 @@ jobs:
|
|||||||
- id: buildx-setup
|
- id: buildx-setup
|
||||||
name: Set up Docker Buildx
|
name: Set up Docker Buildx
|
||||||
uses: docker/setup-buildx-action@v3
|
uses: docker/setup-buildx-action@v3
|
||||||
|
- id: arm-install-skopeo
|
||||||
|
name: Install 'skopeo' on ARM64
|
||||||
|
if: matrix.os == 'ubuntu-24.04-arm'
|
||||||
|
run: |
|
||||||
|
sudo apt-get install -y skopeo
|
||||||
- id: arm-buildx-platform
|
- id: arm-buildx-platform
|
||||||
name: Set BUILDX_PLATFORM to ARM64
|
name: Set BUILDX_PLATFORM to ARM64
|
||||||
if: matrix.os == 'self-hosted'
|
if: matrix.os == 'ubuntu-24.04-arm'
|
||||||
run: |
|
run: |
|
||||||
echo "BUILDX_PLATFORM=linux/arm64" >>"${GITHUB_ENV}"
|
echo "BUILDX_PLATFORM=linux/arm64" >>"${GITHUB_ENV}"
|
||||||
- id: docker-build
|
- id: docker-build
|
||||||
@ -85,7 +91,7 @@ jobs:
|
|||||||
BUILDX_BUILDER_NAME: ${{ steps.buildx-setup.outputs.name }}
|
BUILDX_BUILDER_NAME: ${{ steps.buildx-setup.outputs.name }}
|
||||||
- id: arm-time-limit
|
- id: arm-time-limit
|
||||||
name: Set Netbox container start_period higher on ARM64
|
name: Set Netbox container start_period higher on ARM64
|
||||||
if: matrix.os == 'self-hosted'
|
if: matrix.os == 'ubuntu-24.04-arm'
|
||||||
run: |
|
run: |
|
||||||
echo "NETBOX_START_PERIOD=240s" >>"${GITHUB_ENV}"
|
echo "NETBOX_START_PERIOD=240s" >>"${GITHUB_ENV}"
|
||||||
- id: docker-test
|
- id: docker-test
|
||||||
|
2
.github/workflows/release.yml
vendored
2
.github/workflows/release.yml
vendored
@ -21,7 +21,7 @@ jobs:
|
|||||||
platform:
|
platform:
|
||||||
- linux/amd64,linux/arm64
|
- linux/amd64,linux/arm64
|
||||||
fail-fast: false
|
fail-fast: false
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-24.04
|
||||||
name: Builds new NetBox Docker Images
|
name: Builds new NetBox Docker Images
|
||||||
env:
|
env:
|
||||||
GH_ACTION: enable
|
GH_ACTION: enable
|
||||||
|
24
Dockerfile
24
Dockerfile
@ -1,6 +1,7 @@
|
|||||||
ARG FROM
|
ARG FROM
|
||||||
FROM ${FROM} AS builder
|
FROM ${FROM} AS builder
|
||||||
|
|
||||||
|
COPY --from=ghcr.io/astral-sh/uv:0.5 /uv /usr/local/bin/
|
||||||
RUN export DEBIAN_FRONTEND=noninteractive \
|
RUN export DEBIAN_FRONTEND=noninteractive \
|
||||||
&& apt-get update -qq \
|
&& apt-get update -qq \
|
||||||
&& apt-get upgrade \
|
&& apt-get upgrade \
|
||||||
@ -20,16 +21,11 @@ RUN export DEBIAN_FRONTEND=noninteractive \
|
|||||||
libxslt-dev \
|
libxslt-dev \
|
||||||
pkg-config \
|
pkg-config \
|
||||||
python3-dev \
|
python3-dev \
|
||||||
python3-pip \
|
&& /usr/local/bin/uv venv /opt/netbox/venv
|
||||||
python3-venv \
|
|
||||||
&& python3 -m venv /opt/netbox/venv \
|
|
||||||
&& /opt/netbox/venv/bin/python3 -m pip install --upgrade \
|
|
||||||
pip \
|
|
||||||
setuptools \
|
|
||||||
wheel
|
|
||||||
|
|
||||||
ARG NETBOX_PATH
|
ARG NETBOX_PATH
|
||||||
COPY ${NETBOX_PATH}/requirements.txt requirements-container.txt /
|
COPY ${NETBOX_PATH}/requirements.txt requirements-container.txt /
|
||||||
|
ENV VIRTUAL_ENV=/opt/netbox/venv
|
||||||
RUN \
|
RUN \
|
||||||
# Gunicorn is not needed because we use Nginx Unit
|
# Gunicorn is not needed because we use Nginx Unit
|
||||||
sed -i -e '/gunicorn/d' /requirements.txt && \
|
sed -i -e '/gunicorn/d' /requirements.txt && \
|
||||||
@ -37,7 +33,7 @@ RUN \
|
|||||||
# we have potential version conflicts and the build will fail.
|
# we have potential version conflicts and the build will fail.
|
||||||
# That's why we just replace it in the original requirements.txt.
|
# That's why we just replace it in the original requirements.txt.
|
||||||
sed -i -e 's/social-auth-core/social-auth-core\[all\]/g' /requirements.txt && \
|
sed -i -e 's/social-auth-core/social-auth-core\[all\]/g' /requirements.txt && \
|
||||||
/opt/netbox/venv/bin/pip install \
|
/usr/local/bin/uv pip install \
|
||||||
-r /requirements.txt \
|
-r /requirements.txt \
|
||||||
-r /requirements-container.txt
|
-r /requirements-container.txt
|
||||||
|
|
||||||
@ -75,12 +71,13 @@ RUN export DEBIAN_FRONTEND=noninteractive \
|
|||||||
unit-python3.12=1.34.1-1~noble \
|
unit-python3.12=1.34.1-1~noble \
|
||||||
&& rm -rf /var/lib/apt/lists/*
|
&& rm -rf /var/lib/apt/lists/*
|
||||||
|
|
||||||
|
# Copy the modified 'requirements*.txt' files, to have the files actually used during installation
|
||||||
|
COPY --from=builder /requirements.txt /requirements-container.txt /opt/netbox/
|
||||||
|
COPY --from=builder /usr/local/bin/uv /usr/local/bin/
|
||||||
COPY --from=builder /opt/netbox/venv /opt/netbox/venv
|
COPY --from=builder /opt/netbox/venv /opt/netbox/venv
|
||||||
|
|
||||||
ARG NETBOX_PATH
|
ARG NETBOX_PATH
|
||||||
COPY ${NETBOX_PATH} /opt/netbox
|
COPY ${NETBOX_PATH} /opt/netbox
|
||||||
# Copy the modified 'requirements*.txt' files, to have the files actually used during installation
|
|
||||||
COPY --from=builder /requirements.txt /requirements-container.txt /opt/netbox/
|
|
||||||
|
|
||||||
COPY docker/configuration.docker.py /opt/netbox/netbox/netbox/configuration.py
|
COPY docker/configuration.docker.py /opt/netbox/netbox/netbox/configuration.py
|
||||||
COPY docker/ldap_config.docker.py /opt/netbox/netbox/netbox/ldap_config.py
|
COPY docker/ldap_config.docker.py /opt/netbox/netbox/netbox/ldap_config.py
|
||||||
@ -89,6 +86,7 @@ COPY docker/housekeeping.sh /opt/netbox/housekeeping.sh
|
|||||||
COPY docker/launch-netbox.sh /opt/netbox/launch-netbox.sh
|
COPY docker/launch-netbox.sh /opt/netbox/launch-netbox.sh
|
||||||
COPY configuration/ /etc/netbox/config/
|
COPY configuration/ /etc/netbox/config/
|
||||||
COPY docker/nginx-unit.json /etc/unit/
|
COPY docker/nginx-unit.json /etc/unit/
|
||||||
|
COPY VERSION /opt/netbox/VERSION
|
||||||
|
|
||||||
WORKDIR /opt/netbox/netbox
|
WORKDIR /opt/netbox/netbox
|
||||||
|
|
||||||
@ -99,9 +97,11 @@ RUN mkdir -p static /opt/unit/state/ /opt/unit/tmp/ \
|
|||||||
&& chmod -R g+w /opt/unit/ media reports scripts \
|
&& chmod -R g+w /opt/unit/ media reports scripts \
|
||||||
&& cd /opt/netbox/ && SECRET_KEY="dummyKeyWithMinimumLength-------------------------" /opt/netbox/venv/bin/python -m mkdocs build \
|
&& cd /opt/netbox/ && SECRET_KEY="dummyKeyWithMinimumLength-------------------------" /opt/netbox/venv/bin/python -m mkdocs build \
|
||||||
--config-file /opt/netbox/mkdocs.yml --site-dir /opt/netbox/netbox/project-static/docs/ \
|
--config-file /opt/netbox/mkdocs.yml --site-dir /opt/netbox/netbox/project-static/docs/ \
|
||||||
&& SECRET_KEY="dummyKeyWithMinimumLength-------------------------" /opt/netbox/venv/bin/python /opt/netbox/netbox/manage.py collectstatic --no-input
|
&& DEBUG="true" SECRET_KEY="dummyKeyWithMinimumLength-------------------------" /opt/netbox/venv/bin/python /opt/netbox/netbox/manage.py collectstatic --no-input \
|
||||||
|
&& mkdir /opt/netbox/netbox/local \
|
||||||
|
&& echo "build: Docker-$(cat /opt/netbox/VERSION)" > /opt/netbox/netbox/local/release.yaml
|
||||||
|
|
||||||
ENV LANG=C.utf8 PATH=/opt/netbox/venv/bin:$PATH
|
ENV LANG=C.utf8 PATH=/opt/netbox/venv/bin:$PATH VIRTUAL_ENV=/opt/netbox/venv UV_NO_CACHE=1
|
||||||
ENTRYPOINT [ "/usr/bin/tini", "--" ]
|
ENTRYPOINT [ "/usr/bin/tini", "--" ]
|
||||||
|
|
||||||
CMD [ "/opt/netbox/docker-entrypoint.sh", "/opt/netbox/launch-netbox.sh" ]
|
CMD [ "/opt/netbox/docker-entrypoint.sh", "/opt/netbox/launch-netbox.sh" ]
|
||||||
|
19
MAINTAINERS.md
Normal file
19
MAINTAINERS.md
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
# Maintainers of _NetBox Docker_
|
||||||
|
|
||||||
|
This file lists all currently recognized maintainers of the _NetBox Docker_ project in alphabetical order:
|
||||||
|
|
||||||
|
- @cimnine
|
||||||
|
- @tobiasge
|
||||||
|
|
||||||
|
## Stepping Down
|
||||||
|
|
||||||
|
Every maintainer is a volunteer and may step down as maintainer at any time without providing any reason.
|
||||||
|
To make this explicit, the maintainer is asked to update this file.
|
||||||
|
|
||||||
|
The last maintainer stepping down is asked to archive the project on GitHub to indicate that the project is no longer maintained.
|
||||||
|
|
||||||
|
## Signing up
|
||||||
|
|
||||||
|
Everyone is welcome to sign up as maintainer by creating a PR and add their own username to the list.
|
||||||
|
The current maintainers shall discuss the application.
|
||||||
|
They may turn down an application if they don't feel confident that the new maintainer is a positive addition.
|
71
PRINCIPALS.md
Normal file
71
PRINCIPALS.md
Normal file
@ -0,0 +1,71 @@
|
|||||||
|
# Development, Maintenance and Community Principals for _NetBox Docker_
|
||||||
|
|
||||||
|
These principals shall guide the development and the maintenance of _NetBox Docker_.
|
||||||
|
|
||||||
|
## Basic principals
|
||||||
|
|
||||||
|
This project is maintained on voluntary basis.
|
||||||
|
Everyone is asked to respect that.
|
||||||
|
|
||||||
|
This means, that …
|
||||||
|
|
||||||
|
- … sometimes features are not implemented as fast as one might like -- or not at all.
|
||||||
|
- … sometimes nobody is looking at bugs, or they are not fixed as fast as one might like -- or not at all.
|
||||||
|
- … sometimes PRs are not reviewed for an extended period.
|
||||||
|
|
||||||
|
Everyone is welcome to provide improvements and bugfixes to the benefit of everyone else.
|
||||||
|
|
||||||
|
## Development Principals
|
||||||
|
|
||||||
|
The goal of the _NetBox Docker_ project is to provide a container to run the basic NetBox project.
|
||||||
|
The container should feel like a native container -- as if it were provided by NetBox itself:
|
||||||
|
|
||||||
|
- Configuration via environment variables where feasible.
|
||||||
|
- Except: Whenever a complex type such as a `dict` is required as value of a configuration setting,
|
||||||
|
then it shall not be provided through an environment variable.
|
||||||
|
- Configuration of secrets via secret files.
|
||||||
|
- Log output to standard out (STDOUT/`&1`) / standard error (STDERR/`&2`).
|
||||||
|
- Volumes for data and cache directories.
|
||||||
|
- Otherwise, no mounts shall be necessary.
|
||||||
|
- Runs a non-root user by default.
|
||||||
|
- One process / role for each instance.
|
||||||
|
|
||||||
|
The container generally does not provide more features than the basic NetBox project itself provides.
|
||||||
|
It may provide additional Python dependencies than the upstream project,
|
||||||
|
so that all configurable features of NetBox can be used in the container without further modification.
|
||||||
|
The container may provide helpers, so that it feels and behaves like a native container.
|
||||||
|
|
||||||
|
The container does not bundle any community plugins.
|
||||||
|
|
||||||
|
## Maintenance Principals
|
||||||
|
|
||||||
|
The main goals of maintaining _NetBox Docker_ are:
|
||||||
|
|
||||||
|
- Keeping the project at a high quality level.
|
||||||
|
- Keeping the maintenance effort minimal.
|
||||||
|
- Coordinating development efforts.
|
||||||
|
|
||||||
|
The following guidelines help us to achieve these goals:
|
||||||
|
|
||||||
|
- As many maintenance tasks as possible shall be automated or scripted.
|
||||||
|
- All manual tasks must be documented.
|
||||||
|
- All changes are reviewed by at least one maintainer.
|
||||||
|
- Changes of maintainers are reviewed by at least one other maintainer.
|
||||||
|
(Except if there's only one maintainer left.)
|
||||||
|
- The infrastructure beyond what GitHub provides shall be kept to a minimum.
|
||||||
|
- On request, every maintainer shall get access to infrastructure that is beyond GitHub
|
||||||
|
(at the time of writing that's _Docker Hub_ and _Quay_ in particular).
|
||||||
|
|
||||||
|
## Community Principals
|
||||||
|
|
||||||
|
This project is developed by the NetBox community for the NetBox community.
|
||||||
|
We welcome contributions, as long as they are in line with the principals above.
|
||||||
|
|
||||||
|
The maintainers of NetBox Docker are not the support team.
|
||||||
|
The community is expected to help each other out.
|
||||||
|
|
||||||
|
Always remember:
|
||||||
|
Behind every screen (or screen-reader) on the other end is a fellow human.
|
||||||
|
Be nice and respectful, thankful for help,
|
||||||
|
and value ideas and contributions,
|
||||||
|
even when they don't fit the goals.
|
53
README.md
53
README.md
@ -8,11 +8,16 @@
|
|||||||
[][netbox-docker-license]
|
[][netbox-docker-license]
|
||||||
|
|
||||||
[The GitHub repository][netbox-docker-github] houses the components needed to build NetBox as a container.
|
[The GitHub repository][netbox-docker-github] 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][netbox-dockerhub], [Quay.io][netbox-quayio] and [GitHub Container Registry][netbox-ghcr].
|
Images are built regularly using the code in that repository
|
||||||
|
and are pushed to [Docker Hub][netbox-dockerhub],
|
||||||
|
[Quay.io][netbox-quayio] and [GitHub Container Registry][netbox-ghcr].
|
||||||
|
_NetBox Docker_ is a project developed and maintained by the _NetBox_ community.
|
||||||
|
|
||||||
Do you have any questions?
|
Do you have any questions?
|
||||||
Before opening an issue on Github,
|
Before opening an issue on GitHub,
|
||||||
please join [our Slack][netbox-docker-slack] and ask for help in the [`#netbox-docker`][netbox-docker-slack-channel] channel.
|
please join [our Slack][netbox-docker-slack]
|
||||||
|
and ask for help in the [`#netbox-docker`][netbox-docker-slack-channel] channel,
|
||||||
|
or start a new [GitHub Discussion][github-discussions].
|
||||||
|
|
||||||
[github-stargazers]: https://github.com/netbox-community/netbox-docker/stargazers
|
[github-stargazers]: https://github.com/netbox-community/netbox-docker/stargazers
|
||||||
[github-release]: https://github.com/netbox-community/netbox-docker/releases
|
[github-release]: https://github.com/netbox-community/netbox-docker/releases
|
||||||
@ -24,6 +29,7 @@ please join [our Slack][netbox-docker-slack] and ask for help in the [`#netbox-d
|
|||||||
[netbox-docker-slack-channel]: https://netdev-community.slack.com/archives/C01P0GEVBU7
|
[netbox-docker-slack-channel]: https://netdev-community.slack.com/archives/C01P0GEVBU7
|
||||||
[netbox-slack-channel]: https://netdev-community.slack.com/archives/C01P0FRSXRV
|
[netbox-slack-channel]: https://netdev-community.slack.com/archives/C01P0FRSXRV
|
||||||
[netbox-docker-license]: https://github.com/netbox-community/netbox-docker/blob/release/LICENSE
|
[netbox-docker-license]: https://github.com/netbox-community/netbox-docker/blob/release/LICENSE
|
||||||
|
[github-discussions]: https://github.com/netbox-community/netbox-docker/discussions
|
||||||
|
|
||||||
## Quickstart
|
## Quickstart
|
||||||
|
|
||||||
@ -53,7 +59,8 @@ To create the first admin user run this command:
|
|||||||
docker compose exec netbox /opt/netbox/netbox/manage.py createsuperuser
|
docker compose exec netbox /opt/netbox/netbox/manage.py createsuperuser
|
||||||
```
|
```
|
||||||
|
|
||||||
If you need to restart Netbox from an empty database often, you can also set the `SUPERUSER_*` variables in your `docker-compose.override.yml` as shown in the example.
|
If you need to restart Netbox from an empty database often,
|
||||||
|
you can also set the `SUPERUSER_*` variables in your `docker-compose.override.yml`.
|
||||||
|
|
||||||
[wiki-getting-started]: https://github.com/netbox-community/netbox-docker/wiki/Getting-Started
|
[wiki-getting-started]: https://github.com/netbox-community/netbox-docker/wiki/Getting-Started
|
||||||
|
|
||||||
@ -63,37 +70,34 @@ 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!
|
> 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`:
|
- `vX.Y.Z-a.b.c`, `vX.Y-a.b.c`:
|
||||||
These are release builds containing _NetBox version_ `vX.Y.Z`.
|
These are release builds containing _NetBox version_ `vX.Y.Z`.
|
||||||
They contain the support files of _NetBox Docker version_ `a.b.c`.
|
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.
|
You must use _NetBox Docker version_ `a.b.c` to guarantee the compatibility.
|
||||||
These images are automatically built from [the corresponding releases of NetBox][netbox-releases].
|
These images are automatically built from [the corresponding releases of NetBox][netbox-releases].
|
||||||
* `latest-a.b.c`:
|
- `latest-a.b.c`:
|
||||||
These are release builds, containing the latest stable version of NetBox.
|
These are release builds, containing the latest stable version of NetBox.
|
||||||
They contain the support files of _NetBox Docker version_ `a.b.c`.
|
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.
|
You must use _NetBox Docker version_ `a.b.c` to guarantee the compatibility.
|
||||||
These images are automatically built from [the `master` branch of NetBox][netbox-master].
|
- `snapshot-a.b.c`:
|
||||||
* `snapshot-a.b.c`:
|
|
||||||
These are prerelease builds.
|
These are prerelease builds.
|
||||||
They contain the support files of _NetBox Docker version_ `a.b.c`.
|
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.
|
You must use _NetBox Docker version_ `a.b.c` to guarantee the compatibility.
|
||||||
These images are automatically built from the [`develop` branch of NetBox][netbox-develop].
|
These images are automatically built from the [`main` branch of NetBox][netbox-main].
|
||||||
|
|
||||||
For each of the above tag, there is an extra tag:
|
For each of the above tag, there is an extra tag:
|
||||||
|
|
||||||
* `vX.Y.Z`, `vX.Y`:
|
- `vX.Y.Z`, `vX.Y`:
|
||||||
This is the same version as `vX.Y.Z-a.b.c` (or `vX.Y-a.b.c`, respectively).
|
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`
|
||||||
* `latest`
|
|
||||||
This is the same version as `latest-a.b.c`.
|
This is the same version as `latest-a.b.c`.
|
||||||
It always points to the latest version of _NetBox Docker_.
|
It always points to the latest version of _NetBox Docker_.
|
||||||
* `snapshot`
|
- `snapshot`
|
||||||
This is the same version as `snapshot-a.b.c`.
|
This is the same version as `snapshot-a.b.c`.
|
||||||
It always points to the latest version of _NetBox Docker_.
|
It always points to the latest version of _NetBox Docker_.
|
||||||
|
|
||||||
[netbox-releases]: https://github.com/netbox-community/netbox/releases
|
[netbox-releases]: https://github.com/netbox-community/netbox/releases
|
||||||
[netbox-master]: https://github.com/netbox-community/netbox/tree/master
|
[netbox-main]: https://github.com/netbox-community/netbox/tree/main
|
||||||
[netbox-develop]: https://github.com/netbox-community/netbox/tree/develop
|
|
||||||
|
|
||||||
## Documentation
|
## Documentation
|
||||||
|
|
||||||
@ -109,7 +113,7 @@ Feel free to correct errors, update outdated information or provide additional g
|
|||||||
|
|
||||||
Feel free to ask questions in our [GitHub Community][netbox-community]
|
Feel free to ask questions in our [GitHub Community][netbox-community]
|
||||||
or [join our Slack][netbox-docker-slack] and ask [in our channel `#netbox-docker`][netbox-docker-slack-channel],
|
or [join our Slack][netbox-docker-slack] and ask [in our channel `#netbox-docker`][netbox-docker-slack-channel],
|
||||||
which is free to use and where there are almost always people online that can help you in the Slack channel.
|
which is free to use and where there are almost always people online that can help you.
|
||||||
|
|
||||||
If you need help with using NetBox or developing for it or against it's API
|
If you need help with using NetBox or developing for it or against it's API
|
||||||
you may find [the `#netbox` channel][netbox-slack-channel] on the same Slack instance very helpful.
|
you may find [the `#netbox` channel][netbox-slack-channel] on the same Slack instance very helpful.
|
||||||
@ -120,16 +124,16 @@ you may find [the `#netbox` channel][netbox-slack-channel] on the same Slack ins
|
|||||||
|
|
||||||
This project relies only on _Docker_ and _docker-compose_ meeting these requirements:
|
This project relies only on _Docker_ and _docker-compose_ meeting these requirements:
|
||||||
|
|
||||||
* The _Docker version_ must be at least `20.10.10`.
|
- The _Docker version_ must be at least `20.10.10`.
|
||||||
* The _containerd version_ must be at least `1.5.6`.
|
- The _containerd version_ must be at least `1.5.6`.
|
||||||
* The _docker-compose version_ must be at least `1.28.0`.
|
- 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`.
|
To check the version installed on your system run `docker --version` and `docker compose version`.
|
||||||
|
|
||||||
## Updating
|
## Updating
|
||||||
|
|
||||||
Please read [the release notes][releases] carefully when updating to a new image version.
|
Please read [the release notes][releases] 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.
|
Note that the version of the NetBox Docker container image must stay in sync with the version of the Git repository.
|
||||||
|
|
||||||
If you update for the first time, be sure [to follow our _How To Update NetBox Docker_ guide in the wiki][netbox-docker-wiki-updating].
|
If you update for the first time, be sure [to follow our _How To Update NetBox Docker_ guide in the wiki][netbox-docker-wiki-updating].
|
||||||
|
|
||||||
@ -138,7 +142,8 @@ If you update for the first time, be sure [to follow our _How To Update NetBox D
|
|||||||
|
|
||||||
## Rebuilding the Image
|
## Rebuilding the Image
|
||||||
|
|
||||||
`./build.sh` can be used to rebuild the container image. See `./build.sh --help` for more information.
|
`./build.sh` can be used to rebuild the container image.
|
||||||
|
See `./build.sh --help` for more information or `./build-latest.sh` for an example.
|
||||||
|
|
||||||
For more details on custom builds [consult our wiki][netbox-docker-wiki-build].
|
For more details on custom builds [consult our wiki][netbox-docker-wiki-build].
|
||||||
|
|
||||||
@ -147,13 +152,15 @@ For more details on custom builds [consult our wiki][netbox-docker-wiki-build].
|
|||||||
## Tests
|
## Tests
|
||||||
|
|
||||||
We have a test script.
|
We have a test script.
|
||||||
It runs NetBox's own unit tests and ensures that all initializers work:
|
It runs NetBox's own unit tests and ensures that NetBox starts:
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
IMAGE=netboxcommunity/netbox:latest ./test.sh
|
IMAGE=docker.io/netboxcommunity/netbox:latest ./test.sh
|
||||||
```
|
```
|
||||||
|
|
||||||
## Support
|
## Support
|
||||||
|
|
||||||
This repository is currently maintained by the community.
|
This repository is currently maintained by the community.
|
||||||
|
The community is expected to help each other.
|
||||||
|
|
||||||
Please consider sponsoring the maintainers of this project.
|
Please consider sponsoring the maintainers of this project.
|
||||||
|
5
actionlint.yml
Normal file
5
actionlint.yml
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
---
|
||||||
|
paths:
|
||||||
|
.github/workflows/**/*.{yml,yaml}:
|
||||||
|
ignore:
|
||||||
|
- ".*ubuntu-24.04-arm.*"
|
@ -1,6 +1,6 @@
|
|||||||
services:
|
services:
|
||||||
netbox: &netbox
|
netbox: &netbox
|
||||||
image: docker.io/netboxcommunity/netbox:${VERSION-v4.2-3.1.1}
|
image: docker.io/netboxcommunity/netbox:${VERSION-v4.2-3.2.0}
|
||||||
depends_on:
|
depends_on:
|
||||||
- postgres
|
- postgres
|
||||||
- redis
|
- redis
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"listeners": {
|
"listeners": {
|
||||||
"*:8080": {
|
"0.0.0.0:8080": {
|
||||||
"pass": "routes/main",
|
"pass": "routes/main",
|
||||||
"forwarded": {
|
"forwarded": {
|
||||||
"client_ip": "X-Forwarded-For",
|
"client_ip": "X-Forwarded-For",
|
||||||
@ -8,13 +8,29 @@
|
|||||||
"source": ["10.0.0.0/8", "172.16.0.0/12", "192.168.0.0/16"]
|
"source": ["10.0.0.0/8", "172.16.0.0/12", "192.168.0.0/16"]
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"*:8081": {
|
"0.0.0.0:8081": {
|
||||||
"pass": "routes/status",
|
"pass": "routes/status",
|
||||||
"forwarded": {
|
"forwarded": {
|
||||||
"client_ip": "X-Forwarded-For",
|
"client_ip": "X-Forwarded-For",
|
||||||
"protocol": "X-Forwarded-Proto",
|
"protocol": "X-Forwarded-Proto",
|
||||||
"source": ["10.0.0.0/8", "172.16.0.0/12", "192.168.0.0/16"]
|
"source": ["10.0.0.0/8", "172.16.0.0/12", "192.168.0.0/16"]
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
"[::]:8080": {
|
||||||
|
"pass": "routes/main",
|
||||||
|
"forwarded": {
|
||||||
|
"client_ip": "X-Forwarded-For",
|
||||||
|
"protocol": "X-Forwarded-Proto",
|
||||||
|
"source": ["fc00::/7", "fe80::/10"]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"[::]:8081": {
|
||||||
|
"pass": "routes/status",
|
||||||
|
"forwarded": {
|
||||||
|
"client_ip": "X-Forwarded-For",
|
||||||
|
"protocol": "X-Forwarded-Proto",
|
||||||
|
"source": ["fc00::/7", "fe80::/10"]
|
||||||
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"routes": {
|
"routes": {
|
||||||
|
@ -1,5 +1,7 @@
|
|||||||
django-auth-ldap==5.1.0
|
django-auth-ldap==5.1.0
|
||||||
django-storages[azure,boto3,dropbox,google,libcloud,sftp]==1.14.4
|
django-storages[azure,boto3,dropbox,google,libcloud,sftp]==1.14.4
|
||||||
dulwich==0.22.7
|
dulwich==0.22.7
|
||||||
python3-saml==1.16.0 --no-binary lxml,xmlsec
|
python3-saml==1.16.0
|
||||||
|
--no-binary lxml
|
||||||
|
--no-binary xmlsec
|
||||||
sentry-sdk[django]==2.20.0
|
sentry-sdk[django]==2.20.0
|
||||||
|
Loading…
Reference in New Issue
Block a user