Docker Configuration
Floci spawns real Docker containers for services that need them: Lambda, RDS, ElastiCache, OpenSearch, MSK, and ECS. All of these share the same Docker client configuration, controlled under floci.docker.
Docker Daemon Socket
By default Floci connects to the local Docker daemon via the Unix socket. Override it with docker-host when needed (e.g. a remote Docker host or a non-standard socket path):
Environment variable: FLOCI_DOCKER_DOCKER_HOST
When running Floci inside Docker Compose, mount the host socket:
Private Registry Authentication
Any service that pulls a container image from a private registry (Lambda image functions, custom OpenSearch images, private Postgres images, etc.) needs Docker credentials. Two approaches are supported and can be combined.
Mount the host Docker config
Reuses existing docker login sessions and credential helpers from the host machine. Mount the host ~/.docker directory and point Floci at it:
services:
floci:
volumes:
- /var/run/docker.sock:/var/run/docker.sock
- ~/.docker:/root/.docker:ro
environment:
FLOCI_DOCKER_DOCKER_CONFIG_PATH: /root/.docker
Or in application.yml:
This works with any credential helper configured on the host (docker-credential-desktop, ecr-credential-helper, etc.) as long as the helper binary is also available inside the Floci container.
Explicit per-registry credentials
For CI environments or air-gapped setups where mounting the host filesystem is not practical:
services:
floci:
environment:
FLOCI_DOCKER_REGISTRY_CREDENTIALS_0__SERVER: myregistry.example.com
FLOCI_DOCKER_REGISTRY_CREDENTIALS_0__USERNAME: myuser
FLOCI_DOCKER_REGISTRY_CREDENTIALS_0__PASSWORD: mypassword
# Add more registries by incrementing the index:
# FLOCI_DOCKER_REGISTRY_CREDENTIALS_1__SERVER: other.registry.io
# FLOCI_DOCKER_REGISTRY_CREDENTIALS_1__USERNAME: ...
# FLOCI_DOCKER_REGISTRY_CREDENTIALS_1__PASSWORD: ...
Or in application.yml:
floci:
docker:
registry-credentials:
- server: myregistry.example.com
username: myuser
password: mypassword
- server: other.registry.io
username: otheruser
password: otherpassword
The server field must match the registry hostname exactly as it appears in the image URI (e.g. myregistry.example.com for myregistry.example.com/repo:tag). Docker Hub images (e.g. ubuntu:22.04) have an empty hostname and are not matched by any explicit credential entry — use the Docker config mount approach for Docker Hub authentication.
Precedence
Explicit credentials take precedence for registries they cover. For everything else, Floci falls back to the Docker config file (if docker-config-path is set) and then to an anonymous pull.
Container Log Settings
Configure log rotation for all containers spawned by Floci:
floci:
docker:
log-max-size: "10m" # Max size per log file before rotation (Docker json-file format)
log-max-file: "3" # Number of rotated log files to retain per container
Docker Network
Containers spawned by Floci (Lambda, RDS, ElastiCache, OpenSearch, MSK, ECS) need to be on the same Docker network to communicate with each other and with Floci itself.
Set the shared network at the top level:
Environment variable: FLOCI_SERVICES_DOCKER_NETWORK
Individual services can override the network with their own docker-network setting (e.g. floci.services.lambda.docker-network).
Tip
In Docker Compose, the default network name is <project-name>_default. If your compose file is in a directory named myapp, the network is myapp_default.
Full Reference
| Environment variable | Default | Description |
|---|---|---|
FLOCI_DOCKER_DOCKER_HOST |
unix:///var/run/docker.sock |
Docker daemon socket |
FLOCI_DOCKER_DOCKER_CONFIG_PATH |
(unset) | Path to directory containing Docker's config.json |
FLOCI_DOCKER_REGISTRY_CREDENTIALS_0__SERVER |
(unset) | Registry hostname for credential entry 0 |
FLOCI_DOCKER_REGISTRY_CREDENTIALS_0__USERNAME |
(unset) | Username for credential entry 0 |
FLOCI_DOCKER_REGISTRY_CREDENTIALS_0__PASSWORD |
(unset) | Password for credential entry 0 |
FLOCI_DOCKER_LOG_MAX_SIZE |
10m |
Max container log file size before rotation |
FLOCI_DOCKER_LOG_MAX_FILE |
3 |
Number of rotated log files to retain |
FLOCI_SERVICES_DOCKER_NETWORK |
(unset) | Shared Docker network for all container-based services |