Upgrading to DefectDojo Version 2.51.x

Performance improvements

This release includes multiple improvements aimed at making DefectDojo faster, more scalable, and lighter on your database and workers.

  • Import and reimport are significantly more efficient: product grading is now orchestrated in batches using Celery chords, reducing the number of background tasks and database churn during large scans. This means faster imports and smoother post-processing on busy systems. See PR 12914.
  • Query-count reductions and importer hot-path tuning: we trimmed unnecessary ORM calls and optimized how findings/endpoints are updated during (re)import. You should see noticeably quicker runs out of the box. See PR 13182 and PR 13152.
  • Smarter background task orchestration for product graing: less duplicate work and better scheduling during heavy operations, keeping the UI responsive while long jobs run. See PR 12900.
  • Bulk tag addition for large batches: adds an internal method to add tags to many findings at once, performing tagging in batches (default 1,000) with only a few queries per batch. This replaces ~3 queries per finding with ~3 queries per batch, significantly reducing DB load during imports, reimports, and bulk edit. On a ~10k-findings sample, import time dropped from ~372s to ~190s. See PR 13285.
  • Preparations for our switch to django-pghistory which provides more features and better performance compared to django-auditlog. See PR 13169.

No configuration changes are requiredβ€”gains are automatic after upgrading.

Helm Chart Changes

This release introduces several important changes to the Helm chart configuration:

Breaking changes

Volume Management Improvements

  • Streamlined volume configuration: The existing volume logic has been removed and replaced with more flexible extraVolumes and extraVolumeMounts options that provide deployment-agnostic volume management.

The previous volume implementation prevented mounting projected volumes (such as secret mounts with renamed key names) and per-container volume mounts (like nginx emptyDir when readOnlyRootFs is enforced). The new approach resolves these limitations.

Moved values

The following Helm chart values have been modified in this release:

  • redis.transportEncryption.enabled β†’ redis.tls.enabled (aligned with upstream Helm chart)
  • redis.scheme β†’ redis.sentinel.enabled (controls deployment mode and aligns with upstream chart)
  • redis.redisServer β†’ redisServer (prevents potential schema conflicts with upstream chart)
  • redis.transportEncryption.params β†’ redisParams (prevents potential schema conflicts with upstream chart)
  • postgresql.postgresServer β†’ postgresServer (prevents potential schema conflicts with upstream chart)

New features

Container and Environment Enhancements

  • Added extraInitContainers support: Both Celery and Django deployments now support additional init containers through the extraInitContainers configuration option.
  • Enhanced probe configuration for Celery: Added support for customizing liveness, readiness, and startup probes in both Celery beat and worker deployments.
  • Enhanced environment variable management: All deployments now include extraEnv support for adding custom environment variables. For backwards compatibility, .Values.extraEnv can be used to inject common environment variables to all workloads.

Other changes

  • Celery pod annotations: Now we can add annotations to Celery beat/worker pods separately.
  • Flexible secret deployment: Added the capability to deploy secrets as regular (non-hooked) resources to address compatibility issues encountered with CI/CD tools (such as ArgoCD).
  • Optional secret references: Some secret references are now optional, allowing the chart to function even when certain secrets are not created.
  • Fixed secret mounting: Resolved issues with optional secret mounts and references.
  • Improved code organization: Minor Helm chart refactoring to enhance readability and maintainability.

PostgreSQL Major Version Upgrade in Docker Compose

This release incorporates a major upgrade of Postgres. When using the default docker compose setup you’ll need to upgrade the Postgres data folder before you can use Defect Dojo 2.51.0.

There are lots of online guides to be found such as https://hub.docker.com/r/tianon/postgres-upgrade or https://github.com/pgautoupgrade/docker-pgautoupgrade.

There’s also the official documentation on pg_upgrade, but this doesn’t work out of the box when using Docker containers.

Sometimes it’s easier to just perform the upgrade manually, which would look something like the steps below. It may need some tuning to your specific needs and docker compose setup. The guide is loosely based on https://simplebackups.com/blog/docker-postgres-backup-restore-guide-with-examples. If you already have a valid backup of the postgres 16 database, you can start at step 4.

0. Backup

Always back up your data before starting and save it somewhere. Make sure the backup and restore is tested before continuing the steps below where the docker volume containing the database will be removed.

1. Start the Old Postgres Container

If you’ve acceidentally already updated your docker-compose.yml to the new versions, downgrade to postgres 16 for now:

Edit your docker-compose.yml to use the old Postgres version (e.g., postgres:17.6-alpine):

postgres:
  image: postgres:17.6-alpine
  ...

Start only the Postgres container which will now be 17.6:

docker compose up -d postgres

2. Dump Your Database

docker compose exec -t postgres pg_dump -U defectdojo -Fc defectdojo -f /tmp/defectdojo.dump
docker cp <postgres_container_name>:/tmp/defectdojo.dump defectdojo.dump

You can find the postgres_container_name via docker container ls or docker ps.

3. Stop Containers and Remove the Old Volume

You can find the volume name via docker volume ls.

docker compose down
docker volume rm <defectdojo_postgres_volume_name>

4. Switch to the New Postgres Version

Edit your docker-compose.yml to use the new version (e.g., postgres:18-alpine):

postgres:
  image: postgres:18-alpine
  ...

5. Start the New Postgres Container

docker compose up -d postgres

6. Restore Your Database

Copy the dump file into the new container:

docker cp defectdojo.dump <postgres_container_name>:/defectdojo.dump

Restore inside the container:

docker exec -it <postgres_container_name> bash
pg_restore -U defectdojo -d defectdojo /defectdojo.dump

7. Start the Rest of Your Services

docker compose up -d

There are other instructions for upgrading to 2.51.x. Check the Release Notes for the contents of the release.