-
Notifications
You must be signed in to change notification settings - Fork 120
Home
BloodHound CE is a security tool that uses graph theory to reveal the hidden and often unintended relationships within an Active Directory or Entra ID (formerly known as Azure AD) environment. Attackers can use BloodHound to easily identify highly complex attack paths that would otherwise be impossible to quickly identify. Defenders can use BloodHound to identify and eliminate those same attack paths. Both blue and red teams can use BloodHound to easily gain a deeper understanding of privilege relationships in an Active Directory or Azure environment.
If you're visiting this wiki as a BloodHound user, we highly recommend checking out our official documentation. These pages hold a wealth of knowledge around setup, usage, and best practices for BloodHound CE and Enterprise, as most information is interchangeable between the two versions.
If the docs still didn't have an answer then feel free to reach out to us or the Community for help. You can check out the Contact page for more information.
Deploy BloodHound CE quickly with the following steps:
- Install Docker Desktop. Docker Desktop includes Docker Compose as part of the installation.
- Download the Docker Compose YAML file and save it to a directory where you'd like to run BloodHound. You can do this from a terminal application with
curl -L https://ghst.ly/getbhce
.On Windows: Execute the command in CMD, or use
curl.exe
instead ofcurl
in PowerShell. - Navigate to the folder with the saved
docker-compose.yaml
file and rundocker compose pull && docker compose up
. - Locate the randomly generated password in the terminal output of Docker Compose.
- In a browser, navigate to
http://localhost:8080/ui/login
. Login with a username ofadmin
and the randomly generated password from the logs.
NOTE: The default docker-compose.yml
example binds only to localhost (127.0.0.1). If you want to access BloodHound outside of localhost, you'll need to follow the instructions in examples/docker-compose/README.md to configure the host binding for the container.
Details on setting up the BloodHound CE development environment and contributing code can be found on the Development page.
BloodHound will soon be targeting Postgres 16 for development. This is part of our ongoing effort to ensure better performance and security, grant us access to new features, and to stay ahead of the release support schedule. Postgres 13's last release is scheduled for November 13th, 2025. As of this writing, it is not required to update any pre-existing Postgres deployment to use newer versions of BloodHound.
If you have data that you want to keep, follow the steps below on how to back up and restore your data before the upgrade happens. Once the upgrade is done on the repo, any unbacked data will be lost. If you prefer to upgrade your environment using other methods, links to alternative approaches are provided at the end.
Otherwise, if you have no concern for data loss, no action is required and the upgrade will proceed automatically.
# 0. Depending on which version you're running, either 13.2 or 16, you may have to run these commands twice. Where each attempt is (1) going from 16 to 13.2, and then (2) back to 16. If you're still on 13.2, you only need to run these commands once.
# 1. Stop any running containers, navigate to examples/docker-compose/, and start only the database container
docker compose up app-db
# 2. Change the password encryption from MD5 to SCRAM-SHA-256 format (Postgres 16 defaults to this format)
docker compose exec app-db sh -c "psql -c \"SET password_encryption = 'scram-sha-256'; ALTER ROLE CURRENT_USER PASSWORD '\${BH_POSTGRES_PASSWORD:-bloodhoundcommunityedition}';\""
# 3. Export existing data via a database dump (while the database container is running)
docker compose exec app-db pg_dumpall > dump.sql
# 4. Stop with Ctrl+C and remove the database container
docker compose rm -f app-db
# 5. Remove only the database volume for the Postgres service
docker volume rm docker-compose_postgres-data
# 6. Edit the docker-compose.yml file in examples/docker-compose/docker-compose.yml or whatever directory the file is kept
Or
# 7. Start only the database container
docker compose up app-db
# 8. Restore the database from the dump file
docker compose exec -T app-db psql < dump.sql
# 9. Stop the database container with Ctrl+C
# 10. Finally, start all containers
docker compose up
If you'd prefer to upgrade via alternative methods, check out the following resources:
https://github.com/tianon/docker-postgres-upgrade/tree/master
https://github.com/pgautoupgrade/docker-pgautoupgrade
If you have any questions or need assistance with backing up or restoring your data, please feel free to reach out to the team on our official BloodHound community Slack!