How to contribute to Canonical Kubernetes¶
Canonical Kubernetes is proudly open source, published under the GPLv3 license. We welcome and encourage contributions to the code and the documentation. See the community page for ways to get in touch and provide feedback.
Contribute to the code¶
Canonical Kubernetes is shipped as a snap package. To contribute to the code, you should first make sure you can build and test the snap locally.
Build the snap¶
To build the snap locally, you will need the following:
The latest, snap-based version of LXD (see the install guide here)
The Snapcraft build tool, for building the snap (see the Snapcraft documentation).
Clone the GitHub repository for the k8s snap and then open a terminal in that directory. Run the command:
snapcraft --use-lxd
This will launch an LXD container and use it to build a version of the snap. This will take some time as the build process fetches dependencies, stages the ‘parts’ of the snap and creates the snap package itself. The snap itself will be fetched from the build environment and placed in the local project directory. Note that the LXD container used for building will be stopped, but not deleted. This is in case there were any errors or artefacts you may wish to inspect.
Install the snap¶
The snap can then be installed locally by using the ‘–dangerous’ option. This is a safeguard to make sure the user is aware that the snap is not signed by the snap store, and is not confined:
sudo snap install k8s_v1.29.2_multi.snap --dangerous --classic
Note
You will not be able to install this snap if there is already a k8s snap installed on your system.
Once you have verified the current snap build works, it can be removed with:
sudo snap remove k8s --purge
The purge
option is recommended when iterating over code changes, as it also
removes all the installed artefacts which may be associated with the snap.
Now you can iterate over changes to the snap, rebuild and test.
As noted previously, the LXD container used for building is not removed and will be reused by subsequent build instructions. When you are satisfied it is no longer needed, this container can be removed:
lxc delete snapcraft-k8s
Contribute changes¶
We welcome any improvements and bug-fixes to the Canonical Kubernetes code. Once you have tested your changes, please make a pull request on the code repository and we will review it as soon as possible.
Contribute to the documentation¶
Our aim is to provide easy-to-understand documentation on all aspects of Canonical Kubernetes, so we greatly appreciate your feedback and contributions. See our community page for ways of getting in touch.
The source of the documentation and the system used to build it are included in the main repository for the Canonical Kubernetes snap.
Documentation framework¶
This documentation has adopted the Diátaxis framework. You can read more about it on the Diátaxis website. In essence though, this guides the way we categorise and write our documentation. You can see there are four main categories of documentation:
Tutorials for guided walk-throughs
How to pages for specific tasks and goals
Explanation pages which give background reasons and, well, explanations
Reference, where you will find the commands, the roadmap, etc.
Every page of documentation should fit into one of those categories. If it doesn’t you may consider if it is actually two pages (e.g. a How to and an explanation).
Small changes¶
If you are simply correcting a typo or updating a link, you can follow the ‘Edit this page on GitHub’ link on any page and it will take you to the online editor to make your change. You will still need to raise a pull request and explain your change to get it reviewed.
Myst, Markdown and Sphinx¶
We use the Sphinx documentation tools to actually build the documentation. You
will find all the Sphinx tooling in the docs/tools
directory.
Although Sphinx is normally associated with the ReSTructured text
format, we
write all our documentation in Markdown to make it easier for humans to work
with. There are a few extra things that come with this - certain features need
to be specially marked up (e.g. admonitions) to be processed properly. There is
a guide to using Myst
(which is a Markdown extension for Sphinx) directives
and formatting contained in the _parts directory of the docs.
Local testing¶
To test your changes locally, you can build a local version of the
documentation. Open a terminal and go to the /docs/tools
directory. From
there you can run the command:
make run
This will create a local environment, install all the dependencies and build
the docs. The output will then be served locally - check the output for the
URL. Using the run
option means that the docs will automatically be
regenerated when you change any of the source files too (though remember to
press F5
in your browser to reload the page without caching)!