-
Notifications
You must be signed in to change notification settings - Fork 14
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Custom bootstrap configuration Documentation #935
base: main
Are you sure you want to change the base?
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Great work. 😸
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM overall, great work! A few points I'd like to bring up
- IIRC All features are disabled by default when a config file is used unless
enabled: true
is set exclusively for desired features. I feel like we should mention this somewhere here. See https://github.com/canonical/k8s-snap/blob/main/tests/integration/templates/bootstrap-all.yaml for example - Another point is we can pass a "bootstrap file" to the
join-cluster
command as well, which is mostly used to adjust per-node config. Should we make this into another page like join config or mention it here? @nhennigan
Just double checking: according to the bootstrap reference guide the network, dns and gateway are by default enabled and the rest disabled. Is that wrong? |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Great work @louiseschmidtgen, thanks a lot! LGTM overall, just some minor nits.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Generally LGTM, added a couple of comments.
Great work @louiseschmidtgen
|
||
If your deployment requires a more fine tuned configuration, use the bootstrap | ||
configuration file. A good starting point can be the default | ||
[bootstrap-config-full.yaml]. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think we moved away from code pointers as it creates implicit dependencies between code and documentation that can easily break, e.g. if we decide to move this file in the future.
I'd just link to the reference page here as the source of truth.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I am worried about that too- but seeing that it is part of a test that tests I am quite confident that it will stay updated... Happy to remove it as well if that's the better call
When creating a {{ product }} cluster that differs from the default | ||
configuration you can choose to use a custom bootstrap configuration. | ||
The CLI's interactive mode or a custom bootstrap configuration file allow you | ||
to modify the configuration of the first node that will join your cluster. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The first node will always be control plane yes? Join the cluster implies it already exists. Suggestion: the first node of your cluster.
I think it is important to add the line about providing a config file disabling the features by default. The user should be aware of exactly the implications of using a custom config file.
Mateo also did a similar page for the charms here where the worker nodes custom config join was a separate page. I liked how he had different workers configs for different workloads. It is not a massive deal whether this is two separate pages or one but I would lean towards two. |
Agreed @nhennigan , we should definitely mention it. I recall a user hitting this case and getting confused. And for @louiseschmidtgen to verify that features are disabled unless specified you can bootstrap a cluster with pod-cidr: 10.100.0.0/16
service-cidr: 10.200.0.0/16 as the config file and check |
@nhennigan and @berkayoz I've corrected the default feature settings reference. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Great work. Small nit and then good to merge 😄
The CLI's interactive mode or a custom bootstrap configuration file allow you | ||
to modify the configuration of the first node of your cluster. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I wouldn't be so specific here. Technically the config. will apply to other nodes as well.
``` {note} | ||
Most of these configuration options are set during the initial bootstrapping | ||
and cannot be modified afterward. Runtime changes may be unsupported and | ||
could require deploying a new cluster. Refer to the reference page to |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Link to the reference page
Custom bootstrap configuration Documentation
This PR adds the custom bootstrap configuration documentation which includes bootstrapping with the interactive mode and through a configuration file.