This post will guide you how to install ArgoCD on the kubernetes, along with ingress access and intergrate with third parth authorization.
What is ArgoCD
Argo CD is a declarative, GitOps continuous delivery tool for Kubernetes.
Install
kubectl create namespace argocd
kubectl apply -n argocd -f https://raw.githubusercontent.com/argoproj/argo-cd/stable/manifests/install.yaml
data:image/s3,"s3://crabby-images/cf89e/cf89ebbe44c9a00e864b48e8ed52885cd0fa6fbc" alt="Install ArgoCD on the Kubernetes 1 image"
Configure HTTP/HTTPS ingress for UI
Replace the value of host to a new value.
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
name: argocd-server-http-ingress
namespace: argocd
annotations:
kubernetes.io/ingress.class: "nginx"
nginx.ingress.kubernetes.io/force-ssl-redirect: "true"
nginx.ingress.kubernetes.io/backend-protocol: "HTTP"
spec:
rules:
- http:
paths:
- backend:
serviceName: argocd-server
servicePort: http
host: argocd.example.com
tls:
- hosts:
- argocd.gosysops.com
secretName: argocd-secret # do not change, this is provided by Argo CD
apply the HTTP yaml file
kubectl apply -f argocd-http.yaml
data:image/s3,"s3://crabby-images/fb8bb/fb8bb930e5fd1022bd563fb7f4cdf17799acdc87" alt="Install ArgoCD on the Kubernetes 2 image 1"
Configure GRPC ingress for client CLI access
same above, you need to change the value of host field.
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
name: argocd-server-grpc-ingress
namespace: argocd
annotations:
kubernetes.io/ingress.class: "nginx"
nginx.ingress.kubernetes.io/backend-protocol: "GRPC"
spec:
rules:
- http:
paths:
- backend:
serviceName: argocd-server
servicePort: https
host: grpc.argocd.example.com
tls:
- hosts:
- grpc.argocd.gosysops.com
secretName: argocd-secret # do not change, this is provided by Argo CD
apply grpc ingress
kubectl apply argocd-grpc.yaml
data:image/s3,"s3://crabby-images/3ccbd/3ccbdb669df192b8a7376e5216589c0c5bace4e2" alt="Install ArgoCD on the Kubernetes 3 image 2"
Configure argo-server to allow HTTP
edit argo-server deoployment to add parameters
data:image/s3,"s3://crabby-images/be884/be884c9a1e6c302ad3885e35ad54479eec8aab13" alt="Install ArgoCD on the Kubernetes 4 image 3"
Default Password
For ArgoCD 1.8, the initial password is autogenerated to be the pod name of the ArgoCD API server. This can be retrieved with the command:
kubectl get pods -n argocd -l app.kubernetes.io/name=argocd-server -o name | cut -d'/' -f 2
it won’t be work sometimes, you can re-deployment argocd-server. but the simplest way is to change password with updating config map.
go to the https://www.browserling.com/tools/bcrypt to generate a new hash password.
data:image/s3,"s3://crabby-images/cb0d9/cb0d92a5f41a34d3289388e52a75e2d1643311a7" alt="Install ArgoCD on the Kubernetes 5 image 6"
replace the value of admin.password field and apply it
kubectl -n argocd patch secret argocd-secret \
-p '{"stringData": {
"admin.password": "$2a$10$ejPpkdo5b52Ue5MDi2X4.OdcKzodli4OR15NuMWyAta6RyKjx6FvW",
"admin.passwordMtime": "'$(date +%FT%T%Z)'"
}}'
data:image/s3,"s3://crabby-images/0eeb3/0eeb3b6efe50136831325c340c15adc504a24fbd" alt="Install ArgoCD on the Kubernetes 6 image 7"
Login
data:image/s3,"s3://crabby-images/eea85/eea85732e8bf921b6796d4871285334a3a09b3c8" alt="Install ArgoCD on the Kubernetes 7 image 8"