Skip to content

Commit

Permalink
docs: add buildkitd.toml docs new gc options
Browse files Browse the repository at this point in the history
Signed-off-by: Justin Chadwell <me@jedevc.com>
  • Loading branch information
jedevc committed Oct 25, 2024
1 parent d09703e commit ffd2516
Showing 1 changed file with 61 additions and 9 deletions.
70 changes: 61 additions & 9 deletions docs/buildkitd.toml.md
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,13 @@ The file path is `/etc/buildkit/buildkitd.toml` for rootful mode,
The following is a complete `buildkitd.toml` configuration example.
Note that some configuration options are only useful in edge cases.

This config file has been updated, some options may not be available on older
buildkit versions:
- In v0.17.0, `reservedSpace`/`maxUsedSpace`/`minFreeSpace` properties were
added on `worker.oci` and `worker.containerd` as well as to their respective
`gcpolicy` properties. `gckeepbytes`/`keepBytes` have been deprecated as a
result.

```toml
# debug enables additional debug logging
debug = true
Expand Down Expand Up @@ -62,11 +69,27 @@ insecure-entitlements = [ "network.host", "security.insecure" ]
# Whether run subprocesses in main pid namespace or not, this is useful for
# running rootless buildkit inside a container.
noProcessSandbox = false

# gc enables/disables garbage collection
gc = true
# gckeepstorage can be an integer number of bytes (e.g. 512000000), a string
# with a unit (e.g. "512MB"), or a string percentage of the total disk
# space (e.g. "10%")
gckeepstorage = 9000
# deprecated: gckeepstorage is a fallback for reservedSpace
gckeepstorage = "30%"
# reservedSpace is the minimum amount of disk space guaranteed to be
# retained - any usage below this threshold will not be reclaimed during
# garbage collection.
# all disk space parameters can be an integer number of bytes (e.g.
# 512000000), a string with a unit (e.g. "512MB"), or a string percentage
# of the total disk space (e.g. "10%")
reservedSpace = "30%"
# maxUsedSpace is the maximum amount of disk space that may be used -
# any usage above this threshold will be reclaimed during garbage
# collection.
maxUsedSpace = "60%"
# minFreeSpace is the target amount of free disk space that the garbage
# collector will attempt to leave - however, it will never be bought below
# reservedSpace.
minFreeSpace = "20GB"

# alternate OCI worker binary name(example 'crun'), by default either
# buildkit-runc or runc binary is used
binary = ""
Expand All @@ -83,10 +106,21 @@ insecure-entitlements = [ "network.host", "security.insecure" ]
"foo" = "bar"

[[worker.oci.gcpolicy]]
# keepBytes can be an integer number of bytes (e.g. 512000000), a string
# with a unit (e.g. "512MB"), or a string percentage of the total disk
# space (e.g. "10%")
# deprecated: keepBytes is a fallback for reservedSpace
keepBytes = "512MB"
# reservedSpace is the minimum amount of disk space guaranteed to be
# retained by this policy - any usage below this threshold will not be
# reclaimed during # garbage collection.
reservedSpace = "512MB"
# maxUsedSpace is the maximum amount of disk space that may be used by this
# policy - any usage above this threshold will be reclaimed during garbage
# collection.
maxUsedSpace = "1GB"
# minFreeSpace is the target amount of free disk space that the garbage
# collector will attempt to leave - however, it will never be bought below
# reservedSpace.
minFreeSpace = "10GB"

# keepDuration can be an integer number of seconds (e.g. 172800), or a
# string duration (e.g. "48h")
keepDuration = "48h"
Expand All @@ -100,9 +134,27 @@ insecure-entitlements = [ "network.host", "security.insecure" ]
enabled = true
platforms = [ "linux/amd64", "linux/arm64" ]
namespace = "buildkit"

# gc enables/disables garbage collection
gc = true
# gckeepstorage sets storage limit for default gc profile, in bytes.
gckeepstorage = 9000
# deprecated: gckeepstorage is a fallback for reservedSpace
gckeepstorage = "30%"
# reservedSpace is the minimum amount of disk space guaranteed to be
# retained - any usage below this threshold will not be reclaimed during
# garbage collection.
# all disk space parameters can be an integer number of bytes (e.g.
# 512000000), a string with a unit (e.g. "512MB"), or a string percentage
# of the total disk space (e.g. "10%")
reservedSpace = "30%"
# maxUsedSpace is the maximum amount of disk space that may be used -
# any usage above this threshold will be reclaimed during garbage
# collection.
maxUsedSpace = "60%"
# minFreeSpace is the target amount of free disk space that the garbage
# collector will attempt to leave - however, it will never be bought below
# reservedSpace.
minFreeSpace = "20GB"

# maintain a pool of reusable CNI network namespaces to amortize the overhead
# of allocating and releasing the namespaces
cniPoolSize = 16
Expand Down

0 comments on commit ffd2516

Please sign in to comment.