This document provides instructions on how to build and run Kanister locally.
Kanister is a data management framework written in Go. It allows users to express data protection workflows using blueprints and actionsets. These resources are defined as Kubernetes Custom Resource Definitions , following the operator pattern.
build
- A collection of shell scripts used by the Makefile targets to build, test and package Kanistercmd
- Gomain
packages containing the source of thecontroller
,kanctl
andkando
executablesdocker
- A collection of Dockerfiles for build and demosdocs
- Source of the documentation at docs.kanister.ioexamples
- A collection of example blueprints to show how Kanister works with different data servicesgraphic
- Image files used in documentationhelm
- Helm chart for the Kanister operatorpkg
- Go library packages used by Kanister
The Makefile provides a set of targets to help simplify the build
tasks. To ensure cross-platform consistency, many of these targets use Docker
to spawn build containers based on the ghcr.io/kanisterio/build
public image.
For make test
to succeed, a valid kubeconfig
file must be found at
$HOME/.kube/config
. See the Docker command that runs make test
here.
Use the check
target to ensure your development environment has the necessary
development tools:
make check
The following targets can be used to lint, test and build the Kanister controller:
make golint
make test
make build-controller
To build the controller OCI image:
make release-controller \
IMAGE=<your_registry>/<your_controller_image> \
VERSION=<your_image_tag>
Update the IMAGE
variable to reference the image registry you'd like to push
your image to. You must have write permissions on the registry. If IMAGE
is
not specified, the Makefile will use the default of kanisterio/controller
.
The VERSION
variable is useful for versioning your image with a custom tag.
If VERSION
is not specified, the Makefile will auto-generate one for your
image.
For example, the following command will build and push your image to the
registry at ghcr.io/myregistry/kanister
, with the tag 20221003
:
make release-controller \
IMAGE=ghcr.io/myregistry/kanister \
VERSION=20221003
You can test your Kanister controller locally by using Helm to deploy the local Helm chart:
helm install kanister ./helm/kanister-operator \
--create-namespace \
--namespace kanister \
--set image.repository=<your_registry>/<your_controller_image> \
--set image.tag=<your_image_tag>
Subsequent changes to your Kanister controller can be applied using the helm upgrade
command:
helm upgrade kanister ./helm/kanister-operator \
--namespace kanister \
--set image.repository=<your_registry>/<your_controller_image> \
--set image.tag=<your_new_image_tag>
Most of the Makefile targets can work in a non-Docker development setup, by
setting the DOCKER_BUILD
variable to false
.
The source of the documentation is found in the docs
folder. They are written
in the reStructuredText format.
To rebuild the documentation:
make docs
The docs
target uses the ghcr.io/kanisterio/docker-sphinx
public image to
generate the HTML documents and store them in your local /docs/_build/html
folder.
If you have new blueprints that you think will benefit the community, feel free
to add them to the examples
folder via pull requests. Use the existing folder
layout as a guide. Be sure to include a comprehensive README.md to demonstrate
end-to-end usage.
Kanister can be extended with custom Kanister Functions. All the functions are
written in Go. They are located in the pkg/function
folder.
Take a look at this PR to see how to write a new Kanister Function.
Don't forget to update the documentation at docs/functions.rst
with
configuration information and examples to show off your new function.
The Kanister build image workflow
is used to build and push a new Kanister build image (ghcr.io/kanisterio/build
).
It is an on-demand workflow and needs to be run manually. This workflow expects
image tag
value as an input.
The author updating the build image tag must raise a separate PR to update this value for it to be used in the build process. It should be set it here.
The MongoDB Atlas image workflow
is used to build and push a new Atlas tools image (ghcr.io/kanisterio/mongodb-atlas
).
It is an on-demand workflow and needs to be run manually when there are changes
in Atlas dockerfile. This workflow expects
image tag
value as an input.