Merge "Update document docker provider(capd)"

This commit is contained in:
Zuul 2021-04-08 13:11:32 +00:00 committed by Gerrit Code Review
commit d4ca04ffae

View File

@ -3,18 +3,14 @@
## Overview ## Overview
This document demonstrates usage of airshipctl to create kubernetes clusters This document demonstrates usage of airshipctl to create kubernetes clusters
locally using docker and kind. locally using docker and kind. Airshipctl requires an existing kubernetes cluster
accessible via kubectl. We will use kind as a local bootstrap cluster, to provision
Airshipctl requires an existing Kubernetes cluster accessible via kubectl. a target management cluster on the docker infrastructure provider.
We will use kind as a local bootstrap cluster, to provision a target management The target management cluster will then be used to create a workload cluster
cluster on the docker infrastructure provider. The target management cluster with one or more worker nodes.
will then be used to create a workload cluster with one or more worker nodes.
## Workflow ## Workflow
Below are the steps that we will go through to create the kubernetes clusters
locally using docker and kind.
- create a single node kubernetes cluster using kind - create a single node kubernetes cluster using kind
- initialize the kind cluster with cluster api management components - initialize the kind cluster with cluster api management components
- use the kind management cluster to create a target cluster with one control - use the kind management cluster to create a target cluster with one control
@ -29,29 +25,31 @@ locally using docker and kind.
## Airshipctl Commands Used And Purpose ## Airshipctl Commands Used And Purpose
`Pull documents from the remote git repository` ```
Pull documents from the remote git repository
> airshipctl document pull > airshipctl document pull
`Initialize the kind cluster with cluster api and docker provider components` Initialize the kind cluster with cluster api and docker provider components
> airshipctl phase run clusterctl-init-ephemeral > airshipctl phase run clusterctl-init-ephemeral
`Use the management cluster to create a target cluster with one control plane` Use the management cluster to create a target cluster with one control plane
> airshipctl phase run controlplane-ephemeral > airshipctl phase run controlplane-ephemeral
`Get multiple contexts for every cluster in the airship site` Get multiple contexts for every cluster in the airship site
> airshipctl cluster get-kubeconfig > ~/.airship/kubeconfig-tmp > airshipctl cluster get-kubeconfig > ~/.airship/kubeconfig-tmp
`Initialize CNI on target cluster` Initialize CNI on target cluster`
> airshipctl phase run initinfra-networking-target > airshipctl phase run initinfra-networking-target
`Initialize Target Cluster with cluster api and docker proivder components` Initialize Target Cluster with cluster api and docker proivder components
> airshipctl phase run clusterctl-init-target > airshipctl phase run clusterctl-init-target
`Move managment CRDs from kind management cluster to target management cluster` Move managment CRDs from kind management cluster to target management cluster
> airshipctl phase run clusterctl-move > airshipctl phase run clusterctl-move
`Use target management cluster to deploy workers` Use target management cluster to deploy workers
> airshipctl phase run workers-target > airshipctl phase run workers-target
```
## Getting Started ## Getting Started
@ -111,20 +109,17 @@ $ export KIND_EXPERIMENTAL_DOCKER_NETWORK=bridge
$ export KUBECONFIG="${HOME}/.airship/kubeconfig" $ export KUBECONFIG="${HOME}/.airship/kubeconfig"
<<<<<<< HEAD $ kind create cluster --name ephemeral-cluster --wait 120s \
$ kind create cluster --name ephemeral-cluster --wait 120s --kubeconfig \ --kubeconfig "${HOME}/.airship/kubeconfig" \
"${HOME}/.airship/kubeconfig" \
--config ./tools/deployment/templates/kind-cluster-with-extramounts --config ./tools/deployment/templates/kind-cluster-with-extramounts
=======
```
Context: kind-capi-docker
manifest: docker_manifest
>>>>>>> Remove NameInKubeconf field from Context struct
$ kubectl config set-context ephemeral-cluster \ $ kubectl config set-context ephemeral-cluster \
--cluster kind-ephemeral-cluster \ --cluster kind-ephemeral-cluster \
--user kind-ephemeral-cluster --kubeconfig $KUBECONFIG --user kind-ephemeral-cluster --kubeconfig $KUBECONFIG
$ kubectl config set-context target-cluster --user target-cluster-admin \
--cluster target-cluster --kubeconfig $KUBECONFIG
$ airshipctl document pull -n --debug $ airshipctl document pull -n --debug
$ airshipctl phase run clusterctl-init-ephemeral --debug --wait-timeout 300s $ airshipctl phase run clusterctl-init-ephemeral --debug --wait-timeout 300s
@ -144,15 +139,11 @@ $ kubectl get nodes --context target-cluster -A
``` ```
`Note: Note: Please take note of the control plane node name from the output of previous
Please take note of the control plane node name because it is untainted command because it is untainted in the next step. For eg. control plane node
in the next step. name could be something like target-cluster-control-plane-twwsv
For eg. control plane node name could be something like
target-cluster-control-plane-twwsv
`
``` ```
$ kubectl taint node target-cluster-control-plane-twwsv \ $ kubectl taint node target-cluster-control-plane-twwsv \
node-role.kubernetes.io/master- --context target-cluster --request-timeout 10s node-role.kubernetes.io/master- --context target-cluster --request-timeout 10s
@ -160,7 +151,7 @@ $ airshipctl phase run clusterctl-init-target --debug --wait-timeout 300s
$ kubectl get pods -A --context target-cluster $ kubectl get pods -A --context target-cluster
$ airshipctl phase run clusterctl-move --debug --progress $ airshipctl phase run clusterctl-move --debug
$ kubectl get machines --context target-cluster $ kubectl get machines --context target-cluster