Resources to get deployed on kubernetes or openshift cluster
The goal of this project is to have a simple way to prepare a kubernetes or openshift cluster with some basic resources/tools for tests, experiments and proof of concepts. It was created to provide the resources to experiment the ArtemisCloud operator but may be used as a general tool to provision cluster resources.
There are also other README.md files which are relevant to the information contained here:
-
tools - tools that are used my during the deployment and help to debug and configuration the cluster resources.
-
manifests - kubernetes manifests used during the deployment or to deploy ArtemisCloud instances
In the targets list below, you will see what can be deployed in the cluster. There is a target that creates a local cluster but this is not a requirement. If you have a remote cluster, since you are logged in it, it will work without issues. If you are running an Openshift cluster there are targets which may not apply, like the ones which deploys olm
and redhat operators catalog
.
The local cluster is created using kind as you will see below. In the kind configuration, kind-config.yaml, there is an extra mount to mount the ${HOME}/.docker/config.json
. This file allows kind to use the registries credentials from docker. As an example, if you are logged in on a private registry like registry.redhat.io
in docker, kind will be able to use images from there. It also expose ports 80, 443 as needed by the ingress-nginx and the port ranges 5000-5009, 5100-51009, 33060-33065, 51510-51519, 52520-52529 to be used by ingress-nginx to expose TCP protocol other than http and https like to expose artemis acceptor without SSL, java remote debugger, mariadb, etc to the host machine. Refer to ingress-ngnix-expose-tcp-port.sh
in tools for more information.
For a local cluster there are also some tips related to ingress on configuring the ingress to work
-
prepare-k8s, ie:
make prepare-k8s
- This target execute most of the targets below. You can see the list of targets in the Makefile under the
PREPARE_K8S_TARGETS
variable. If you want to skip targets, you may executemake prepare-k8s SKIP_TARGETS="target_a target_b"
.
- This target execute most of the targets below. You can see the list of targets in the Makefile under the
-
prepare-ocp, ie:
make prepare-ocp
- This target execute most of the targets below but skips those which should not be needed on an Openshift cluster. You can see the list of targets in the Makefile under the
PREPARE_OCP_TARGETS
variable. If you want to skip targets, you add executemake prepare-ocp SKIP_TARGETS="target_a target_b"
.
- This target execute most of the targets below but skips those which should not be needed on an Openshift cluster. You can see the list of targets in the Makefile under the
-
create-kind, ie:
make create-kind
-
Create kind cluster using the configuration file kind-config.yaml.
-
K8S_VERSION environment variable can be used to define the kubernetes version kind will use. ie:
make create-kind K8S_VERSION=v1.30.0
. If the K8S_VERSION is not provide kind uses the latest version available on for the installed kind version. -
KIND_CLUSTER_NAME environment variable can be used to define the cluster name. It is useful if there is more than one kind cluster on your computer. ie:
make create-kind KIND_CLUSTER_NAME=my-cluster
. It defaults tolocal-k8s
.
-
-
delete-local-cluster, ie:
make delete-kind
- delete the local kind cluster.
-
copy-kind-kubeconfig-to-toolbox, ie:
make copy-kind-kubeconfig-to-toolbox
- copy kind kubeconfig file into toolbox container. This will allow access from the toolbox container into the cluster for tools that use kubeconfig like
kubeclt
.
- copy kind kubeconfig file into toolbox container. This will allow access from the toolbox container into the cluster for tools that use kubeconfig like
-
deploy-ingress-controller, ie:
make deploy-ingress-controller
- Deploy Ingress controller in
ingress-nginx
namespace using ingress-nginx/ingress-nginx helm chart. Please refer to the target in the Makefile to see the options used.
- Deploy Ingress controller in
-
deploy-metrics-server, ie:
make deploy-metrics-server
- Deploy Kubernetes Metric Server in
kube-system
namespace using metrics-server/metrics-server helm chart. This target should not be executed on openshift clusters
- Deploy Kubernetes Metric Server in
-
deploy-olm, ie:
make deploy-olm
-
Deploy Operator Lifecycle Manager (OLM) in
olm
namespace. This target should not be executed on openshift clusters as Openshift already have OLM installed. -
OLM_VERSION environment variable can be used to define the OLM version to install otherwise it will install the latest version from olm github releases
-
-
deploy-cert-manager-operator, ie:
make deploy-cert-manager-operator
- Deploy Cert Manager Operator in in
cert-manager
namespace using jetstack/cert-manager helm chart.
- Deploy Cert Manager Operator in in
-
deploy-trust-manager-operator, ie:
make deploy-trust-manager-operator
- Deploy Trust Manager Operator in
cert-manager
namespace using jetstack/trust-manager helm chart.
- Deploy Trust Manager Operator in
-
deploy-selfsigned-ca, ie:
make deploy-selfsigned-ca
- Deploy a self-signed CA Issuer, a self-signed CA and a CA issuer for the created self-signed CA in the namespace
cert-manager
from here. It also create copy of the self-signed CA to allow rotation of the CA without issues as suggested by cert-manager/trust-manager documentation.
- Deploy a self-signed CA Issuer, a self-signed CA and a CA issuer for the created self-signed CA in the namespace
-
deploy-prometheus, ie:
make deploy-prometheus
- Deploy Prometheus Stack (Prometheus Operator, Prometheus, AlertManager, Node Exporter, Kube State Metrics, Grafana) in
prometheus
namespace using prometheus-community/kube-prometheus-stack helm chart - INGRESS_DOMAIN environment variable can be used to define the ingress domain. It defaults to
localcluster
.
- Deploy Prometheus Stack (Prometheus Operator, Prometheus, AlertManager, Node Exporter, Kube State Metrics, Grafana) in
-
deploy-mariadb-operator-crds, ie:
make deploy-mariadb-operator-crds
- Deploy Mariadb Operator CRDs in
mariadb-operator
namespace using mariadb-operator/mariadb-operator-crds helm chart.
- Deploy Mariadb Operator CRDs in
-
deploy-mariadb-operator, ie:
make deploy-mariadb-operator
- Deploy Mariadb Operator in
mariadb-operator
namespace using mariadb-operator/mariadb-operator helm chart.
- Deploy Mariadb Operator in
-
deploy-mariadb-instance, ie:
make deploy-mariadb-instance
- Deploy Mariadb Instance in
mariadb
namespace using the manifest files from here. It defined the root user password asroot_mariadb
.
- Deploy Mariadb Instance in
-
deploy-toolbox, ie:
make deploy-toolbox
- Deploy toolbox container using tlbueno/toolbox using tlbueno/toolbox helm chart. Toolbox is a simple container image which has a set of tools installed in it.
-
deploy-redhat-operators-catalog, ie:
make deploy-redhat-operators-catalog
-
Deploy RedHat Operators Catalog in
olm
namespace using tlbueno/catalog-source-installer. This target should not be executed on openshift clusters as Openshift already have this package index installed. -
REDHAT_CATALOG_IMAGE
environment variable can be used to specify the catalog index image to be used.
-
-
deploy-artemiscloud-operator, ie:
make deploy-artemiscloud-operator
-
Deploy ArtemisCloud operator using tlbueno/artemiscloud-operator.
-
ARTEMISCLOUD_NAMESPACE
environment variable can be used to specify the namespace to install the operator. Defaults toartemiscloud-operator
. -
ARTEMISCLOUD_LOG_LEVEL
environment variable can be used to set the operator log level. Defaults toinfo
-
ARTEMISCLOUD_WATCH_MODE
environment variable can be used to set the operator watch namespace mode. Defauls toall
-
ARTEMISCLOUD_WATCH_NAMESPACES
environment variable can be used to set the operator namespaces the operator should watch when watch mode ismulti
. The namespaces should be provided as a list with comma as separator, ie: ARTEMISCLOUD_WATCH_NAMESPACES="ns1,ns2,ns3" -
ARTEMISCLOUD_CHART_VERSION
environment variable can be used to set the chart version to install. ArtemisCloud chart version as mapped directly to the opearator version from chart version greater than 1.2.5, ie: chart 1.2.5 install operator version 1.2.5
-
-
deploy-chaos-mesh, ie:
make deploy-chaos-mesh
-
Deploy chaos-mesh using chaos-mesh/chaos-mesh.
-
CHAOS_MESH_CONTAINER_RUNTIME
environment variable can be used to specify the cluster container runtime. It defaults tocontainerd
. Verify chaos mesh documentation for more details. -
CHAOS_MESH_CONTAINER_SOCKET_PATH
environment variable can be used to specify the cluster container runtime socket path. It defaults to/run/containerd/containerd.sock
. Verify chaos mesh documentation for more details.
-
-
configure-inotify, ie:
make configure-inotify
- Configure sysctl inotify values (requires sudo access). This may be need in some cases for some applications run fine inside the kind cluster.
-
add-helm-charts-repos, ie:
make add-helm-charts-repos
- Add helm-charts repos needed by the other targets to helm. May be needed if you are not using the
prepare-k8s
target.
- Add helm-charts repos needed by the other targets to helm. May be needed if you are not using the
-
update-helm-charts-repos, ie:
make update-helm-charts-repos
- Update helm-charts repos. It is useful to get the latest version of charts from the repos. May be needed if you are not using the
prepare-k8s
target.
- Update helm-charts repos. It is useful to get the latest version of charts from the repos. May be needed if you are not using the
-
exec-toolbox, ie:
make exec-toolbox
- Execute a shell in the toolbox container.
-
help, ie:
make help
- Display a simple list of the targets and its description.
To use the ingress usually you need to add the ingress address in /etc/host pointing to the cluster ingress entrypoint. ie, in the kind local cluster, you should point my-app.my-domain to the address 127.0.0.1. If you have multiple ingress addresses it is a boring task to do and manage. Another possible solution is to use an local DNS server to handle it. Below I show the steps to configure the dnsmasq DNS server to handle any subdomain of my main local domain, localcluster
. The configuration was based on Fedora 40 and it may change on other versions or other distributions.
- Install dnsmasq
sudo dnf install dnsmasq
- Create an dnsmasq configuration, configure dnsmasq to start on system boot and start dnsmasq:
cat - <<EOF | sudo tee /etc/dnsmasq.d/00-local.conf
address=/localcluster/127.0.0.1
no-resolv
EOF
sudo systemctl enable dnsmasq.service
sudo systemctl start dnsmasq
- Create an systemd-resolved configuration to forward DNS queries to dnsmasq, restart systemd-resolved:
cat - <<EOF | sudo tee /etc/systemd/resolved.conf
[Resolve]
DNS=127.0.0.1
Domains=~localcluster
EOF
sudo systemctl restart systemd-resolved.service
- Check if it is working by trying to ping or resolve any domain under
localcluster
, ie:
ping this.is.a.test.localcluster -c 2
PING this.is.a.test.localcluster (127.0.0.1) 56(84) bytes of data.
64 bytes from localhost (127.0.0.1): icmp_seq=1 ttl=64 time=0.017 ms
64 bytes from localhost (127.0.0.1): icmp_seq=2 ttl=64 time=0.023 ms
--- this.is.a.test.localcluster ping statistics ---
2 packets transmitted, 2 received, 0% packet loss, time 1021ms
rtt min/avg/max/mdev = 0.017/0.020/0.023/0.003 ms
dig this.is.another.test.localcluster
; <<>> DiG 9.18.26 <<>> this.is.another.test.localcluster
;; global options: +cmd
;; Got answer:
;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 48062
;; flags: qr rd ra; QUERY: 1, ANSWER: 1, AUTHORITY: 0, ADDITIONAL: 1
;; OPT PSEUDOSECTION:
; EDNS: version: 0, flags:; udp: 65494
;; QUESTION SECTION:
;this.is.another.test.localcluster. IN A
;; ANSWER SECTION:
this.is.another.test.localcluster. 0 IN A 127.0.0.1
;; Query time: 1 msec
;; SERVER: 127.0.0.53#53(127.0.0.53) (UDP)
;; WHEN: Fri May 24 08:12:49 -03 2024
;; MSG SIZE rcvd: 74