Customizing kn¶
You can customize your kn
CLI setup by creating a config.yaml
configuration file. You can provide this configuration by using the --config
flag, otherwise the configuration is picked up from a default location. The default configuration location conforms to the XDG Base Directory Specification, and is different for Unix systems and Windows systems.
- If the
XDG_CONFIG_HOME
environment variable is set, the default configuration location thatkn
looks for is$XDG_CONFIG_HOME/kn
. - If the
XDG_CONFIG_HOME
environment variable is not set,kn
looks for the configuration in the home directory of the user at$HOME/.config/kn/config.yaml
. - For Windows systems, the default
kn
configuration location is%APPDATA%\kn
.
Example configuration file¶
plugins:
path-lookup: true
directory: ~/.config/kn/plugins
eventing:
sink-mappings:
- prefix: svc
group: core
version: v1
resource: services
Where
path-lookup
specifies whetherkn
should look for plugins in thePATH
environment variable. This is a boolean configuration option (default:true
). Note: thepath-lookup
option has been deprecated and will be removed in a future version where path lookup will be enabled unconditionally.directory
specifies the directory wherekn
will look for plugins. The default path depends on the operating system, as described earlier. This can be any directory that is visible to the user (default:$base_dir/plugins
, where$base_dir
is the directory where this configuration file is stored).sink-mappings
defines the Kubernetes Addressable resource that is used when you use the--sink
flag with akn
CLI command.prefix
: The prefix you want to use to describe your sink. Service,svc
,channel
, andbroker
are predefined prefixes inkn
.group
: The API group of the Kubernetes resource.version
: The version of the Kubernetes resource.resource
: The lowercased, plural name of the Kubernetes resource type. For example,services
orbrokers
.