Synchronize Pi-hole v6.x configuration to replicas.
This project is not a part of the official Pi-hole project, but uses the api provided by Pi-hole instances to perform the synchronization actions.
- Full sync: Use Pi-hole Teleporter for full synchronization.
- Selective sync: Selective feature synchronization.
- Cron schedule: Run on cron schedule.
Download binary from the latest release or build from source:
go install github.com/lovelaze/nebula-sync@latest
Run binary:
# run
nebula-sync run
# read envs from file
nebula-sync run --env-file .env
---
services:
nebula-sync:
image: ghcr.io/lovelaze/nebula-sync:latest
container_name: nebula-sync
environment:
- PRIMARY=http://ph1.example.com|password
- REPLICAS=http://ph2.example.com|password,http://ph3.example.com|password
- FULL_SYNC=true
- RUN_GRAVITY=true
- CRON=0 * * * *
docker run --rm \
--name nebula-sync \
-e PRIMARY="http://ph1.example.com|password" \
-e REPLICAS="http://ph2.example.com|password" \
-e FULL_SYNC=true \
-e RUN_GRAVITY=true \
ghcr.io/lovelaze/nebula-sync:latest
Env and docker-compose examples can be found here
The following environment variables can be specified:
Name | Default | Example | Description |
---|---|---|---|
PRIMARY |
n/a | http://ph1.example.com|password |
Specifies the primary Pi-hole configuration |
REPLICAS |
n/a | http://ph2.example.com|password,http://ph3.example.com|password |
Specifies the list of replica Pi-hole configurations |
FULL_SYNC |
n/a | true |
Specifies whether to perform a full synchronization |
Note: When
FULL_SYNC=true
, the system will perform a full Teleporter import/export from the primary Pi-hole to the replicas. This will synchronize all settings and configurations.
Docker secrets:
PRIMARY
andREPLICAS
environment variables support Docker secrets when defined asPRIMARY_FILE
andREPLICAS_FILE
. See note regarding default user and Docker secrets example below.
Name | Default | Example | Description |
---|---|---|---|
CRON |
n/a | 0 * * * * |
Specifies the cron schedule for synchronization |
RUN_GRAVITY |
false | true | Specifies whether to run gravity after syncing |
TZ |
n/a | Europe/London |
Specifies the timezone for logs and cron |
CLIENT_SKIP_TLS_VERIFICATION |
false | true | Skips TLS certificate verification |
CLIENT_RETRY_DELAY_SECONDS |
1 | 5 | Seconds to delay between connection attempts |
CLIENT_TIMEOUT_SECONDS |
20 | 60 | Http client timeout in seconds |
Note: The following optional settings apply only if
FULL_SYNC=false
. They allow for granular control of synchronization if a full sync is not wanted.
Name | Default | Description |
---|---|---|
SYNC_CONFIG_DNS |
false | Synchronize DNS settings |
SYNC_CONFIG_DHCP |
false | Synchronize DHCP settings |
SYNC_CONFIG_NTP |
false | Synchronize NTP settings |
SYNC_CONFIG_RESOLVER |
false | Synchronize resolver settings |
SYNC_CONFIG_DATABASE |
false | Synchronize database settings |
SYNC_CONFIG_MISC |
false | Synchronize miscellaneous settings |
SYNC_CONFIG_DEBUG |
false | Synchronize debug settings |
SYNC_GRAVITY_DHCP_LEASES |
false | Synchronize DHCP leases |
SYNC_GRAVITY_GROUP |
false | Synchronize groups |
SYNC_GRAVITY_AD_LIST |
false | Synchronize ad lists |
SYNC_GRAVITY_AD_LIST_BY_GROUP |
false | Synchronize ad lists by group |
SYNC_GRAVITY_DOMAIN_LIST |
false | Synchronize domain lists |
SYNC_GRAVITY_DOMAIN_LIST_BY_GROUP |
false | Synchronize domain lists by group |
SYNC_GRAVITY_CLIENT |
false | Synchronize clients |
SYNC_GRAVITY_CLIENT_BY_GROUP |
false | Synchronize clients by group |
Allows including or excluding specific config keys.
Note:The SYNC_CONFIG_*_INCLUDE
andSYNC_CONFIG_*_EXCLUDE
settings are mutually exclusive within each section. Additionally, config filters are only applied ifFULL_SYNC=false
.
Config keys are relative to the section and are case sensitive. For example, the keydns.upstreams
should be referred to asupstreams
, anddns.cache.size
should be referred to ascache.size
.
Name | Example | Description |
---|---|---|
SYNC_CONFIG_DNS_INCLUDE |
upstreams,interface | DNS config keys to include |
SYNC_CONFIG_DNS_EXCLUDE |
upstreams,interface | DNS config keys to exclude |
SYNC_CONFIG_DHCP_INCLUDE |
active,start | DHCP config keys to include |
SYNC_CONFIG_DHCP_EXCLUDE |
active,start | DHCP config keys to exclude |
SYNC_CONFIG_NTP_INCLUDE |
ipv4,sync | NTP config keys to include |
SYNC_CONFIG_NTP_EXCLUDE |
ipv4,sync | NTP config keys to exclude |
SYNC_CONFIG_RESOLVER_INCLUDE |
resolveIPv4,networkNames | Resolver config keys to include |
SYNC_CONFIG_RESOLVER_EXCLUDE |
resolveIPv4,networkNames | Resolver config keys to exclude |
SYNC_CONFIG_DATABASE_INCLUDE |
DBimport,maxDBdays | Database config keys to include |
SYNC_CONFIG_DATABASE_EXCLUDE |
DBimport,maxDBdays | Database config keys to exclude |
SYNC_CONFIG_MISC_INCLUDE |
nice,delay_startup | Misc config keys to include |
SYNC_CONFIG_MISC_EXCLUDE |
nice,delay_startup | Misc config keys to exclude |
SYNC_CONFIG_DEBUG_INCLUDE |
database,networking | Debug config keys to include |
SYNC_CONFIG_DEBUG_EXCLUDE |
database,networking | Debug config keys to exclude |
Nebula Sync can invoke webhooks depending if a sync succeeded or failed. URL is required for the webhook to trigger. Both success and failure webhooks use the same enviroment variable pattern. Webhooks have a timeout of 10 seconds.
Note: Replace
<OUTCOME>
with eitherSUCCESS
orFAILURE
.
Name | Default | Example | Description |
---|---|---|---|
WEBHOOK_SYNC_<OUTCOME>_URL |
n/a | https://www.example.com/webhook |
URL to invoke for the webhook |
WEBHOOK_SYNC_<OUTCOME>_METHOD |
POST |
GET |
The HTTP method for the webhook |
WEBHOOK_SYNC_<OUTCOME>_BODY |
n/a | this is my webhook body |
The body of the webhook request |
WEBHOOK_SYNC_<OUTCOME>_HEADERS |
n/a | header1:foo,header2:bar |
HTTP headers to set for the webhook request in the format key:value separated by comma. Any whitespace will be used verbatim, no string trimming. |
Additionally, you can skip TLS verification for all webhooks if necessary:
Name | Default | Example | Description |
---|---|---|---|
WEBHOOK_CLIENT_SKIP_TLS_VERIFICATION |
false | true | Skips TLS certificate verification |
WEBHOOK_SYNC_SUCCESS_URL=https://hc-ping.com/{your-slug-or-guid-here}
WEBHOOK_SYNC_FAILURE_URL=https://hc-ping.com/{your-slug-or-guid-here}/fail
WEBHOOK_SYNC_FAILURE_URL=http://localhost:8080/notify
WEBHOOK_SYNC_FAILURE_BODY=urls=mailto://user:pass@gmail.com&body=test message
WEBHOOK_SYNC_FAILURE_URL=https://www.example.com/notify.json
WEBHOOK_SYNC_FAILURE_BODY={"hello":"world"}
WEBHOOK_SYNC_FAILURE_HEADERS=Content-Type:application/json
By default, the Docker container runs as user 1001
. If you are using Docker secrets, the user that is running the container will need read permissions to the files that the Docker secrets reference. If the user does not have the right permissions you will receive an error Failed to initialize service error="open /run/secrets/primary: permission denied"
. To avoid this error, either make sure to chown 1001 ./your/secretfiles && chmod 400 ./your/secretfiles
or use the user
directive in Docker Compose to change the user that the container runs as to a user of your choice - and then make sure to update your secret files' ownership to that user. In the example docker-compose-with-secrets.yml, user 1234
owns ./secrets/primary.txt
and ./secrets/replicas.txt
and both have -r--------
permissions.
When using Pi-hole's app passwords ("Configure app password" in the Web interface / API settings page) with nebula-sync, you should enable the Pi-hole setting webserver.api.app_sudo
on your REPLICAS
servers or you may receive authentication errors. To configure this setting, perform one of the following:
- From the Pi-hole web UI, go to Settings -> All Settings. Toggle the "Modified settings / All settings" slider in the upper right to show "All settings". Choose the "Webserver and API" section. Check the "Enabled" box under
webserver.api.app_sudo
and then click "Save & Apply". Repeat for each replica. - With the text editor of your choice, edit the
/etc/pihole/pihole.toml
file. Find theapp_sudo = false
line under[webserver.api]
and modify it to readapp_sudo = true
. Save the file and restart the pihole-FTL service. Repeat for each replica.
This project is an unofficial, community-maintained project and is not affiliated with the official Pi-hole project. It aims to add sync/replication features not available in the core Pi-hole product but operates independently of Pi-hole LLC. Although tested across various environments, using any software from the Internet involves inherent risks. See the license for more details.
Pi-hole and the Pi-hole logo are registered trademarks of Pi-hole LLC.