Sebastian Mark
d99b33d669
- rename bootstrap files for clarification - remove project and application from argocd-apps values - add new YAML for project configuration - add new YAML for application configuration |
||
---|---|---|
argocd-bootstrap | ||
bin | ||
manifests | ||
.gitignore | ||
.renovaterc.json | ||
docker-compose.yml | ||
logo.png | ||
README.md |
k3s Kubernetes + Baseline
- k3s
- ArgoCD
- NGINX Ingress Controller
- cert-manager
- selfsigned issuer
- LetsEncrypt issuers (Prod and Staging)
- zabbix-proxy
- keel
- reloader
Run (k3s + baseline)
docker compose up
Get kubeconfig
docker compose exec -it k3s kubectl config view --flatten
Notes
ArgoCD
To retrieve the initial admin password use
kubectl -n argocd get secret argocd-initial-admin-secret -o jsonpath="{.data.password}" | base64 -d
To change the password follow Argocd account update password.
Sync Applications with Kubectl
Add to application:
operation:
sync:
syncStrategy:
hook: {}
Zabbix Monitoring
See: infrastructure/zabbix-config - Zabbix Kubernetes Monitoring
Cloud Setups
Linode
PROXY protocol needs to be enabled for ingress-nginx to see the clients IP in ingress log.
Add the PROXY protocol annotation to the ingress-nginx service:
annotations:
service.beta.kubernetes.io/linode-loadbalancer-proxy-protocol: v2
Update the ingress-nginx ConfigMap to make nginx expect PROXY protocol data:
data:
use-proxy-protocol: "true"
cert-manager
However, when you have the PROXY protocol enabled, the external load balancer does modify the traffic, prepending the PROXY line before each TCP connection. If you connect directly to the web server internally, bypassing the external load balancer, then it will receive traffic without the PROXY line.
This is particularly a problem when using cert-manager for provisioning SSL certificates.
After enabling the PROXY protocol cert-manager is unable to perform a self check ("propagation check failed", "failed to perform self check GET request").
hairpin-proxy adds PROXY protocol support for internal-to-LoadBalancer traffic for Kubernetes Ingress users, specifically for cert-manager self-checks (no further configuration needed).