mirror of
https://github.com/status-im/nim-dagger.git
synced 2025-01-15 09:16:40 +00:00
74c46b3651
* add support for uPnP and PMP nat traversal * update cli flags * merge with master * use listener address from switch * update build script to rename version file * fix styling issues * update docker files - remove Disc_ip env - update CODE_NAT parsing logic * code cleanup * move nat flag parsing logic to conf.nim
Codex Docker Image
Codex provides pre-built docker images and they are stored in the codexstorage/nim-codex repository.
Run
We can run Codex Docker image using CLI
# Default run
docker run --rm codexstorage/nim-codex
# Mount local datadir
docker run -v ./datadir:/datadir --rm codexstorage/nim-codex codex --data-dir=/datadir
And Docker Compose
# Run in detached mode
docker-compose up -d
Arguments
Docker image is based on the codex.Dockerfile and there is
ENTRYPOINT ["/docker-entrypoint.sh"]
CMD ["codex"]
It means that at the image run it will just run codex
application without any arguments and we can pass them as a regular arguments, by overriding command
docker run codexstorage/nim-codex codex --api-bindaddr=0.0.0.0 --api-port=8080
Environment variables
We can configure Codex using Environment variables and docker-compose.yaml file can be useful as an example.
We also added a temporary environment variable NAT_IP_AUTO
to the entrypoint which is set as false
for releases and true
for regular builds. That approach is useful for Dist-Tests.
# Disable NAT_IP_AUTO for regular builds
docker run -e NAT_IP_AUTO=false codexstorage/nim-codex
Slim
- Build the image using
docker build -t codexstorage/codexsetup:latest -f codex.Dockerfile ..
- The docker image can then be minified using slim. Install slim on your path and then run:
slim # brings up interactive prompt >>> build --target status-im/codexsetup --http-probe-off true
- This should output an image with name
status-im/codexsetup.slim
- We can then bring up the image using
docker-compose up -d
.