To configure the checks KubeLinter runs or to run your own custom checks, you
can use a yaml
configuration file. When you run the lint
command, use the
--config
option and provide the path to your configuration file.
If a config file is not explicitly provided to the command, KubeLinter will look for a configuration file in the current working directory (by order of preference):
.kube-linter.yaml
.kube-linter.yml
Finally, if none is found, the default config is used.
# specific config file
kube-linter lint pod.yaml --config kubelinter-config.yaml
# will search for config based on the above order or will load defaults
kube-linter lint pod.yaml
The configuration file has two sections:
customChecks
for configuring custom checks, andchecks
for configuring default checks.
To view a list of all built-in checks, see KubeLinter checks.
To disable all built in checks, set doNotAutoAddDefaults
to true
.
checks:
doNotAutoAddDefaults: true
Equivalent CLI flag is
--do-not-auto-add-defaults
To run all built-in checks, set addAllBuiltIn
to true
.
checks:
addAllBuiltIn: true
To ignore checks on files or directories under certain paths, add ignored paths to ignorePaths
.
checks:
ignorePaths:
- ~/foo/bar
- ../baz
- /tmp/*.yaml
Equivalent CLI flag is
--ignore-paths
Note
- If you set both
doNotAutoAddDefaults
andaddAllBuiltIn
totrue
,addAllBuiltIn
takes precedence.
Equivalent CLI flag is
--add-all-built-in
You can use the include
and exclude
keys to run only specific checks. For
example,
- To disable majority of checks and only run few specific checks,
use
doNotAutoAddDefaults
along withinclude
.checks: doNotAutoAddDefaults: true include: - "privileged-container" - "run-as-non-root"
- To run majority of checks and only exclude few specific checks,
use
addAllBuiltIn
along withexclude
.checks: addAllBuiltIn: true exclude: - "unset-cpu-requirements" - "unset-memory-requirements"
Equivalent CLI flags are
--include
and--exclude
respectively
[!TIP] >
exclude
always takes precedence, if you include and exclude the same check, KubeLinter always skips the check.
To ignore violations for specific objects, users can add an annotation with the key
ignore-check.kube-linter.io/<check-name>
. We strongly encourage adding an explanation as the value for the annotation.
For example, to ignore a check named "privileged" for a specific deployment, you can add an annotation like that:
metadata:
annotations:
ignore-check.kube-linter.io/privileged: "This deployment needs to run as privileged because it needs kernel access"
To ignore all checks for a specific object, you can use the special annotation key kube-linter.io/ignore-all
.
You can write custom checks based on existing templates. Every template description includes details about the parameters (params
) you can use along with that template.
For example,
-
To make sure that an annotation exists, you can use the
required-annotation
template:customChecks: - name: required-annotation-responsible template: required-annotation params: key: company.io/responsible
-
To make sure that a specific label exists, you can use the
required-label
template:customChecks: - name: required-label-release template: required-label params: key: company.io/release
With custom checks, you can control the checks to run only on specific Kubernetes object types (such as services or deployments). You can also modify the remediation message you get when your custom check fails.
For example,
-
To make sure that a specific annotation exists on all deployments, you can use the
required-label
template and specify ascope
customChecks: - name: required-annotation-responsible template: required-annotation params: key: company.io/responsible scope: objectKinds: - DeploymentLike
For details about
objectKinds
that KubeLinter support, see https://github.com/stackrox/kube-linter/tree/main/pkg/objectkinds. -
Use
remediation
to include a remediation message that users get when your custom check fails:customChecks: - name: required-annotation-responsible template: required-annotation params: key: company.io/responsible remediation: Please set the annotation 'company.io/responsible'. This will be parsed by xy to generate some docs.
If you want to add a check for an objectKind that isn't built into kube-linter, you can also register your own custom objectKind alongside your custom check. This is especially useful for resources from CRDs, where the objectKind may not exist in every cluster, and isn't a good candidate for upstream support.
custom_resource_template_test.go
contains an example of a check that looks for excessively long certificate lifetimes in CNCF cert-manager
Certificate resources.