pi-hole_docs/docs/docker/build-image.md
XhmikosR 7ca1c7b7aa Markdownlint: enable MD040 rule
Signed-off-by: XhmikosR <xhmikosr@gmail.com>
2025-03-04 08:29:46 +02:00

80 lines
2.9 KiB
Markdown

In case you wish to customize the image, or perhaps check out a branch after being asked by a developer to do so, you can use the convenient `build.sh` script located in the root of the [docker-pi-hole repository](https://github.com/pi-hole/docker-pi-hole)
## Checking out the repository
In order to build the image locally, you will first need a copy of the repository on your computer. The following commands will clone the repository from Github and then put you into the directory
```bash
git clone https://github.com/pi-hole/docker-pi-hole
cd docker-pi-hole
git checkout development #NOTE: This step is only needed until V6 is released
```
All other commands following assume you have at least run the above steps.
## Build.sh
```text
Usage: ./build.sh [-l] [-f <ftl_branch>] [-c <core_branch>] [-w <web_branch>] [-t <tag>] [use_cache]
Options:
-f, --ftlbranch <branch> Specify FTL branch (cannot be used in conjunction with -l)
-c, --corebranch <branch> Specify Core branch
-w, --webbranch <branch> Specify Web branch
-p, --paddbranch <branch> Specify PADD branch
-t, --tag <tag> Specify Docker image tag (default: pihole:local)
-l, --local Use locally built FTL binary (requires src/pihole-FTL file)
use_cache Enable caching (by default --no-cache is used)
If no options are specified, the following command will be executed:
docker buildx build src/. --tag pihole:local --load --no-cache
```
## Example uses of the script
### Contributing to the development of `docker-pi-hole`
When contributing, it's always a good idea to test your changes before submitting a pull request. Simply running `./build.sh` will allow you to do so.
There is also `./build-and-test.sh`, which can be used to verify the tests that are run on Github pass with your changes.
```bash
git checkout -b myNewFeatureBranch
#make some changes
./build.sh
```
### As an alternative to `pihole checkout`
Occasionally you may need to try an alternative branch of one of the components (`core`,`web`,`ftl`). On bare metal you would run, for example, `pihole checkout core branchName`, however in the Docker image we have disabled this command as it can cause unpredictable results.
#### Examples
- You have been asked by a developer to checkout the FTL branch `new/Sensors`. To do so
```bash
./build.sh -f new/Sensors
```
- There is new docker-specific work being carried out on the branch `fix/logRotate` that you wish to test
```bash
git checkout fix/logRotate
./build.sh
```
## Using the built image
Unless otherwise named via the `-t` command, the script will build an image locally and tag it as `pihole:local`. You can reference this as a drop-in replacement for `pihole/pihole:latest` in your compose file or your run command:
```yaml
services:
pihole:
container_name: pihole
image: pihole:local
...
```
```bash
docker run [options] pihole:local
```