[yahoon 原创] ArgoCD从内网的GitLab Repo部署应用

简介: 本文将讲解中我的home lab(一个访问受限的环境中),使用ArgoCD 部署一个gitlab repo的全部过程

「本文同步首发于个人博客 yahoon.github.io,原创内容,转载请注明出处」

ArgoCD从内网的GitLab Repo部署应用

本文将讲解中我的home lab(一个访问受限的环境中),使用ArgoCD 部署一个gitlab repo的全部过程

Home lab Env

在home lab中, 有如下服务运行着

GitLab server:

http://192.168.1.4:8080/

K8s Cluster

我有一个3节点的k8s集群: 一个maste,2个node

❯ kubectl cluster-info
Kubernetes control plane is running at https://192.168.1.101:6443
CoreDNS is running at https://192.168.1.101:6443/api/v1/namespaces/kube-system/services/kube-dns:dns/proxy

To further debug and diagnose cluster problems, use 'kubectl cluster-info dump'.

❯ kubectl get no
NAME          STATUS   ROLES           AGE   VERSION
k8s-master    Ready    control-plane   25d   v1.36.0
k8s-worker1   Ready    <none>          25d   v1.36.0
k8s-worker2   Ready    <none>          25d   v1.36.0

ArgoCD

ArgoCD 已经部署到K8S集群里面了

❯ argocd version
argocd: v3.4.3+1801122
  BuildDate: 2026-05-28T12:02:57Z
  GitCommit: 1801122b4391cad4961301f787006dc9a88c2dd3
  GitTreeState: clean
  GoVersion: go1.26.0
  Compiler: gc
  Platform: linux/amd64
argocd-server: v3.4.3

ArgoCD Web UI:
https://192.168.1.101:31157/

准备 repo

创建 GitLab repo

Git repo name: argocd-demo-gl

Repo GitLab URL http://192.168.1.4:8080/yahoon/argocd-demo-gl

Set the repo to public

Clone to local dir:

❯ git clone ssh://git@192.168.1.4:2222/yahoon/argocd-demo-gl.git
Cloning into 'argocd-demo-gl'...

填充git repo内容

目录结构如下

❯ tree .
.
├── container-image
│   └── argocd-demo
│       ├── Containerfile
│       ├── index.html
│       └── README.md
├── k8s-apps
│   └── argocd-demo
│       ├── deployment.yaml
│       └── service.yaml
└── README.md

内容说明

  • container-image: 放image, 我用 argocd-demo-gl做名字
    • 主要效果是http/80 显示html 内容 Hello, This is Yahoon's ArgoCD Demo from Local GitLab!
  • k8s-apps: 在k8s上部署的resource,主要是service argocd-demo-go

Git提交 & push

你可以访问所有代码在这个仓库: https://github.com/yahoon/argocd-demo-gl

准备 image repo

在Quay上创建 public repo: https://quay.io/repository/yahoon/argocd-demo-gl

准备image

我用 argocd-demo-gl做名字

❯ cd container-image/argocd-demo/
❯ podman build -t quay.io/yahoon/argocd-demo-gl:v1 .

本地测试image

❯ podman run --rm -d  -P quay.io/yahoon/argocd-demo-gl:v1

❯ podman ps
CONTAINER ID  IMAGE                             COMMAND               CREATED        STATUS        PORTS                  NAMES
226a6d5f6589  quay.io/yahoon/argocd-demo-gl:v1  nginx -g daemon o...  2 seconds ago  Up 2 seconds  0.0.0.0:44137->80/tcp  intelligent_banzai

❯ curl localhost:44137
Hello, This is Yahoon's ArgoCD Demof rom Local GitLab!

推送image

❯ podman login -u='yahoon' -p='yahoon-quay-password' quay.io
❯ podman push quay.io/yahoon/argocd-demo-gl:v1

在ArgoCD UI 上部署app

Create app

Login Argo UI: https://192.168.1.101:31157/

点击 + NEW APP,填写:

General 区

  • Application Name: argocd-demo-gl
  • Project: default
  • Sync Policy: Manual
    Sync Options 区(点开折叠)
    • 勾选 Auto-Create Namespace

Source 区

  • Repository URL: http://192.168.1.4:8080/yahoon/argocd-demo-gl.git
  • Revision: HEAD
  • Path: k8s-apps/argocd-demo

Destination 区

  • Cluster URL: 下拉选择 in-cluster (https://kubernetes.default.svc)
  • Namespace: argocd-ademo-gl

点击右上角 CREATE

Sync app

点开app页面,点sync, 等一会就成功了

3.png

在CLI下面查看:

❯ oc get app -n argocd
NAME             SYNC STATUS   HEALTH STATUS
argocd-demo-gl   Synced        Healthy

❯ oc get all -n argocd-demo-gl
NAME                               READY   STATUS    RESTARTS   AGE
pod/argocd-demo-79d888c774-4mwpx   1/1     Running   0          7s
pod/argocd-demo-79d888c774-6fshr   1/1     Running   0          7s

NAME                     TYPE        CLUSTER-IP     EXTERNAL-IP   PORT(S)   AGE
service/argocd-demo-gl   ClusterIP   10.109.8.250   <none>        80/TCP    7s

NAME                          READY   UP-TO-DATE   AVAILABLE   AGE
deployment.apps/argocd-demo   2/2     2            2           7s

NAME                                     DESIRED   CURRENT   READY   AGE
replicaset.apps/argocd-demo-79d888c774   2         2         2       7s

Test the app

❯ kubectl run curl-test -n argocd-demo-gl --rm -it --image=quay.io/curl/curl --restart=Never -- \                                                           
  curl http://argocd-demo-gl.argocd-demo-gl.svc.cluster.local 
// 应该返回 "Hello, This is Yahoon's ArgoCD Demo"。

端口转发

❯ kubectl port-forward -n argocd-demo-gl svc/argocd-demo-gl 8081:80

在web browser 里访问 http://localhost:8081/

总结

总体实现就是Argo直接从git repo来部署应用到k8s上,应用所有的更改都要通过git 来实现=》 这也就是 GitOps的意义所在了!

关注yahoon, 为你带来更多实用的知识。

「本文同步首发于个人博客 yahoon.github.io,原创内容,转载请注明出处」

目录
相关文章
|
4天前
|
人工智能 自然语言处理 API
【Azure AI Search】 stopword 是什么,为什么它会影响搜索结果?
本文解析 Azure AI Search 中搜索 &quot;in brief&quot; 返回结果过多的问题,指出根源在于 analyzer 对停用词(如 &quot;in&quot;)的处理差异:默认 `standard.lucene` 保留停用词导致泛匹配,而 `en.microsoft` 会过滤停用词,使结果更精准。关键在于根据业务语义选择合适 analyzer。
186 121
|
5天前
|
人工智能 自然语言处理 API
【Azure AI Search】Index的字段使用默认Analyzer(standard.lucene) 和 en.microsoft 有什么不同?
Azure AI Search英文检索因词形差异(如brief/briefs)无法匹配,根源在于analyzer选择:默认standard.lucene不处理词形还原,而en.microsoft支持lemmatization,可将变体还原为基本形式。需通过新增字段并配置en.microsoft analyzer解决,兼顾检索质量与业务需求。
203 124
|
10天前
|
弹性计算 监控 Java
Maven 并行构建配置:-T 4C 提速 4 倍实战
本文深入讲解了 Maven 并行构建的核心原理和实战技巧,包含 -T 参数详解、模块并行化改造、性能监控与分析等企业级最佳实践。通过真实案例展示了如何将多模块项目的构建时间从 45 分钟缩短到 11 分钟(提升 4.1 倍),提供完整的性能测试脚本和优化检查清单。掌握这些技能,你将能够充分利用多核 CPU 加速 Maven 构建。适合 Java 开发者、架构师、DevOps 工程师阅读。
263 8
|
4天前
|
人工智能 安全 API
阿里云千问大模型入门到精通全解:核心功能、价格配置与完整实操指南
千问,官方名称通义千问,代号Qwen,是阿里云完全自主研发的全栈大模型家族,并非单一模型,而是覆盖纯文本、代码、图像、音频、视频、行业垂直场景的完整模型产品矩阵,统一依托阿里云百炼大模型服务平台对外提供能力调用、微调、智能体开发、知识库构建、应用部署等全链路服务。
2376 2
|
3天前
|
人工智能 缓存 监控
阿里云 AI 网关 FinOps 能力正式上线丨让每一个 Token 的消耗都“看得见、管得住”
阿里云 AI 网关 FinOps 能力,从“消费者配额”切入,让企业在大模型调用的每一个环节都做到心中有数。
106 11
|
4天前
|
人工智能 JSON API
AI Agent 完全入门:从“大模型”到“能干活”的智能体,一篇讲透
本文深入浅出解析AI Agent本质:非 merely 工具调用,而是“感知-规划-记忆-工具”四层闭环的行动系统。对比普通大模型“只生成答案”,Agent能自主拆解目标、多步执行任务。聚焦测试场景,详解其在自动生成数据、UI自愈、智能断言三大落地点的实效价值。
|
2天前
|
人工智能 运维 安全
工单闭环从半天到 6 分钟:我们把 AI Agent 编进了组织架构
我们以云原生应用部门为试验田,用商业化产品 AgentTeams 落地一支"数字员工小分队",让它们承接日常研发、工单答疑、开源维护与运营等业务,把原本人肉串联的协作流程,做成 AI Native 的工作方式。
|
3天前
|
人工智能 弹性计算 开发者
2026年阿里云618活动攻略:时间、入口及优惠政策详解
2026阿里云618大促开启!主题“AI加速季,智惠生产力”,6月1日-30日限时开展。涵盖云服务器秒杀(低至38元/年)、上云满减券(最高减1728元)、Qwen 3.7大模型5折、全模型节省计划直省55%,及QoderWork首月0元等专属AI权益,助力开发者与企业低成本上云、高效用AI。(240字)
109 2
|
10天前
|
人工智能 自然语言处理 监控
告别复杂接入流程:用 AI Agent Skill 驱动云监控可观测接入
对云原生与AI应用带来的接入复杂性,阿里云可观测团队将接入接口CLI化,并提供开箱即用的Skill,支持主流的APM和AI应用高效接入,用户仅需自然语言描述即可完成自动化接入,显著降低运维门槛。
177 16
|
6天前
|
人工智能 弹性计算 API
OpenClaw+阿里云百炼Token Plan 一站式部署与配置流程
OpenClaw作为一款开源可自托管的AI智能体执行框架,能让大模型从单纯对话升级为可执行文件处理、代码编写、流程自动化等任务的数字助手。在阿里云上部署OpenClaw并接入百炼Token Plan,可依托阿里云稳定的云服务与百炼的大模型能力,打造专属、高效、低成本的AI智能体服务。本文将从准备工作、阿里云服务器部署、百炼Token Plan开通与密钥获取、OpenClaw配置、功能验证到常见问题排查,提供完整实操流程,帮助用户快速完成部署与配置。
128 9