-
Notifications
You must be signed in to change notification settings - Fork 2
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Simple docker registry is deployed to the kind cluster as OCI Helm registry, exposed to the local machine with the NodePort on 30500 - Added docker daemon installation on Linux-based systems - Added notes about `make help` to the README.md - Added docs with detailed explanation for General setup steps - Fixed helm package bug with missing templates directory (added .gitkeep files)
- Loading branch information
Iaroslav Ivchenkov
committed
Dec 30, 2024
1 parent
6e86365
commit 633cbe8
Showing
11 changed files
with
173 additions
and
91 deletions.
There are no files selected for viewing
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,16 @@ | ||
# Bootstrap local management cluster | ||
|
||
To demonstrate the capabilities of the 2A platform, we need to create a [management kubernetes cluster](https://mirantis.github.io/project-2a-docs/glossary/#management-cluster) through which [managed clusters](https://mirantis.github.io/project-2a-docs/glossary/#managed-cluster) will be deployed and ["beach-headed" services](https://mirantis.github.io/project-2a-docs/glossary/#beach-head-services) will be installed on them. | ||
|
||
For these purposes, we use the [kind utility](https://kind.sigs.k8s.io/), which easily allows you to create a local kubernetes cluster. | ||
Cluster nodes are deployed inside containers, it turns out to be isolated and access for traffic "from the outside" is closed, except for the kubernetes API (to allow kubectl access). Since we will also need a Helm registry for further steps and in order to have access to it from our working machine, we will immediately, when creating the cluster, establish a connection from port 30500 of our working machine to port 30500 of kind cluster nodes. This port will later be used for a Helm registry NodePort service. You can find the kind cluster configuration at [setup/kind-cluster.yaml](../setup/kind-cluster.yaml). | ||
|
||
By default, kind cluster has the `hmc-management-local` name and it can be changed with the `KIND_CLUSTER_NAME` environment variable. | ||
|
||
## Prerequisites | ||
|
||
The `make bootstrap-kind-cluster` command makes several checks before running the command that creates the cluster: | ||
|
||
1. If Docker Engine is not installed on your machine, the binary will be installed for Linux-based OS and the error with the documentation link printed for Darwin OS. By default, the `27.4.1` Docker Engine version will be installed for Linux OS and it can be changed with the `DOCKER_VERSION` environment variable. | ||
2. If `kind` binary is not detected on your machine, the one will be downloaded, installed in the `<local-repo-path>/bin` directory and be used during the whole demo. By default, will be installed kind version `0.25.0` and it can be changed with the `KIND_VERSION` environment variable. | ||
3. If `kubectl` binary is not detected on your machine, it will be downloaded, installed in the `<local-repo-path>/bin` directory and be used during the whole. The latest stable version of `kubectl` will be installed. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
# 2A Deploy | ||
|
||
2A is deployed using the Helm chart on top of the management kubernetes cluster. It installs required CRDs, hmc kubernetes operator and a couple of common utilities. However, when Helm chart is successfully deployed, 2A is not ready to be used at the moment. HMC operator starts the reconciliation process that installs [CAPI](https://cluster-api.sigs.k8s.io/), different cloud providers, default built-in cluster and service templates, etc. | ||
|
||
To get the information about 2A platform readiness you can run this command: | ||
|
||
```shell | ||
PATH=$PATH:./bin kubectl get management hmc -o go-template='{{range $key, $value := .status.components}}{{$key}}: {{if $value.success}}{{$value.success}}{{else}}{{$value.error}}{{end}}{{"\n"}}{{end}}' | ||
``` | ||
|
||
It checks the `Management` object, which is the HMC custom resource. This object contains requirements on what providers must be installed, the HMC release version, etc. HMC operator reconciles the platform state to satisfy requirements from this object and updates the status. | ||
|
||
You can find detailed information about 2A installation in the [official documentation](https://mirantis.github.io/project-2a-docs/quick-start/2a-installation/). |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,7 @@ | ||
# Deploy and setup Helm registry | ||
|
||
During the demo we want to show how [BYO](https://mirantis.github.io/project-2a-docs/template/byo-templates/) `ClusterTemplate` and `ServiceTemplate` objects can be created and used to provision managed clusters and to install services on top of them. As 2A uses Flux CD, we will package configurations to Helm charts, push them to the Helm registry and use this registry in 2A. | ||
|
||
As a simple OCI Helm registry will be used docker registry, deployed to the kind cluster as pod and exposed with the NodePort service outside of the cluster on the `30500` port. As a result, the Helm registry can be accessed from the local working machine via `oci://127.0.0.1:30500/helm-charts` and `oci://helm-registry:5000/helm-charts` inside the cluster. | ||
|
||
You can find the registry configuration at [./setup/helmRepository.yaml](../setup/helmRepository.yaml). |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,13 +1,69 @@ | ||
apiVersion: source.toolkit.fluxcd.io/v1 | ||
kind: HelmRepository | ||
--- | ||
apiVersion: apps/v1 | ||
kind: Deployment | ||
metadata: | ||
name: 2a-demos | ||
namespace: hmc-system | ||
labels: | ||
hmc.mirantis.com/managed: "true" | ||
name: helm-registry | ||
namespace: $TESTING_NAMESPACE | ||
spec: | ||
insecure: true | ||
interval: 10m0s | ||
provider: generic | ||
type: oci | ||
url: oci://ghcr.io/mirantis/2a-demos/charts | ||
selector: | ||
matchLabels: | ||
run: helm-registry | ||
template: | ||
metadata: | ||
labels: | ||
run: helm-registry | ||
spec: | ||
containers: | ||
- image: registry:2 | ||
name: helm-registry | ||
ports: | ||
- containerPort: $HELM_REGISTRY_INTERNAL_PORT | ||
volumes: | ||
- name: registry-storage | ||
persistentVolumeClaim: | ||
claimName: helm-registry-storage | ||
|
||
--- | ||
apiVersion: v1 | ||
kind: PersistentVolumeClaim | ||
metadata: | ||
name: helm-registry-storage | ||
namespace: $TESTING_NAMESPACE | ||
spec: | ||
accessModes: | ||
- ReadWriteOnce | ||
storageClassName: standard # kind local-path provisioner | ||
resources: | ||
requests: | ||
storage: 50Mi | ||
|
||
--- | ||
apiVersion: v1 | ||
kind: Service | ||
metadata: | ||
name: helm-registry | ||
namespace: $TESTING_NAMESPACE | ||
spec: | ||
type: NodePort | ||
ports: | ||
- port: $HELM_REGISTRY_INTERNAL_PORT | ||
protocol: TCP | ||
targetPort: $HELM_REGISTRY_INTERNAL_PORT | ||
nodePort: $HELM_REGISTRY_EXTERNAL_PORT | ||
selector: | ||
run: helm-registry | ||
|
||
# --- | ||
# apiVersion: source.toolkit.fluxcd.io/v1 | ||
# kind: HelmRepository | ||
# metadata: | ||
# name: 2a-demos | ||
# namespace: $TESTING_NAMESPACE | ||
# labels: | ||
# hmc.mirantis.com/managed: "true" | ||
# spec: | ||
# insecure: true | ||
# interval: 10m0s | ||
# provider: generic | ||
# type: oci | ||
# url: oci://helm-registry.$TESTING_NAMESPACE.svc.cluster.local:5000/helm-charts |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,8 @@ | ||
kind: Cluster | ||
apiVersion: kind.x-k8s.io/v1alpha4 | ||
nodes: | ||
- role: control-plane | ||
extraPortMappings: | ||
- containerPort: $HELM_REGISTRY_EXTERNAL_PORT | ||
hostPort: $HELM_REGISTRY_EXTERNAL_PORT | ||
protocol: TCP |
Empty file.
Empty file.
Empty file.