【Devops】ArgoCD实战

argocd

官网:
https://argo-cd.readthedocs.io/en/stable/#getting-started

整体发布流程如图所示
用户提交 应用发布文件(k8s manifest yaml / helm / kustomize 等)到 git 仓库(gitlab/github 等)
argocd 监听 git 仓库的文件变化,根据配置手动或者自动把应用发布文件同步变更到 k8s 集群中

在这里插入图片描述

创建名称空间,下载yaml文件

kubectl create ns argo
//在安装yaml文件的目录下,执行
kubectl apply -n argo -f .

本地访问Argocd

我们将 argo-ui 改成 NodePort 类型的 Service(当然也可以创建 Ingress 对象通过域名进行访问、port_forward等方式)

[10:28:21] yang :: lucky ➜ ~ » kubectl edit svc -n argocd argocd-server -oyaml

apiVersion: v1
kind: Service
metadata:
  annotations:
    kubectl.kubernetes.io/last-applied-configuration: |
      {"apiVersion":"v1","kind":"Service","metadata":{"annotations":{},"labels":{"app.kubernetes.io/component":"server","app.kubernetes.io/name":"argocd-server","app.kubernetes.io/part-of":"argocd"},"name":"argocd-server","namespace":"argocd"},"spec":{"ports":[{"name":"http","port":80,"protocol":"TCP","targetPort":8080},{"name":"https","port":443,"protocol":"TCP","targetPort":8080}],"selector":{"app.kubernetes.io/name":"argocd-server"}}}
  creationTimestamp: "2022-04-25T02:17:13Z"
  labels:
    app.kubernetes.io/component: server
    app.kubernetes.io/name: argocd-server
    app.kubernetes.io/part-of: argocd
  name: argocd-server
  namespace: argocd
  resourceVersion: "165890"
  uid: f0adb693-08f3-43c8-86c0-e047959d037b
spec:
  clusterIP: 10.109.64.172
  clusterIPs:
  - 10.109.64.172
  externalTrafficPolicy: Cluster
  ipFamilies:
  - IPv4
  ipFamilyPolicy: SingleStack
  ports:
  - name: http
    nodePort: 32337
    port: 80
    protocol: TCP
    targetPort: 8080
  - name: https
    nodePort: 30069
    port: 443
    protocol: TCP
    targetPort: 8080
  selector:
    app.kubernetes.io/name: argocd-server
  sessionAffinity: None
  type: NodePort
status:
  loadBalancer: {}
[10:37:30] yang :: lucky  ➜  ~ » kubectl get svc -n argocd argocd-server
NAME            TYPE       CLUSTER-IP      EXTERNAL-IP   PORT(S)                      AGE
argocd-server   NodePort   10.109.64.172   <none>        80:32337/TCP,443:30069/TCP   25m

在浏览器访问 http://127.0.0.1:30069

在这里插入图片描述

// 查看 argocd 默认密码(argocd 1.9 以后的版本,参考:https://argoproj.github.io/argo-cd/faq/#i-forgot-the-admin-password-how-do-i-reset-it)
# kubectl -n argocd get secret argocd-initial-admin-secret -o jsonpath="{.data.password}" | base64 -d
pVLydNUWOOwiSxJm
// 更改 admin 密码
// 先到 https://www.browserling.com/tools/bcrypt 生成 bcrypt 字符串,比如 123456 就是 $2a$10$O8NqwiyZY0Yl8LyteZyJf.4XYBIFBlUHT0kmFR9jrs1a1HwDgyAFK
// 替换为下面的 admin.password 的值
kubectl -n argocd patch secret argocd-secret \
  -p '{"stringData": {
    "admin.password": "$2a$10$O8NqwiyZY0Yl8LyteZyJf.4XYBIFBlUHT0kmFR9jrs1a1HwDgyAFK",
    "admin.passwordMtime": "'$(date +%FT%T%Z)'"
  }}'

访问 argocd web 页面,输入账号 admin 和 密码 123456 就可以登录了

怎么部署服务

添加代码仓库

https://gitee.com/why777/py-k8s
在这里插入图片描述

请添加图片描述

添加project

在这里插入图片描述

发布成功后的状态
在页面上可以看到各个资源的状态、配置、以及关联关系

在这里插入图片描述

能看pod日志,事件,yaml等,算是一个简单版本的k8s dashboard

在这里插入图片描述

其他

如果项目有 configmap、ingress 等其他资源也是差不多的发布流程

容器镜像要提前通过 CI 流程打包到镜像仓库,发布时更改对应项目 git 仓库里 deployment 的 image 版本即可

参考:
https://argo-cd.readthedocs.io/en/stable/getting_started/
https://www.jianshu.com/p/3e9ca0c2668b
https://www.kancloud.cn/willseecloud/jenkins/2424038
https://kubeoperator.io/docs/user_manual/argocd/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Rancher是一种用于DevOps实践的开源平台。它为开发人员和运维团队提供了一个统一的界面来管理和部署容器化应用程序。通过Rancher,团队可以轻松地创建和管理多个Kubernetes集群,使其更加便捷和高效。 Rancher的主要功能包括: 1. 集群管理:Rancher可以方便地创建和管理多个Kubernetes集群。团队可以根据需要创建新的集群,并监控和管理现有集群的状态和健康状况。 2. 应用程序管理:Rancher提供了一个直观的用户界面,使开发人员和运维人员能够轻松地部署、扩展和更新容器化应用程序。它还可以自动处理应用程序的健康检查和自动缩放等任务。 3. 基础设施管理:Rancher支持多个云平台和虚拟化平台,包括AWS、Azure、OpenStack和VMware等。这使得团队可以轻松地在不同的基础设施上创建和管理容器化应用程序。 4. 安全监控:Rancher提供了一套全面的安全功能,包括基于角色的访问控制、容器网络隔离和系统审计等。这有助于保护应用程序的安全,并确保整个平台的稳定和可靠性。 5. DevOps集成:Rancher与常用的DevOps工具和技术集成,如CI/CD工具、日志收集系统和监控系统等。这使得团队可以无缝地将Rancher与现有的工作流程和工具集成在一起,实现端到端的DevOps流程。 总之,Rancher是一种非常实用和强大的DevOps工具,它提供了一种简单而高效的方式来管理和部署容器化应用程序。通过Rancher,团队可以更好地协作和交付高质量的软件,从而实现快速迭代和持续交付的目标。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值