ArgoCD安装体验

警告
本文最后更新于 2022-07-01,文中内容可能已过时。

Argo CD是用于Kubernetes的声明性GitOps连续交付工具。

img

demo:https://cd.apps.argoproj.io/

应用程序定义,配置和环境应为声明性的,并受版本控制。应用程序部署和生命周期管理应该是自动化的,可审核的且易于理解的。

Argo CD Architecture

Argo CD是作为kubernetes控制器实现的,它持续监控运行中的应用程序,并将当前的活动状态与预期的目标状态进行比较(如Git repo中指定的那样)。如果部署的应用程序的活动状态偏离了目标状态,则被认为是OutOfSync。Argo CD报告和可视化差异,同时提供自动或手动同步实时状态到所需的目标状态的工具。在Git repo中对目标状态所做的任何修改都可以自动应用并反映到指定的目标环境中。

1
2
kubectl create namespace argocd
kubectl apply -n argocd -f https://raw.githubusercontent.com/argoproj/argo-cd/stable/manifests/install.yaml

参考链接:Getting Started

添加helm仓库

1
helm repo add argo https://argoproj.github.io/argo-helm

部署

1
2
3
4
5
6
helm install argocd \
  --namespace=argocd --create-namespace \
  --set global.image.repository="argoproj/argocd" \
  --set dex.image.repository="dexidp/dex" \
  --set server.service.type=LoadBalancer \
  argo/argo-cd

获取admin用户密码

1
kubectl -n argocd get secret argocd-initial-admin-secret -o jsonpath="{.data.password}" | base64 -d

参考链接:Argo Helm Charts

参考链接:CLI installation documentation

1
2
curl -sSL -o /usr/local/bin/argocd https://github.com/argoproj/argo-cd/releases/latest/download/argocd-linux-amd64
chmod +x /usr/local/bin/argocd

修改serivce类型为LoadBalancer

1
kubectl patch svc argocd-server -n argocd -p '{"spec": {"type": "LoadBalancer"}}'

admin帐户的初始密码是自动生成的,并以明文形式存储在Argo CD安装命名空间中名为argocd-initial-admin-secretpassword字段中。你可以使用kubectl简单地检索这个密码:

1
kubectl -n argocd get secret argocd-initial-admin-secret -o jsonpath="{.data.password}" | base64 -d; echo

使用用户名admin和上面的密码,登录到Argo CD的IP地址或主机名:

1
argocd login <ARGOCD_SERVER>

使用如下命令修改密码:

1
argocd account update-password

image-20220309145328326

点击NEW APP创建一个应用

同步策略:Automatic

源可以使用:https://github.com/bwcxyk/gitops-demo.git

https://github.com/argoproj/argocd-example-apps.git

path填写:reversewords/overlays/pro

Cluster URL:默认

Namespace:reverse-words

创建成功即可看到如下

image-20220309151346299