生产级 DevOps 自动化交付模板(基于 Kubernetes 与 GitOps)

📦 一、项目目录结构(标准企业布局)

复制代码

devops-demo/
├── app/ # 应用代码(示例)
│ ├── Dockerfile
│ └── index.html

├── jenkins/
│ └── Jenkinsfile

├── k8s/
│ ├── base/
│ │ ├── deployment.yaml
│ │ ├── service.yaml
│ │ └── ingress.yaml
│ │
│ └── rollout/
│ └── rollout.yaml # 金丝雀发布

├── argocd/
│ └── application.yaml

└── README.md


🐳 二、应用 + Dockerfile

app/index.html

<h1>Hello DevOps 🚀</h1>

app/Dockerfile

FROM nginx:1.25-alpine

COPY index.html /usr/share/nginx/html/index.html

EXPOSE 80


🔧 三、Jenkinsfile(CI核心)

📍作用:构建 + 推送镜像 + 更新 Git(触发 CD)

pipeline {
agent any

environment {
REGISTRY = "192.168.100.30:5000/devops-demo"
IMAGE = "web"
TAG = "${BUILD_NUMBER}"
GIT_CREDENTIALS = "gitlab-creds"
}

stages {

stage('Checkout') {
steps {
git branch: 'master',
credentialsId: "${GIT_CREDENTIALS}",
url: 'http://192.168.100.100/devops/devops-demo.git'
}
}

stage('Build Image') {
steps {
sh """
docker build -t $REGISTRY/$IMAGE:$TAG ./app
"""
}
}

stage('Push Image') {
steps {
sh """
docker push $REGISTRY/$IMAGE:$TAG
"""
}
}

stage('Update K8s YAML') {
steps {
sh """
sed -i 's#image:.*#image: $REGISTRY/$IMAGE:$TAG#g' k8s/rollout/rollout.yaml
git config user.name "jenkins"
git config user.email "jenkins@local"
git commit -am "update image to $TAG"
git push origin master
"""
}
}
}
}


☸️ 四、Kubernetes 部署 YAML

1️⃣ Service

apiVersion: v1
kind:Service
metadata:
name:devops-demo
spec:
selector:
app:devops-demo
ports:
-port:80
targetPort:80
type:ClusterIP


2️⃣ Ingress(外部访问)

apiVersion: networking.k8s.io/v1
kind:Ingress
metadata:
name:devops-demo
spec:
rules:
-host:devops.local
http:
paths:
-path:/
pathType:Prefix
backend:
service:
name:devops-demo
port:
number:80

👉 记得本地 /etc/hosts

192.168.100.xxx devops.local


🚀 五、金丝雀发布(重点🔥)

k8s/rollout/rollout.yaml

apiVersion: argoproj.io/v1alpha1
kind:Rollout
metadata:
name:devops-demo
spec:
replicas:3

selector:
matchLabels:
app:devops-demo

template:
metadata:
labels:
app:devops-demo
spec:
containers:
-name:app
image:192.168.100.30:5000/devops-demo/web:1
ports:
-containerPort:80

strategy:
canary:
steps:
-setWeight:20
-pause: {duration:30}
-setWeight:50
-pause: {duration:60}
-setWeight:100


🔁 六、ArgoCD(CD核心)

argocd/application.yaml

apiVersion: argoproj.io/v1alpha1
kind:Application
metadata:
name:devops-demo
namespace:argocd

spec:
project:default

source:
repoURL:http://192.168.100.100/devops/devops-demo.git
targetRevision:master
path:k8s

destination:
server:https://kubernetes.default.svc
namespace:default

syncPolicy:
automated:
prune:true
selfHeal:true


🔄 七、完整执行流程

1. 开发 push 代码 → GitLab

2. Jenkins 自动执行:
`

  • 构建 Docker 镜像
  • push Harbor
  • 修改 rollout.yaml
  • push Git`

3. ArgoCD 检测 Git 变更:
`

  • 自动同步 K8s`

4. Argo Rollouts:
`

  • 20% → 50% → 100% 灰度发布`

5. 用户访问:
devops.local


🧪 八、部署步骤(实战)

1️⃣ 准备环境

  • Kubernetes

  • Jenkins(已装)

  • Harbor(已装)

  • ArgoCD(建议 Helm 安装)


2️⃣ 安装 ArgoCD

kubectl create namespace argocd

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


3️⃣ 安装 Argo Rollouts

kubectl create namespace argo-rollouts

kubectl apply -n argo-rollouts -f \
https://github.com/argoproj/argo-rollouts/releases/latest/download/install.yaml


4️⃣ 创建应用

kubectl apply -f argocd/application.yaml


5️⃣ 访问

kubectl get svc -n argocd

相关推荐
Gnix102975 天前
Copier 总报错?一篇讲透排查、升级、治理和团队落地
devops
运维开发故事5 天前
基于 Arthas 的多集群在线诊断系统设计与实现
kubernetes
Patrick_Wilson7 天前
从「改个端口」到 502:Next.js on k8s 的容器端口、Service 映射与 env 覆盖
docker·kubernetes·next.js
探索云原生7 天前
K8s 1.36 这个 GA 特性,把 initContainer 拉模型的 hack 干掉了
ai·云原生·kubernetes
Java之美8 天前
一次k8s升级引发的DevicePlugin注册失败
云原生·kubernetes
shushangyun_15 天前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化
施努卡机器视觉15 天前
SNK施努卡侧滑门锁上滑轮总成自动化装配线,从零件到组件,全流程精密制造方案
运维·自动化·制造
lunzi_082615 天前
【开源治理】05-把流程翻译成门禁:开源治理嵌入 DevOps 流水线实战
供应链管理·devops·开源治理
dayuOK630715 天前
写作卡壳怎么办?我的“5分钟启动法”
人工智能·职场和发展·自动化·新媒体运营·媒体