mirror of
https://github.com/status-im/nim-codex.git
synced 2025-01-10 19:06:28 +00:00
8c232b6759
* Uses correct string for marketplace address * first steps towards support for arm64 * Applies multiarch ubuntu dockerfile as codex-dockerfile. * Add `--simulate-proof-failures` env variable, update docker-compose to point to slimmed image * Add image to CI, and update startCodex.sh * Sets up separate docker build for arm * Update arm64 arm of docker ci * [docker] modify startCodex.sh - include overridden node name in log output if specified in test - quote `—log-level` value so that multiple log levels can be specified - ensure any CLI parameter env vars are passed through to the codex binary, instead of conditionally including them - add `—persistence` - add `—validator` * fixes load and push for amd docker build --------- Co-authored-by: Eric Mastro <github@egonat.me>
64 lines
2.0 KiB
Markdown
64 lines
2.0 KiB
Markdown
# Codex Docker Image
|
|
|
|
Build and run using the example docker-compose file:
|
|
`docker-compose up -d`
|
|
|
|
Stop and retain image and volume data:
|
|
`docker-compose down`
|
|
|
|
Stop and delete image and volume data:
|
|
`docker-compose down --rmi all -v`
|
|
`rm -R hostdatadir`
|
|
|
|
# Environment variables
|
|
Codex docker image supports the following environment variables:
|
|
- LISTEN_ADDRS(*)
|
|
- API_BINDADDR(*)
|
|
- DATA_DIR(*)
|
|
- LOG_LEVEL
|
|
- METRICS_ADDR
|
|
- METRICS_PORT
|
|
- NAT_IP
|
|
- API_PORT
|
|
- DISC_IP
|
|
- DISC_PORT
|
|
- NET_PRIVKEY
|
|
- BOOTSTRAP_SPR
|
|
- MAX_PEERS
|
|
- AGENT_STRING
|
|
- STORAGE_QUOTA
|
|
- BLOCK_TTL
|
|
- CACHE_SIZE
|
|
- ETH_PROVIDER
|
|
- ETH_ACCOUNT
|
|
- ETH_DEPLOYMENT
|
|
- SIMULATE_PROOF_FAILURES
|
|
- VALIDATOR
|
|
- PERSISTENCE
|
|
- CODEX_NODENAME(†)
|
|
|
|
(*) These variables have default values in the docker image that are different from Codex's standard default values.
|
|
|
|
(†) CODEX_NODENAME is used for logging purposes only in the docker image
|
|
|
|
All environment variables are optional and will default to Codex's CLI default values.
|
|
|
|
# Constants
|
|
Codex CLI arguments 'data-dir', 'listen-addrs', and 'api-bindaddr' cannot be configured. They are set to values required for docker in case of bind addresses. In the case of 'data-dir', the value is set to `/datadir`. It is important that you map this folder to a host volume in your container configuration. See docker-compose.yaml for examples.
|
|
|
|
# Useful
|
|
Connect nodes with the `/connect` endpoint.
|
|
To get the IP address of a container within a network:
|
|
Find container Id: `docker ps`
|
|
Open terminal in container: `docker exec -it <CONTAINER ID> sh`
|
|
Get IP addresses: `ifconfig`
|
|
|
|
# Slim
|
|
1. Build the image using `docker build -t status-im/codexsetup:latest -f codex.Dockerfile ..`
|
|
2. The docker image can then be minifed using [slim](https://github.com/slimtoolkit/slim). Install slim on your path and then run:
|
|
```shell
|
|
slim # brings up interactive prompt
|
|
>>> build --target status-im/codexsetup --http-probe-off true
|
|
```
|
|
3. This should output an image with name `status-im/codexsetup.slim`
|
|
4. We can then bring up the image using `docker-compose up -d`. |