ghcr.io or quay.io, or a local caching proxy.
How it Works
When you ask BoxLite to create a box from an image (e.g.,image="alpine"), it needs to resolve this “unqualified” reference into a full image reference (e.g., docker.io/library/alpine:latest).
By default, if no registries are configured, BoxLite uses docker.io (Docker Hub) as the implicit default.
You can provide a list of custom registries. BoxLite will try to pull the image from each registry in the provided order. The first successful pull wins. If all registries fail, the operation returns an error.
Fully qualified image references (e.g.,
quay.io/prometheus/prometheus:v2.40.1) always bypass the search mechanism and are pulled directly.CLI Configuration
The CLI layers configuration sources with the following priority (from lowest to highest):- Default:
docker.io - Configuration File (
--config): Loads configuration from the specified path - CLI Flags (
--registry): Prepended to registries from config file (highest priority)
1. Configuration File
Create a JSON configuration file with your registry preferences:image_registries field is optional. It contains a list of registries to search for unqualified image references.
2. Using the Configuration File
Use the--config flag to specify your configuration file:
3. Command Line Flags
You can use the global--registry flag with boxlite run or boxlite create. You can specify it multiple times.
These flags are prepended to your configured list. This allows you to force a specific registry to be checked first for a single command without editing your config file.
SDK Configuration
The SDKs are “pure” by design. They do not automatically load any configuration file. This ensures that your code’s behavior is deterministic and does not silently depend on the user’s local environment.- Programmatic Options: You explicitly pass the list of registries when initializing the runtime.
- Default:
docker.io(if you pass an empty list or nothing).
Advanced: Loading Config in SDKs
If you want your SDK application to respect a configuration file, you can manually load it. This puts the control in your hands.Registry Resolution Order
To summarize the full resolution order for CLI usage:Check if the image reference is fully qualified
If the image reference includes a registry domain (e.g.,
quay.io/prometheus/prometheus:v2.40.1), pull directly from that registry. Skip all other steps.Try CLI --registry flags (highest priority)
If
--registry flags were provided, try each one in order.Try registries from configuration file
If a
--config file was specified and it contains image_registries, try each one in order.