From 0c29018fa83aaf682627adc19834a59441e3e5b5 Mon Sep 17 00:00:00 2001 From: fabriziopandini Date: Mon, 29 Apr 2024 15:32:20 +0200 Subject: [PATCH] Drop docs not maintained --- README.md | 2 - docs/book/src/introduction.md | 19 ++- docs/scope-and-objectives.md | 177 ------------------------ docs/staging-use-cases.md | 245 ---------------------------------- hack/generate-doctoc.sh | 2 +- 5 files changed, 19 insertions(+), 426 deletions(-) delete mode 100644 docs/scope-and-objectives.md delete mode 100644 docs/staging-use-cases.md diff --git a/README.md b/README.md index aca166adab26..b4a3b9d5d175 100644 --- a/README.md +++ b/README.md @@ -13,9 +13,7 @@ ### 👋 Welcome to our project! Our [Book](https://cluster-api.sigs.k8s.io) can help you get started and provides lots of in-depth information. #### Useful links -- [Scope, objectives, goals and requirements](./docs/scope-and-objectives.md) - [Feature proposals](./docs/proposals) -- [Reference use cases](./docs/staging-use-cases.md) - [Quick Start](https://cluster-api.sigs.k8s.io/user/quick-start.html) ## ✨ What is the Cluster API? diff --git a/docs/book/src/introduction.md b/docs/book/src/introduction.md index 53d5eebba779..d62b258204c6 100644 --- a/docs/book/src/introduction.md +++ b/docs/book/src/introduction.md @@ -55,6 +55,23 @@ However, while kubeadm and other bootstrap providers reduce installation complex SIG Cluster Lifecycle began the Cluster API project as a way to address these gaps by building declarative, Kubernetes-style APIs, that automate cluster creation, configuration, and management. Using this model, Cluster API can also be extended to support any infrastructure provider (AWS, Azure, vSphere, etc.) or bootstrap provider (kubeadm is default) you need. See the growing list of [available providers](./reference/providers.md). -{{#include ../../scope-and-objectives.md:Goals}} +### Goals + +- To manage the lifecycle (create, scale, upgrade, destroy) of Kubernetes-conformant clusters using a declarative API. +- To work in different environments, both on-premises and in the cloud. +- To define common operations, provide a default implementation, and provide the ability to swap out implementations for alternative ones. +- To reuse and integrate existing ecosystem components rather than duplicating their functionality (e.g. node-problem-detector, cluster autoscaler, SIG-Multi-cluster). +- To provide a transition path for Kubernetes lifecycle products to adopt Cluster API incrementally. Specifically, existing cluster lifecycle management tools should be able to adopt Cluster API in a staged manner, over the course of multiple releases, or even adopting a subset of Cluster API. + +### Non-goals + +- To add these APIs to Kubernetes core (kubernetes/kubernetes). + - This API should live in a namespace outside the core and follow the best practices defined by api-reviewers, but is not subject to core-api constraints. +- To manage the lifecycle of infrastructure unrelated to the running of Kubernetes-conformant clusters. +- To force all Kubernetes lifecycle products (kOps, Kubespray, GKE, AKS, EKS, IKS etc.) to support or use these APIs. +- To manage non-Cluster API provisioned Kubernetes-conformant clusters. +- To manage a single cluster spanning multiple infrastructure providers. +- To configure a machine at any time other than create or upgrade. +- To duplicate functionality that exists or is coming to other tooling, e.g., updating kubelet configuration (c.f. dynamic kubelet configuration), or updating apiserver, controller-manager, scheduler configuration (c.f. component-config effort) after the cluster is deployed. {{#include ../../../README.md:Community}} diff --git a/docs/scope-and-objectives.md b/docs/scope-and-objectives.md deleted file mode 100644 index d489357fff48..000000000000 --- a/docs/scope-and-objectives.md +++ /dev/null @@ -1,177 +0,0 @@ ---- -title: Cluster API Scope and Objectives -authors: - - "@vincepri" - - "@ncdc" - - "@detiber" -reviewers: - - "@timothysc" - - "@justinsb" -creation-date: 2019-04-08 -last-updated: 2019-04-08 ---- - - - - -- [Cluster API Scope and Objectives](#cluster-api-scope-and-objectives) - - [Table of Contents](#table-of-contents) - - [Summary](#summary) - - [What is Cluster API?](#what-is-cluster-api) - - [Glossary](#glossary) - - [Motivation](#motivation) - - [Goals](#goals) - - [Non-goals](#non-goals) - - [Requirements](#requirements) - - [Foundation](#foundation) - - [User Experience](#user-experience) - - [Organization](#organization) - - [Validation](#validation) - - [Extension](#extension) - - - - -# Cluster API Scope and Objectives - -This is a living document that is refined over time. It serves as guard rails for what is in and out of scope for Cluster API. As new ideas or designs take shape over time, this document can and should be updated. - -## Table of Contents - -* [Cluster API Scope and Objectives](#cluster-api-scope-and-objectives) - * [Table of Contents](#table-of-contents) - * [Summary](#summary) - * [What is Cluster API?](#what-is-cluster-api) - * [Glossary](#glossary) - * [Motivation](#motivation) - * [Goals](#goals) - * [Non-goals](#non-goals) - * [Requirements](#requirements) - * [Foundation](#foundation) - * [User Experience](#user-experience) - * [Organization](#organization) - * [Validation](#validation) - * [Extension](#extension) - -## Summary - -We are building a set of Kubernetes cluster management APIs to enable common cluster lifecycle operations (create, scale, upgrade, destroy) across infrastructure providers. - -#### What is Cluster API? - -- An API definition for managing Kubernetes Clusters declaratively. -- A reference implementation for the core logic. -- An API definition for cluster lifecycle management action extension points. - -## Glossary - -[See ./book/GLOSSARY.md](./book/src/reference/glossary.md) - -- __Cluster API__: Unless otherwise specified, this refers to the project as a whole. -- __Infrastructure provider__: Refers to the source of computational resources (e.g. machines, networking, etc.). Examples for cloud include AWS, Azure, Google, etc.; for bare metal include VMware, MAAS, etc. When there is more than one way to obtain resources from the same infrastructure provider (e.g. EC2 vs. EKS) each way is referred to as a variant. -- __Provider implementation__: Existing Cluster API implementations consist of generic and infrastructure provider-specific logic. The infrastructure provider-specific logic is currently maintained in infrastructure provider repositories. -- __Kubernetes-conformant__: A cluster that passes the Kubernetes conformance tests. -- __Scaling__: Unless otherwise specified, this refers to horizontal scaling. -- __Control plane__: - - __Self-provisioned__: A Kubernetes control plane consisting of pods or machines wholly managed by a single Cluster API deployment. - - __External__: A control plane offered and controlled by some system other than Cluster API (e.g., GKE, AKS, EKS, IKS). -- __Core Add-ons__: Addons that are required to deploy a Kubernetes-conformant cluster: DNS, kube-proxy, CNI. -- __Additional Add-ons__: Addons that are not required for a Kubernetes-conformant cluster (e.g. metrics/Heapster, Dashboard). -- __Management cluster__: The cluster where one or more Cluster API providers run, and where resources (e.g. Machines) are stored. -- __Workload cluster__: A cluster whose lifecycle is managed by the Management cluster. -- __Operating system__: A generically understood combination of a kernel and system-level userspace interface, such as Linux or Windows, as opposed to a particular distribution. -- __Manage a cluster__: Create, scale, upgrade, destroy. -- __Default implementation__: A feature implementation offered as part of Cluster API project, infrastructure providers can swap it out for a different one. - -## Motivation - -Kubernetes has a common set of APIs (see the [Kubernetes API Conventions](https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md)) to orchestrate containers regardless of deployment mechanism or cloud provider. Kubernetes also has APIs for handling some infrastructure, like load-balancers, ingress rules, or persistent volumes, but not for creating new machines. -As a result, existing popular deployment mechanisms that manage Kubernetes clusters each have unique APIs and implementations for how to handle lifecycle events like cluster creation or deletion, control plane upgrades, and node upgrades. - - - - -### Goals - -- To manage the lifecycle (create, scale, upgrade, destroy) of Kubernetes-conformant clusters using a declarative API. -- To work in different environments, both on-premises and in the cloud. -- To define common operations, provide a default implementation, and provide the ability to swap out implementations for alternative ones. -- To reuse and integrate existing ecosystem components rather than duplicating their functionality (e.g. node-problem-detector, cluster autoscaler, SIG-Multi-cluster). -- To provide a transition path for Kubernetes lifecycle products to adopt Cluster API incrementally. Specifically, existing cluster lifecycle management tools should be able to adopt Cluster API in a staged manner, over the course of multiple releases, or even adopting a subset of Cluster API. - -### Non-goals - -- To add these APIs to Kubernetes core (kubernetes/kubernetes). - - This API should live in a namespace outside the core and follow the best practices defined by api-reviewers, but is not subject to core-api constraints. -- To manage the lifecycle of infrastructure unrelated to the running of Kubernetes-conformant clusters. -- To force all Kubernetes lifecycle products (kOps, Kubespray, GKE, AKS, EKS, IKS etc.) to support or use these APIs. -- To manage non-Cluster API provisioned Kubernetes-conformant clusters. -- To manage a single cluster spanning multiple infrastructure providers. -- To configure a machine at any time other than create or upgrade. -- To duplicate functionality that exists or is coming to other tooling, e.g., updating kubelet configuration (c.f. dynamic kubelet configuration), or updating apiserver, controller-manager, scheduler configuration (c.f. component-config effort) after the cluster is deployed. - - - -## Requirements - -#### Foundation - -- Cluster API MUST be able to be deployed and run on Kubernetes. - -- Cluster API MUST provide runtime and state isolation between providers within the same Management Cluster - -- Cluster API MUST support multiple infrastructure providers, including both on-prem and cloud providers. - -- Cluster API MUST be able to manage groups/sets of Kubernetes nodes that support scaling and orchestrated upgrades. - -- Cluster API, through a single installation, MUST be able to manage (create, scale, upgrade, destroy) clusters on multiple providers. - -- Cluster API SHOULD support all operating systems in scope for Kubernetes conformance. - -#### User Experience - -- Cluster API MUST be able to provide the versions of Kubernetes and related components of a Node that it manages. - -- Cluster API MUST be able to provide sufficient information for a consumer to directly use the API server of the provisioned workload cluster. - -#### Organization - -- Cluster API MUST NOT have code specific to a particular provider within the main repository, defined as sigs.k8s.io/cluster-api. - -#### Validation - -- Cluster API MUST enable infrastructure providers to validate configuration data. - -- Cluster API MUST test integrations that it claims will work. - -- Cluster API MUST deploy clusters that pass Kubernetes conformance tests. - -- Cluster API MUST document how to bootstrap itself and MAY provide tooling to do so. - -- Cluster API MUST document requirements for machine images and SHOULD reference default tools to prepare machine images. - -- Cluster API MUST have conformance tests to ensure that Cluster API and a given provider fulfill the expectations of users/automation. - -#### Extension - -- Cluster API SHOULD allow default implementations to be pluggable/extensible. - - Cluster API SHOULD offer default implementations for generic operations. - - Users MAY use different provider implementations for different sets of operations. - -- 🔌 Cluster API MUST be able to provide information as to which versions of Kubernetes it can install. - -- 🔌 Cluster API MUST be able to bootstrap a new Kubernetes control plane. - -- 🔌 Cluster API MUST provide a generic image lookup mechanism that can filter on characteristics such as kubernetes version, container runtime, kernel version, etc. - -- 🔌 Cluster API MUST be able to provide a consistent (across providers) way to prepare, configure, and join nodes to a cluster. - -- 🔌 Cluster API MUST be able to scale a self-provisioned control plane up from and down to one replica. - -- 🔌 Cluster API MUST provide high-level orchestration for Kubernetes upgrades (control plane and non-control plane). - -- 🔌 Cluster API MUST define and document configuration elements that it exclusively manages and take corrective actions if these elements are modified by external actors. - -- 🔌 Cluster API MUST provide the ability to receive the health status of a Kubernetes Node from an external source. - -- 🔌 Cluster API provider implementations SHOULD allow customization of machine, node, or operating system image. diff --git a/docs/staging-use-cases.md b/docs/staging-use-cases.md deleted file mode 100644 index 65b723451f37..000000000000 --- a/docs/staging-use-cases.md +++ /dev/null @@ -1,245 +0,0 @@ ---- -title: Cluster API Reference Use Cases -creation-date: 2019-04-16 -last-updated: 2019-04-16 ---- - - - - -- [Cluster API Reference Use Cases](#cluster-api-reference-use-cases) - - [Role Glossary](#role-glossary) - - [Icon Glossary](#icon-glossary) - - [Operator of Workload Cluster](#operator-of-workload-cluster) - - [Creating Clusters](#creating-clusters) - - [Staged Adoption of Cluster API By Operators](#staged-adoption-of-cluster-api-by-operators) - - [Deleting Clusters](#deleting-clusters) - - [Scaling](#scaling) - - [Configuration Updates](#configuration-updates) - - [Security](#security) - - [Upgrades](#upgrades) - - [Monitoring](#monitoring) - - [Adoption](#adoption) - - [Multitenancy Management](#multitenancy-management) - - [Disaster Recovery](#disaster-recovery) - - [Operator of Management Cluster](#operator-of-management-cluster) - - [Versioning and Upgrades](#versioning-and-upgrades) - - [Removing Cluster API](#removing-cluster-api) - - [Cross-cluster Metrics](#cross-cluster-metrics) - - [Specific Architecture Approaches](#specific-architecture-approaches) - - [Multitenancy Management](#multitenancy-management-1) - - [Multi-cluster/Multi-provider](#multi-clustermulti-provider) - - [Managing Providers](#managing-providers) - - [Creating Workload Clusters](#creating-workload-clusters) - - [Provider Implementors](#provider-implementors) - - [Cluster Health Checking](#cluster-health-checking) - - - -# Cluster API Reference Use Cases - -This is a living document that serves as a reference and a staging area for use cases collected from the community during post-v1alpha1 project redesign. - -## Role Glossary -- __User__: consumer of a Kubernetes-conformant cluster created by the Cluster API. - - Does not use Cluster API. -- __Operator__: Administrator responsible for creating and managing a Kubernetes cluster deployed by Cluster API. - - Uses Cluster API. -- __Multi-cluster operator__: An operator responsible for multiple Kubernetes clusters deployed by Cluster API. - - Uses Cluster API. - - Cares about keeping config similar between many clusters. - - -## Icon Glossary -- 🔭 Out of Scope for Cluster API itself, but should be possible via higher level tool. - - These are use-cases that we should take care not to prevent. - -## Operator of Workload Cluster - -### Creating Clusters - -- As an operator, given that I have a cluster running Cluster API, I want to be able to use declarative APIs to manage another Kubernetes cluster (create, upgrade, scale, delete). - -- As an operator, given that I have a cluster running Cluster API, I want to be able to use declarative APIs to manage a vendor’s Kubernetes conformant cluster (create, upgrade, scale, delete). - -- As an operator, when I create a new cluster using Cluster API, I want Cluster API to automatically create and manage any supporting provider infrastructure needed for my new cluster to function. - -- As an operator, when I create a new cluster using Cluster API, I want to be able to use existing infrastructure (e.g. VPC’s, SecurityGroups, veth, GPUs). - -- 🔭 As an operator, when I create a new cluster using Cluster API, I want to be able to take advantage of resource aware topology (e.g. compute, device availability, etc.) to place machines. - -- As an operator, I need to have a way to make minor customizations before kubelet starts while using a standard node image and standard boot script. Example: write a file, disable hyperthreading, load a kernel module. - -- As an operator, I need to have a way to apply labels to Nodes created through ClusterAPI. This will allow me to partition workloads across Nodes/Machines and MachineDeployments. Examples of labels include datacenter, subnet, and hypervisor, which applications can use in affinity policies. - -- As an operator, I want to be able to provision the nodes of a workload cluster on an existing vnet that I don’t have admin control of. - -### Staged Adoption of Cluster API By Operators - -- As an operator, I would like to use some features of Cluster API without using all features of Cluster API. - -- As an operator, given that I have a management cluster and a pre-existing control plane, I would like to manage the lifecycle of a group of worker nodes without managing the control plane those nodes join. - -### Deleting Clusters - -- As an operator, when I delete a Cluster object, I want Cluster API to delete all the infrastructure it created for that cluster. - -- As an operator, when I delete a Machine object, I want Cluster API to gracefully shutdown (drain) that Node and delete all the infrastructure it created for that Machine. - -### Scaling - -- As an operator, given that I have deployed a cluster using Cluster API, I want to configure the cluster-autoscaler to drive scaling operations. - -- As an operator, given that I have a management cluster and a workload cluster, I want to retrieve, set, and change the number of worker Nodes or control plane Nodes in my workload cluster. - -- As an operator, given I have a management cluster and a workload cluster, I want to control the sizing, scaling, and optimizing of the workload cluster’s control plane in terms of Kubernetes primitives (e.g. HPA, VPA, resource limits, etc). I would like to import the best practices, sizing metrics and knowledge from e.g. the specialized SIG Scalability; the information should be expressed uniformly in Kubernetes terms. - -- As an operator, I expect the Cluster API to maintain the number and type of Nodes that I have currently requested as members of the cluster. - -### Configuration Updates - -- As an operator, given that I have a management cluster and a workload cluster, I want to update the IaaS credentials used to lifecycle manage my workload cluster because the correct credentials have changed. - -- As an operator, given I have a management cluster and a workload cluster, I want to apply configuration changes before kubelet starts. - -- As an operator, given that I have deployed a workload cluster via Cluster API, I want to change config in my workload cluster for which Cluster API is authoritative and have a Cluster API controller manage the deployment of that new configuration over the workload cluster. - -- As an operator, given that I have deployed a workload cluster via Cluster API and used Cluster API controller to manage the deployment of a new (broken) configuration, I want to revert to the previous working configuration. - -- As an operator, I want to declare the attributes (os, kernel, CRI) of the nodes I want my workload to run on. The CAPI provider/controller should select an appropriate image that satisfies my constraints/attributes. - - If the provider does not support the attributes I have specified or find an appropriate image it should fail with an appropriate error. - -### Security - -- As an operator, given I have a management cluster and a workload cluster, I want to know when my cluster’s/machines’ certificates will expire, so that I can plan to rotate them. - -- As an operator, given I have a management cluster and a workload cluster, I want to automatically, periodically repave all the nodes of my cluster to reduce the risk of unauthorized software running on my machines. - -- As an operator, I want an external CA to sign certificates for the workload cluster control plane. - -- 🔭As an operator, given I have a management cluster and a workload cluster, I want to rotate all the certificates and credentials my machines are using. - - Some certificates might get rotated as part of machine upgrade, but are otherwise the above is out of scope. - -- 🔭 As an operator, given I have a management cluster and a workload cluster, I want to rotate/change the CA used to sign certificates for my workload cluster. - -- 🔭 As an operator, I want an external CA to sign certificates for workload cluster kubelets. - -### Upgrades -- As an operator, given I have a management cluster and a workload cluster, I want to patch the OS running on all of my machines (e.g. for a CVE). - -- As an operator, given I have a management cluster and a workload cluster, I want to upgrade my workload cluster (control plane and nodes) to a new version of kubernetes. I want the workload cluster control plane to be available during the upgrade. - -- As an operator, given I have a management cluster and a workload cluster, I want to upgrade my workload cluster control plane to a new version of Kubernetes and also update my etcd version at the same time. I want to know in advance if the upgrade will require control plane downtime. - -- As an operator, given I have a management cluster and a workload cluster, I want to upgrade the version of CNI plugin and network daemon that my workload cluster is using. I want to know in advance if the upgrade could cause application downtime. - -- 🔭 As an operator, given I have a management cluster and a workload cluster, I want to upgrade my workload cluster to a new version of etcd without upgrading the Kubernetes control plane. I want to know in advance if the upgrade will require control plane downtime. - -### Monitoring -- 🔭 As an operator, given I have a management cluster and a workload cluster, I want to retrieve metrics about the underlying machines (e.g. CPU usage, memory) in the workload cluster. - -- 🔭 As an operator, given I have a management cluster, a workload cluster, and permission to open interactive shells on that workload cluster, I want to open an interactive shell on the machines in my workload cluster. - -- 🔭 As an operator, given I have a management cluster and a workload cluster, I want to monitor the cleanup of persistent disks/volumes used by my workload cluster. - -- 🔭 As an operator, given I have a management cluster and a workload cluster, I want to monitor the cleanup of created by my workload cluster. - -- 🔭 As an operator, given I have a management cluster and a workload cluster, I want to ensure the etcd database in my workload cluster is backed up. - -### Adoption -- 🔭 As an operator, given I have created a Kubernetes-conformant cluster without ClusterAPI, I want to use ClusterAPI to manage it. In order to do so, I need to know the requirements for adopting/importing this cluster in terms of required CRD’s and operators (e.g Machine and Cluster objects). - -### Multitenancy Management -- 🔭 As an operator, given I have a management cluster and a workload cluster, I want to setup roles, role bindings, users, and usage quotas on my workload cluster. - -### Disaster Recovery -- 🔭As an operator, I want to be able to recover from the complete loss of all the control plane replicas of a workload cluster. This excludes etcd. - -- 🔭As an operator, I want to be able to recover the etcd cluster of a workload cluster from an irrecoverable failure. I will provide the etcd snapshot required by the recovery mechanism. - -## Operator of Management Cluster - -- As an operator, given I have a Kubernetes-conformant cluster, I would like to install Cluster API and a provider on it in a straight-forward process. - -- As an operator, given I have a management cluster that was deployed by Cluster API (via the pivot workflow), I want to manage the lifecycle of my management cluster using Cluster API. - -- As an operator, given I am following the instructions in the Cluster API (/provider) README, I expect the instructions to work and that I will end up with a working management cluster. - -### Versioning and Upgrades -- As an operator, when I choose a version of Cluster API and provider to use, I want to know what version(s) of Kubernetes and other software (CNI, docker, OS, etc) can be managed by a specific Cluster API and/or provider version. - -- As an operator of a management cluster, given that I have a cluster running Cluster API, I would like to upgrade the Cluster API and provider(s) without the users of Cluster API noticing (e.g. due to their API requests not working). - -- As an operator of a management cluster, I want to know what versions of kubelet, control plane, OS, etc, all of the associated workload clusters are running, so that I can plan upgrades to the management cluster that will not break anyone’s ability to manage their workload clusters. - -### Removing Cluster API -- As an operator of a management cluster, given that I have a management cluster that I have used to deploy several workload clusters, I want to remove the Cluster/Machine objects representing one workload cluster from my management cluster without deprovisioning workload cluster. - -- As an operator of a management cluster, given that I have a management cluster that I have used to deploy several workload clusters, I want to uninstall Cluster API from my management cluster without deprovisioning my workload clusters. - -- As an operator of a management cluster, given that I have a management cluster, I want to use it to manage workload clusters that were created by a different management cluster. - -### Cross-cluster Metrics -- As an operator of a management cluster, I want to query my resource allocation on an infrastructure. For example, in an on-prem case, I do not have an infinite capacity cloud, so I need to be able to determine my reservation before deploying a workload cluster. - -### Specific Architecture Approaches -- As an operator of a management cluster, given that I give operators of workload clusters access to my management cluster, they can launch new workload clusters with control planes that run in the management cluster while the nodes of those workload clusters run elsewhere. - -- As a multi-cluster operator, I would like to provide an EKS-like experience in which the workload control plane nodes are joined to the management cluster and the control plane config isn’t exposed to the consumer of the workload cluster. This enables me as an operator to manage the control plane nodes for all clusters using tooling like prometheus and fluentd. I can also control the configuration of the workload control plane in accordance with business policy. - -### Multitenancy Management -- As an operator of a management cluster, I want to control which users of management cluster can deploy new workload clusters, how many clusters they can deploy, and how many nodes/resources those clusters can use. - -- As an operator of a management cluster, I want to ensure that only the user who creates a new workload cluster (and some specific other users) can manage and access the workload cluster. - -- As an operator of a management cluster, I want the user who creates a new workload cluster to be able to give permission to other users to manage that cluster. - -- As an operator of a management cluster, I want to configure whether operators of workload clusters are allowed to open interactive shells onto those clusters machines. - -## Multi-cluster/Multi-provider - -### Managing Providers -- As an operator, given I have a management cluster with at least one provider, I would like to install a new provider. - -- As an operator, given I have a management cluster with at least one provider, I would like to remove one of those providers and orphan any clusters provisioned by that provider. - -- As a multi-cluster operator, given that I have a single management cluster and that I have installed multiple providers and that one of those providers is malicious, I want that provider not to see IaaS secrets provided to any of the other providers. - -- As an operator, if I have a management cluster running a particular Cluster API version and a particular set of providers, then I want to plan an upgrade of Cluster API and the providers so that I upgrade one at a time and always end up with a compatible set of versions. - -### Creating Workload Clusters -- As a multi-cluster operator, given that I have a management cluster, I want to create workload clusters across multiple providers with a consistent interface. For example, if I can create clusters on AWS without any manual intervention, I should have the same level of automation and lack of gotchas when using the VSphere provider. - -- As a multi-cluster operator, given that I have a management cluster, I want to create workload clusters across multiple providers that are all similarly configured. - -- As a multi-cluster operator, given that I have deployed my clusters via Cluster API, I want to find general information (name, status, access details) about my clusters across multiple providers. - -- As a multi-cluster operator, I want to know what versions of Kubernetes all of my workload clusters are running across multiple providers. - -- As a multi-cluster operator, given that I deploy workload clusters via several providers, I want to see a health and status summary from different providers. The detailed information can be provider specific, but a general, common status for generic phases must be given. - -- As a multi-cluster operator, given that I have deployed my clusters via Cluster API, I want to view the configuration of all my clusters across multiple providers. - -- As a multi-cluster operator, given that I have a single management cluster and that I have installed multiple providers, I want to lifecycle manage multiple workload clusters on each installed provider. - -### Provider Implementors -- As a provider, I want the machine controller to reconcile a Machine in response to an event from some other resource in the cluster. This is the sort of thing that other controllers do on a regular basis, so that's nothing particularly interesting. But having made a machine actuator, there's not an easy way to get access to the machine controller object in order to call its Watch method. - -## Cluster Health Checking - -Cluster Health Checking is a service to provide the health status of Kubernetes cluster and its components. - -- As an operator, given I have created a Kubernetes-conformant cluster with ClusterAPI, I want to check the Kubernetes cluster node status. - - Describe nodes and provide details if they are ready/healthy or not ready/healthy. - - List conditions for any nodes which are `NotReady`, list information about allocated resources. - -- As an operator, given I have created a Kubernetes-conformant cluster with ClusterAPI, I want to check the kube-apiserver status. - -- As an operator, given I have created a Kubernetes-conformant cluster with ClusterAPI, I want to check the etcd status. - -- 🔭 As an operator, given I have created a Kubernetes-conformant cluster with ClusterAPI, I want to check the Kubernetes components status, like ingress controller, other add-on components etc. - -- 🔭 As an operator, given I have created a Kubernetes-conformant cluster with ClusterAPI, I want to check unhealthy Pods statuses in configured namespace. - - Provide the details on any pods which are unhealthy in `kube-system` namespace. Filter the unhealthy pods for their status(`kubectl get pods --show-labels -n kube-system | grep -vE "Running|Completed"`) - - Describe any Pods which are not `Completed|Running`, list the Events to provide hints on the failure. - - Look for Pods which don't have all of their containers running. diff --git a/hack/generate-doctoc.sh b/hack/generate-doctoc.sh index d4b8ee40ac54..30fbbe5c9130 100755 --- a/hack/generate-doctoc.sh +++ b/hack/generate-doctoc.sh @@ -28,4 +28,4 @@ if [[ -z "$(command -v doctoc)" ]]; then exit 0 fi -doctoc ./CONTRIBUTING.md docs/release/release-tasks.md docs/release/release-team-onboarding.md docs/release/release-team.md docs/scope-and-objectives.md docs/staging-use-cases.md docs/proposals +doctoc ./CONTRIBUTING.md docs/release/release-tasks.md docs/release/release-team-onboarding.md docs/release/release-team.md docs/proposals