Инсталляция ArgoCD на Kind с помощью Helm


Делаю:
2026.01.20


Взято в книге: [Book][Andrew Block, Christian Hernandez] Argo CD: Up and Running: A Hands-On Guide to GitOps and Kubernetes [ENG, 2025]


Установить Argo CD CLI


Запустить kind

$ cat <<EOF | kind create cluster --config=-
kind: Cluster
apiVersion: kind.x-k8s.io/v1alpha4
nodes:
- role: control-plane
  kubeadmConfigPatches:
  - |
    kind: InitConfiguration
    nodeRegistration:
      kubeletExtraArgs:
        node-labels: "ingress-ready=true"
  extraPortMappings:
    - containerPort: 80
      hostPort: 80
      protocol: TCP
    - containerPort: 443
      hostPort: 443
      protocol: TCP
EOF


$ kubectl get nodes
NAME                 STATUS   ROLES           AGE   VERSION
kind-control-plane   Ready    control-plane   55s   v1.34.0


$ helm repo add ingress-nginx https://kubernetes.github.io/ingress-nginx
$ helm repo update


$ cd ~/tmp


$ cat > values-ingress-nginx.yaml <<EOF
controller:
  service:
    type: NodePort
  hostPort:
    enabled: true
  updateStrategy:
    type: Recreate
EOF


$ helm install ingress-nginx ingress-nginx/ingress-nginx \
  --namespace ingress-nginx \
  --create-namespace \
  --values values-ingress-nginx.yaml


// Дожидаемся, что нужные поды запустятся
$ kubectl wait --namespace ingress-nginx \
  --for=condition=ready pod \
  --selector=app.kubernetes.io/component=controller \
  --timeout=90s


$ kubectl get pods -n ingress-nginx
NAME                                       READY   STATUS    RESTARTS   AGE
ingress-nginx-controller-c98c9b6d4-gs5rz   1/1     Running   0          67s


$ kubectl get svc -n ingress-nginx
NAME                                 TYPE        CLUSTER-IP      EXTERNAL-IP   PORT(S)                      AGE
ingress-nginx-controller             NodePort    10.96.27.157    <none>        80:31117/TCP,443:30497/TCP   2m6s
ingress-nginx-controller-admission   ClusterIP   10.96.244.156   <none>        443/TCP                      2m6s


// OK!
$ curl http://127.0.0.1
<html>
<head><title>404 Not Found</title></head>
<body>
<center><h1>404 Not Found</h1></center>
<hr><center>nginx</center>
</body>
</html>


$ cat > values-argocd-ingress.yaml <<EOF
server:
  ingress:
    enabled: true
    hostname: argocd.k8s.local
    ingressClassName: nginx
  extraArgs:
  - --insecure
EOF


$ helm upgrade -i argo-cd argo/argo-cd \
  --namespace argocd \
  --create-namespace \
  --values values-argocd-ingress.yaml \
  --version 9.2.4


$ kubectl get pods -n argocd
NAME                                                        READY   STATUS    RESTARTS   AGE
argo-cd-argocd-application-controller-0                     1/1     Running   0          10m
argo-cd-argocd-applicationset-controller-586d475675-ch7zs   1/1     Running   0          10m
argo-cd-argocd-dex-server-949d55f49-lrjzw                   1/1     Running   0          10m
argo-cd-argocd-notifications-controller-78c4879795-hl9k2    1/1     Running   0          10m
argo-cd-argocd-redis-9b58f4d5c-jd7dn                        1/1     Running   0          10m
argo-cd-argocd-repo-server-bfc967df4-5lrzv                  1/1     Running   0          10m
argo-cd-argocd-server-678b78f468-j5dkb                      1/1     Running   0          10m


$ kubectl get ingress -n argocd
NAME                    CLASS   HOSTS              ADDRESS   PORTS   AGE
argo-cd-argocd-server   nginx   argocd.k8s.local             80      2s


// Добавить в hosts
$ echo "127.0.0.1 argocd.k8s.local" | sudo tee -a /etc/hosts


$ export ARGOCD_PASSWORD=$(kubectl -n argocd get secret argocd-initial-admin-secret -o jsonpath="{.data.password}" | base64 -d)
$ echo ${ARGOCD_PASSWORD}


$ argocd login argocd.k8s.local \
    --insecure \
    --username admin \
    --password $ARGOCD_PASSWORD \
    --grpc-web


$ ARGOCD_PASSWORD_NEW_PASSWORD=ABCDEFGH123
$ argocd account update-password \
    --current-password ${ARGOCD_PASSWORD} \
    --new-password ${ARGOCD_PASSWORD_NEW_PASSWORD}
$ ARGOCD_PASSWORD=${ARGOCD_PASSWORD_NEW_PASSWORD}
$ echo ${ARGOCD_PASSWORD}


// OK!
// admin / ABCDEFGH123
http://argocd.k8s.local


$ kubectl get nodes
NAME                 STATUS   ROLES           AGE   VERSION
kind-control-plane   Ready    control-plane   13m   v1.34.0


// Удалить
// $ kind delete cluster