ccjk 14.1.11 → 14.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/chunks/config.mjs +17 -2
- package/dist/chunks/doctor.mjs +171 -2
- package/dist/chunks/index10.mjs +18 -4
- package/dist/chunks/mcp-cli.mjs +1 -1
- package/dist/chunks/package.mjs +1 -1
- package/dist/cli.mjs +0 -0
- package/dist/templates/agents/README.md +78 -0
- package/dist/templates/common/error-prevention.md +267 -0
- package/dist/templates/common/karpathy-baseline.md +83 -0
- package/dist/templates/common/output-styles/zh-CN/carmack-mode.md +381 -0
- package/dist/templates/common/output-styles/zh-CN/dhh-mode.md +265 -0
- package/dist/templates/common/output-styles/zh-CN/evan-you-mode.md +539 -0
- package/dist/templates/common/output-styles/zh-CN/jobs-mode.md +369 -0
- package/dist/templates/common/output-styles/zh-CN/linus-mode.md +135 -0
- package/dist/templates/common/output-styles/zh-CN/uncle-bob-mode.md +221 -0
- package/dist/templates/common/workflow/continuousDelivery/en/continuous-delivery.md +628 -0
- package/dist/templates/common/workflow/continuousDelivery/zh-CN/continuous-delivery.md +628 -0
- package/dist/templates/common/workflow/essential/en/agents/ccjk-config-agent.md +187 -0
- package/dist/templates/common/workflow/essential/en/agents/ccjk-mcp-agent.md +191 -0
- package/dist/templates/common/workflow/essential/en/agents/ccjk-skill-agent.md +249 -0
- package/dist/templates/common/workflow/essential/en/agents/ccjk-workflow-agent.md +277 -0
- package/dist/templates/common/workflow/essential/en/agents/get-current-datetime.md +29 -0
- package/dist/templates/common/workflow/essential/en/agents/init-architect.md +115 -0
- package/dist/templates/common/workflow/essential/en/agents/ui-ux-designer.md +91 -0
- package/dist/templates/common/workflow/essential/en/feat.md +92 -0
- package/dist/templates/common/workflow/essential/en/goal.md +147 -0
- package/dist/templates/common/workflow/essential/en/init-project.md +53 -0
- package/dist/templates/common/workflow/essential/zh-CN/agents/get-current-datetime.md +29 -0
- package/dist/templates/common/workflow/essential/zh-CN/agents/init-architect.md +115 -0
- package/dist/templates/common/workflow/essential/zh-CN/agents/ui-ux-designer.md +91 -0
- package/dist/templates/common/workflow/essential/zh-CN/feat.md +315 -0
- package/dist/templates/common/workflow/essential/zh-CN/goal.md +146 -0
- package/dist/templates/common/workflow/essential/zh-CN/init-project.md +53 -0
- package/dist/templates/common/workflow/git/en/git-cleanBranches.md +102 -0
- package/dist/templates/common/workflow/git/en/git-commit.md +205 -0
- package/dist/templates/common/workflow/git/en/git-rollback.md +90 -0
- package/dist/templates/common/workflow/git/en/git-worktree.md +276 -0
- package/dist/templates/common/workflow/git/zh-CN/git-cleanBranches.md +102 -0
- package/dist/templates/common/workflow/git/zh-CN/git-commit.md +205 -0
- package/dist/templates/common/workflow/git/zh-CN/git-rollback.md +90 -0
- package/dist/templates/common/workflow/git/zh-CN/git-worktree.md +276 -0
- package/dist/templates/common/workflow/interview/en/interview.md +67 -0
- package/dist/templates/common/workflow/interview/zh-CN/interview.md +67 -0
- package/dist/templates/common/workflow/linearMethod/en/linear-method.md +651 -0
- package/dist/templates/common/workflow/linearMethod/zh-CN/linear-method.md +752 -0
- package/dist/templates/common/workflow/refactoringMaster/en/refactoring-master.md +516 -0
- package/dist/templates/common/workflow/refactoringMaster/zh-CN/refactoring-master.md +812 -0
- package/dist/templates/common/workflow/sixStep/en/workflow.md +83 -0
- package/dist/templates/common/workflow/sixStep/zh-CN/workflow.md +359 -0
- package/dist/templates/common/workflow/specFirstTDD/en/spec-first-tdd.md +364 -0
- package/dist/templates/common/workflow/specFirstTDD/zh-CN/spec-first-tdd.md +366 -0
- package/dist/templates/hooks/README.md +212 -0
- package/dist/templates/hooks/git-workflow-hooks.md +551 -0
- package/dist/templates/hooks/post-test-coverage.md +434 -0
- package/dist/templates/hooks/pre-commit-black.md +274 -0
- package/dist/templates/hooks/pre-commit-eslint.md +153 -0
- package/dist/templates/hooks/pre-commit-gofmt.md +284 -0
- package/dist/templates/hooks/pre-commit-prettier.md +212 -0
- package/dist/templates/hooks/pre-commit-type-check.md +377 -0
- package/dist/templates/skills/ccjk-init.md +154 -0
- package/dist/templates/skills/ccjk-mcp-setup.md +205 -0
- package/dist/templates/skills/ccjk-troubleshoot.md +228 -0
- package/dist/templates/skills/django-patterns.md +1016 -0
- package/dist/templates/skills/git-workflow.md +748 -0
- package/dist/templates/skills/go-idioms.md +963 -0
- package/dist/templates/skills/nextjs-optimization.md +694 -0
- package/dist/templates/skills/python-pep8.md +852 -0
- package/dist/templates/skills/react-patterns.md +686 -0
- package/dist/templates/skills/rust-patterns.md +1057 -0
- package/dist/templates/skills/security-best-practices.md +1413 -0
- package/dist/templates/skills/testing-best-practices.md +1315 -0
- package/dist/templates/skills/ts-best-practices.md +354 -0
- package/package.json +40 -43
- package/templates/common/karpathy-baseline.md +83 -0
- package/templates/common/output-styles/zh-CN/carmack-mode.md +14 -0
- package/templates/common/output-styles/zh-CN/dhh-mode.md +14 -0
- package/templates/common/output-styles/zh-CN/evan-you-mode.md +14 -0
- package/templates/common/output-styles/zh-CN/jobs-mode.md +14 -0
- package/templates/common/output-styles/zh-CN/linus-mode.md +14 -0
- package/templates/common/output-styles/zh-CN/uncle-bob-mode.md +14 -0
- package/templates/common/workflow/linearMethod/zh-CN/linear-method.md +2 -0
- package/templates/common/workflow/refactoringMaster/zh-CN/refactoring-master.md +2 -0
- package/templates/common/workflow/sixStep/zh-CN/workflow.md +2 -0
- package/templates/common/workflow/specFirstTDD/zh-CN/spec-first-tdd.md +2 -0
|
@@ -0,0 +1,628 @@
|
|
|
1
|
+
---
|
|
2
|
+
description: 持续交付流水线 - 自动化构建、测试、部署,实现随时可发布的软件交付
|
|
3
|
+
allowed-tools: Read(**), Write(**), Exec(npm run build, npm test, docker build, docker push, kubectl apply)
|
|
4
|
+
argument-hint: [--env <staging|production>] [--skip-tests] [--rollback] [--canary]
|
|
5
|
+
# examples:
|
|
6
|
+
# - /continuous-delivery # 部署到 staging 环境
|
|
7
|
+
# - /continuous-delivery --env production # 部署到生产环境
|
|
8
|
+
# - /continuous-delivery --canary # 金丝雀发布
|
|
9
|
+
# - /continuous-delivery --rollback # 回滚到上一版本
|
|
10
|
+
---
|
|
11
|
+
|
|
12
|
+
# Continuous Delivery Pipeline
|
|
13
|
+
|
|
14
|
+
基于 Jez Humble 和 David Farley 的《持续交付》,以及现代 DevOps 实践构建的自动化交付流水线。
|
|
15
|
+
|
|
16
|
+
---
|
|
17
|
+
|
|
18
|
+
## 核心理念
|
|
19
|
+
|
|
20
|
+
**持续交付(Continuous Delivery)**:
|
|
21
|
+
- 代码随时处于可发布状态
|
|
22
|
+
- 自动化构建、测试、部署流程
|
|
23
|
+
- 快速、可靠、可重复的发布
|
|
24
|
+
- 降低发布风险,提高交付频率
|
|
25
|
+
|
|
26
|
+
**关键原则**:
|
|
27
|
+
1. **自动化一切**:从代码提交到生产部署全自动化
|
|
28
|
+
2. **快速反馈**:每次提交都触发完整的验证流程
|
|
29
|
+
3. **小批量发布**:频繁发布小改动,降低风险
|
|
30
|
+
4. **环境一致性**:开发、测试、生产环境配置一致
|
|
31
|
+
5. **可观测性**:全链路监控和日志追踪
|
|
32
|
+
|
|
33
|
+
---
|
|
34
|
+
|
|
35
|
+
## Pipeline Stages
|
|
36
|
+
|
|
37
|
+
### Stage 1: Source Control(源码管理)
|
|
38
|
+
|
|
39
|
+
**触发条件**:
|
|
40
|
+
- Git push 到主分支
|
|
41
|
+
- Pull Request 合并
|
|
42
|
+
- 定时构建(夜间构建)
|
|
43
|
+
|
|
44
|
+
```yaml
|
|
45
|
+
# .github/workflows/cd-pipeline.yml
|
|
46
|
+
name: Continuous Delivery Pipeline
|
|
47
|
+
|
|
48
|
+
on:
|
|
49
|
+
push:
|
|
50
|
+
branches: [main, develop]
|
|
51
|
+
pull_request:
|
|
52
|
+
branches: [main]
|
|
53
|
+
schedule:
|
|
54
|
+
- cron: '0 2 * * *' # 每天凌晨 2 点
|
|
55
|
+
```
|
|
56
|
+
|
|
57
|
+
**检查项**:
|
|
58
|
+
- ✅ 代码已提交到版本控制
|
|
59
|
+
- ✅ 提交信息符合规范
|
|
60
|
+
- ✅ 分支保护规则已配置
|
|
61
|
+
|
|
62
|
+
---
|
|
63
|
+
|
|
64
|
+
### Stage 2: Build(构建)
|
|
65
|
+
|
|
66
|
+
**目标**:将源代码编译为可部署的制品
|
|
67
|
+
|
|
68
|
+
```bash
|
|
69
|
+
# 1. 安装依赖
|
|
70
|
+
npm ci # 使用 ci 而非 install,确保依赖版本一致
|
|
71
|
+
|
|
72
|
+
# 2. 代码检查
|
|
73
|
+
npm run lint
|
|
74
|
+
npm run type-check
|
|
75
|
+
|
|
76
|
+
# 3. 编译构建
|
|
77
|
+
npm run build
|
|
78
|
+
|
|
79
|
+
# 4. 生成版本号
|
|
80
|
+
VERSION=$(git describe --tags --always)
|
|
81
|
+
echo "Building version: $VERSION"
|
|
82
|
+
```
|
|
83
|
+
|
|
84
|
+
**构建优化**:
|
|
85
|
+
```dockerfile
|
|
86
|
+
# Dockerfile - 多阶段构建
|
|
87
|
+
FROM node:20-alpine AS builder
|
|
88
|
+
WORKDIR /app
|
|
89
|
+
COPY package*.json ./
|
|
90
|
+
RUN npm ci --only=production
|
|
91
|
+
COPY . .
|
|
92
|
+
RUN npm run build
|
|
93
|
+
|
|
94
|
+
FROM node:20-alpine AS runtime
|
|
95
|
+
WORKDIR /app
|
|
96
|
+
COPY --from=builder /app/dist ./dist
|
|
97
|
+
COPY --from=builder /app/node_modules ./node_modules
|
|
98
|
+
EXPOSE 3000
|
|
99
|
+
CMD ["node", "dist/index.js"]
|
|
100
|
+
```
|
|
101
|
+
|
|
102
|
+
**检查项**:
|
|
103
|
+
- ✅ 构建成功无错误
|
|
104
|
+
- ✅ 制品大小合理(< 500MB)
|
|
105
|
+
- ✅ 版本号已标记
|
|
106
|
+
- ✅ 构建时间 < 10 分钟
|
|
107
|
+
|
|
108
|
+
---
|
|
109
|
+
|
|
110
|
+
### Stage 3: Test(测试)
|
|
111
|
+
|
|
112
|
+
**目标**:自动化验证代码质量和功能正确性
|
|
113
|
+
|
|
114
|
+
#### 3.1 单元测试(Unit Tests)
|
|
115
|
+
|
|
116
|
+
```bash
|
|
117
|
+
npm run test:unit -- --coverage --ci
|
|
118
|
+
|
|
119
|
+
# 覆盖率要求
|
|
120
|
+
# Statements : 80%
|
|
121
|
+
# Branches : 75%
|
|
122
|
+
# Functions : 80%
|
|
123
|
+
# Lines : 80%
|
|
124
|
+
```
|
|
125
|
+
|
|
126
|
+
#### 3.2 集成测试(Integration Tests)
|
|
127
|
+
|
|
128
|
+
```bash
|
|
129
|
+
# 启动测试数据库
|
|
130
|
+
docker-compose -f docker-compose.test.yml up -d
|
|
131
|
+
|
|
132
|
+
# 运行集成测试
|
|
133
|
+
npm run test:integration
|
|
134
|
+
|
|
135
|
+
# 清理测试环境
|
|
136
|
+
docker-compose -f docker-compose.test.yml down
|
|
137
|
+
```
|
|
138
|
+
|
|
139
|
+
#### 3.3 端到端测试(E2E Tests)
|
|
140
|
+
|
|
141
|
+
```bash
|
|
142
|
+
# 启动应用
|
|
143
|
+
npm run start:test &
|
|
144
|
+
APP_PID=$!
|
|
145
|
+
|
|
146
|
+
# 等待应用就绪
|
|
147
|
+
wait-on http://localhost:3000/health
|
|
148
|
+
|
|
149
|
+
# 运行 E2E 测试
|
|
150
|
+
npm run test:e2e
|
|
151
|
+
|
|
152
|
+
# 清理
|
|
153
|
+
kill $APP_PID
|
|
154
|
+
```
|
|
155
|
+
|
|
156
|
+
#### 3.4 性能测试(Performance Tests)
|
|
157
|
+
|
|
158
|
+
```bash
|
|
159
|
+
# 使用 k6 进行负载测试
|
|
160
|
+
k6 run --vus 100 --duration 30s tests/load/api-test.js
|
|
161
|
+
|
|
162
|
+
# 性能基准
|
|
163
|
+
# - 响应时间 P95 < 200ms
|
|
164
|
+
# - 吞吐量 > 1000 req/s
|
|
165
|
+
# - 错误率 < 0.1%
|
|
166
|
+
```
|
|
167
|
+
|
|
168
|
+
#### 3.5 安全扫描(Security Scan)
|
|
169
|
+
|
|
170
|
+
```bash
|
|
171
|
+
# 依赖漏洞扫描
|
|
172
|
+
npm audit --audit-level=moderate
|
|
173
|
+
|
|
174
|
+
# 容器镜像扫描
|
|
175
|
+
trivy image myapp:$VERSION
|
|
176
|
+
|
|
177
|
+
# SAST 静态代码分析
|
|
178
|
+
sonar-scanner
|
|
179
|
+
```
|
|
180
|
+
|
|
181
|
+
**检查项**:
|
|
182
|
+
- ✅ 所有测试通过
|
|
183
|
+
- ✅ 覆盖率达标
|
|
184
|
+
- ✅ 无高危安全漏洞
|
|
185
|
+
- ✅ 性能指标符合要求
|
|
186
|
+
|
|
187
|
+
---
|
|
188
|
+
|
|
189
|
+
### Stage 4: Package(打包)
|
|
190
|
+
|
|
191
|
+
**目标**:创建不可变的部署制品
|
|
192
|
+
|
|
193
|
+
```bash
|
|
194
|
+
# 1. 构建 Docker 镜像
|
|
195
|
+
docker build -t myapp:$VERSION .
|
|
196
|
+
|
|
197
|
+
# 2. 标记镜像
|
|
198
|
+
docker tag myapp:$VERSION registry.example.com/myapp:$VERSION
|
|
199
|
+
docker tag myapp:$VERSION registry.example.com/myapp:latest
|
|
200
|
+
|
|
201
|
+
# 3. 推送到镜像仓库
|
|
202
|
+
docker push registry.example.com/myapp:$VERSION
|
|
203
|
+
docker push registry.example.com/myapp:latest
|
|
204
|
+
|
|
205
|
+
# 4. 生成 SBOM(软件物料清单)
|
|
206
|
+
syft registry.example.com/myapp:$VERSION -o spdx-json > sbom.json
|
|
207
|
+
|
|
208
|
+
# 5. 签名镜像
|
|
209
|
+
cosign sign registry.example.com/myapp:$VERSION
|
|
210
|
+
```
|
|
211
|
+
|
|
212
|
+
**制品管理**:
|
|
213
|
+
```json
|
|
214
|
+
{
|
|
215
|
+
"artifact": {
|
|
216
|
+
"name": "myapp",
|
|
217
|
+
"version": "v1.2.3",
|
|
218
|
+
"commit": "abc123",
|
|
219
|
+
"buildTime": "2025-02-04T10:30:00Z",
|
|
220
|
+
"registry": "registry.example.com",
|
|
221
|
+
"digest": "sha256:...",
|
|
222
|
+
"size": "245MB"
|
|
223
|
+
}
|
|
224
|
+
}
|
|
225
|
+
```
|
|
226
|
+
|
|
227
|
+
**检查项**:
|
|
228
|
+
- ✅ 镜像构建成功
|
|
229
|
+
- ✅ 镜像已推送到仓库
|
|
230
|
+
- ✅ 镜像已签名验证
|
|
231
|
+
- ✅ SBOM 已生成
|
|
232
|
+
|
|
233
|
+
---
|
|
234
|
+
|
|
235
|
+
### Stage 5: Deploy(部署)
|
|
236
|
+
|
|
237
|
+
**目标**:将制品部署到目标环境
|
|
238
|
+
|
|
239
|
+
#### 5.1 Staging 环境部署
|
|
240
|
+
|
|
241
|
+
```bash
|
|
242
|
+
# 1. 更新 Kubernetes 配置
|
|
243
|
+
kubectl set image deployment/myapp \
|
|
244
|
+
myapp=registry.example.com/myapp:$VERSION \
|
|
245
|
+
-n staging
|
|
246
|
+
|
|
247
|
+
# 2. 等待部署完成
|
|
248
|
+
kubectl rollout status deployment/myapp -n staging
|
|
249
|
+
|
|
250
|
+
# 3. 健康检查
|
|
251
|
+
kubectl get pods -n staging -l app=myapp
|
|
252
|
+
curl https://staging.example.com/health
|
|
253
|
+
|
|
254
|
+
# 4. 烟雾测试
|
|
255
|
+
npm run test:smoke -- --env staging
|
|
256
|
+
```
|
|
257
|
+
|
|
258
|
+
#### 5.2 Production 环境部署
|
|
259
|
+
|
|
260
|
+
**蓝绿部署(Blue-Green Deployment)**:
|
|
261
|
+
|
|
262
|
+
```bash
|
|
263
|
+
# 1. 部署新版本到 Green 环境
|
|
264
|
+
kubectl apply -f k8s/deployment-green.yml
|
|
265
|
+
|
|
266
|
+
# 2. 等待 Green 环境就绪
|
|
267
|
+
kubectl wait --for=condition=available deployment/myapp-green
|
|
268
|
+
|
|
269
|
+
# 3. 运行验证测试
|
|
270
|
+
npm run test:smoke -- --env green
|
|
271
|
+
|
|
272
|
+
# 4. 切换流量到 Green
|
|
273
|
+
kubectl patch service myapp -p '{"spec":{"selector":{"version":"green"}}}'
|
|
274
|
+
|
|
275
|
+
# 5. 监控 5 分钟
|
|
276
|
+
sleep 300
|
|
277
|
+
|
|
278
|
+
# 6. 如果正常,删除 Blue 环境
|
|
279
|
+
kubectl delete deployment myapp-blue
|
|
280
|
+
```
|
|
281
|
+
|
|
282
|
+
**金丝雀发布(Canary Deployment)**:
|
|
283
|
+
|
|
284
|
+
```bash
|
|
285
|
+
# 1. 部署金丝雀版本(5% 流量)
|
|
286
|
+
kubectl apply -f k8s/canary.yml
|
|
287
|
+
|
|
288
|
+
# 2. 监控关键指标
|
|
289
|
+
while true; do
|
|
290
|
+
ERROR_RATE=$(prometheus-query 'rate(http_errors[5m])')
|
|
291
|
+
if [ $ERROR_RATE -gt 0.01 ]; then
|
|
292
|
+
echo "Error rate too high, rolling back"
|
|
293
|
+
kubectl delete -f k8s/canary.yml
|
|
294
|
+
exit 1
|
|
295
|
+
fi
|
|
296
|
+
sleep 60
|
|
297
|
+
done
|
|
298
|
+
|
|
299
|
+
# 3. 逐步增加流量:5% -> 25% -> 50% -> 100%
|
|
300
|
+
kubectl patch deployment myapp-canary -p '{"spec":{"replicas":5}}'
|
|
301
|
+
```
|
|
302
|
+
|
|
303
|
+
**检查项**:
|
|
304
|
+
- ✅ 部署成功
|
|
305
|
+
- ✅ 健康检查通过
|
|
306
|
+
- ✅ 烟雾测试通过
|
|
307
|
+
- ✅ 关键指标正常
|
|
308
|
+
|
|
309
|
+
---
|
|
310
|
+
|
|
311
|
+
### Stage 6: Monitor(监控)
|
|
312
|
+
|
|
313
|
+
**目标**:实时监控应用健康状态和业务指标
|
|
314
|
+
|
|
315
|
+
#### 6.1 基础设施监控
|
|
316
|
+
|
|
317
|
+
```yaml
|
|
318
|
+
# Prometheus 监控指标
|
|
319
|
+
metrics:
|
|
320
|
+
- name: http_requests_total
|
|
321
|
+
type: counter
|
|
322
|
+
help: Total HTTP requests
|
|
323
|
+
|
|
324
|
+
- name: http_request_duration_seconds
|
|
325
|
+
type: histogram
|
|
326
|
+
help: HTTP request latency
|
|
327
|
+
|
|
328
|
+
- name: app_errors_total
|
|
329
|
+
type: counter
|
|
330
|
+
help: Total application errors
|
|
331
|
+
|
|
332
|
+
- name: db_connections_active
|
|
333
|
+
type: gauge
|
|
334
|
+
help: Active database connections
|
|
335
|
+
```
|
|
336
|
+
|
|
337
|
+
#### 6.2 日志聚合
|
|
338
|
+
|
|
339
|
+
```json
|
|
340
|
+
// 结构化日志
|
|
341
|
+
{
|
|
342
|
+
"timestamp": "2025-02-04T10:30:00Z",
|
|
343
|
+
"level": "info",
|
|
344
|
+
"service": "myapp",
|
|
345
|
+
"version": "v1.2.3",
|
|
346
|
+
"traceId": "abc123",
|
|
347
|
+
"message": "User login successful",
|
|
348
|
+
"userId": "user-456",
|
|
349
|
+
"duration": 120
|
|
350
|
+
}
|
|
351
|
+
```
|
|
352
|
+
|
|
353
|
+
#### 6.3 告警规则
|
|
354
|
+
|
|
355
|
+
```yaml
|
|
356
|
+
# Alertmanager 告警配置
|
|
357
|
+
alerts:
|
|
358
|
+
- name: HighErrorRate
|
|
359
|
+
expr: rate(http_errors[5m]) > 0.05
|
|
360
|
+
severity: critical
|
|
361
|
+
message: "Error rate > 5% for 5 minutes"
|
|
362
|
+
|
|
363
|
+
- name: HighLatency
|
|
364
|
+
expr: histogram_quantile(0.95, http_request_duration_seconds) > 1
|
|
365
|
+
severity: warning
|
|
366
|
+
message: "P95 latency > 1s"
|
|
367
|
+
|
|
368
|
+
- name: LowAvailability
|
|
369
|
+
expr: up{job="myapp"} < 0.99
|
|
370
|
+
severity: critical
|
|
371
|
+
message: "Service availability < 99%"
|
|
372
|
+
```
|
|
373
|
+
|
|
374
|
+
#### 6.4 业务指标
|
|
375
|
+
|
|
376
|
+
```typescript
|
|
377
|
+
// 关键业务指标
|
|
378
|
+
const businessMetrics = {
|
|
379
|
+
dailyActiveUsers: 12500,
|
|
380
|
+
conversionRate: 0.032,
|
|
381
|
+
averageOrderValue: 89.50,
|
|
382
|
+
customerSatisfaction: 4.7
|
|
383
|
+
}
|
|
384
|
+
```
|
|
385
|
+
|
|
386
|
+
---
|
|
387
|
+
|
|
388
|
+
### Stage 7: Rollback(回滚)
|
|
389
|
+
|
|
390
|
+
**目标**:快速回滚到上一个稳定版本
|
|
391
|
+
|
|
392
|
+
```bash
|
|
393
|
+
# 1. 查看部署历史
|
|
394
|
+
kubectl rollout history deployment/myapp
|
|
395
|
+
|
|
396
|
+
# 2. 回滚到上一版本
|
|
397
|
+
kubectl rollout undo deployment/myapp
|
|
398
|
+
|
|
399
|
+
# 3. 回滚到指定版本
|
|
400
|
+
kubectl rollout undo deployment/myapp --to-revision=3
|
|
401
|
+
|
|
402
|
+
# 4. 验证回滚
|
|
403
|
+
kubectl rollout status deployment/myapp
|
|
404
|
+
curl https://api.example.com/health
|
|
405
|
+
|
|
406
|
+
# 5. 通知团队
|
|
407
|
+
slack-notify "🔄 Rolled back myapp to v1.2.2 due to high error rate"
|
|
408
|
+
```
|
|
409
|
+
|
|
410
|
+
**自动回滚条件**:
|
|
411
|
+
- 错误率 > 5%
|
|
412
|
+
- P95 延迟 > 2 秒
|
|
413
|
+
- 健康检查失败
|
|
414
|
+
- 关键业务指标异常
|
|
415
|
+
|
|
416
|
+
---
|
|
417
|
+
|
|
418
|
+
## Deployment Strategies
|
|
419
|
+
|
|
420
|
+
### 1. 滚动更新(Rolling Update)
|
|
421
|
+
|
|
422
|
+
```yaml
|
|
423
|
+
apiVersion: apps/v1
|
|
424
|
+
kind: Deployment
|
|
425
|
+
metadata:
|
|
426
|
+
name: myapp
|
|
427
|
+
spec:
|
|
428
|
+
replicas: 10
|
|
429
|
+
strategy:
|
|
430
|
+
type: RollingUpdate
|
|
431
|
+
rollingUpdate:
|
|
432
|
+
maxSurge: 2 # 最多额外创建 2 个 Pod
|
|
433
|
+
maxUnavailable: 1 # 最多 1 个 Pod 不可用
|
|
434
|
+
```
|
|
435
|
+
|
|
436
|
+
**优点**:
|
|
437
|
+
- 零停机部署
|
|
438
|
+
- 资源利用率高
|
|
439
|
+
- 实现简单
|
|
440
|
+
|
|
441
|
+
**缺点**:
|
|
442
|
+
- 新旧版本共存
|
|
443
|
+
- 回滚较慢
|
|
444
|
+
|
|
445
|
+
---
|
|
446
|
+
|
|
447
|
+
### 2. 蓝绿部署(Blue-Green)
|
|
448
|
+
|
|
449
|
+
```
|
|
450
|
+
[Blue v1.0] ← 100% 流量
|
|
451
|
+
[Green v1.1] ← 0% 流量
|
|
452
|
+
|
|
453
|
+
切换后:
|
|
454
|
+
[Blue v1.0] ← 0% 流量(保留用于回滚)
|
|
455
|
+
[Green v1.1] ← 100% 流量
|
|
456
|
+
```
|
|
457
|
+
|
|
458
|
+
**优点**:
|
|
459
|
+
- 瞬间切换
|
|
460
|
+
- 快速回滚
|
|
461
|
+
- 充分测试
|
|
462
|
+
|
|
463
|
+
**缺点**:
|
|
464
|
+
- 需要双倍资源
|
|
465
|
+
- 数据库迁移复杂
|
|
466
|
+
|
|
467
|
+
---
|
|
468
|
+
|
|
469
|
+
### 3. 金丝雀发布(Canary)
|
|
470
|
+
|
|
471
|
+
```
|
|
472
|
+
阶段 1: [v1.0: 95%] [v1.1: 5%]
|
|
473
|
+
阶段 2: [v1.0: 75%] [v1.1: 25%]
|
|
474
|
+
阶段 3: [v1.0: 50%] [v1.1: 50%]
|
|
475
|
+
阶段 4: [v1.0: 0%] [v1.1: 100%]
|
|
476
|
+
```
|
|
477
|
+
|
|
478
|
+
**优点**:
|
|
479
|
+
- 渐进式发布
|
|
480
|
+
- 风险可控
|
|
481
|
+
- 真实流量验证
|
|
482
|
+
|
|
483
|
+
**缺点**:
|
|
484
|
+
- 实现复杂
|
|
485
|
+
- 发布时间长
|
|
486
|
+
|
|
487
|
+
---
|
|
488
|
+
|
|
489
|
+
## Pipeline Configuration
|
|
490
|
+
|
|
491
|
+
### 环境配置
|
|
492
|
+
|
|
493
|
+
```yaml
|
|
494
|
+
# config/environments.yml
|
|
495
|
+
environments:
|
|
496
|
+
development:
|
|
497
|
+
url: http://localhost:3000
|
|
498
|
+
database: dev-db
|
|
499
|
+
replicas: 1
|
|
500
|
+
|
|
501
|
+
staging:
|
|
502
|
+
url: https://staging.example.com
|
|
503
|
+
database: staging-db
|
|
504
|
+
replicas: 3
|
|
505
|
+
|
|
506
|
+
production:
|
|
507
|
+
url: https://api.example.com
|
|
508
|
+
database: prod-db
|
|
509
|
+
replicas: 10
|
|
510
|
+
autoScale:
|
|
511
|
+
min: 10
|
|
512
|
+
max: 50
|
|
513
|
+
targetCPU: 70
|
|
514
|
+
```
|
|
515
|
+
|
|
516
|
+
### 质量门禁
|
|
517
|
+
|
|
518
|
+
```yaml
|
|
519
|
+
# 部署前必须满足的条件
|
|
520
|
+
quality-gates:
|
|
521
|
+
- name: test-coverage
|
|
522
|
+
threshold: 80
|
|
523
|
+
blocking: true
|
|
524
|
+
|
|
525
|
+
- name: code-quality
|
|
526
|
+
sonarqube:
|
|
527
|
+
bugs: 0
|
|
528
|
+
vulnerabilities: 0
|
|
529
|
+
code-smells: < 10
|
|
530
|
+
blocking: true
|
|
531
|
+
|
|
532
|
+
- name: performance
|
|
533
|
+
p95-latency: < 200ms
|
|
534
|
+
throughput: > 1000 rps
|
|
535
|
+
blocking: false
|
|
536
|
+
```
|
|
537
|
+
|
|
538
|
+
---
|
|
539
|
+
|
|
540
|
+
## Best Practices
|
|
541
|
+
|
|
542
|
+
### 1. 版本管理
|
|
543
|
+
|
|
544
|
+
```bash
|
|
545
|
+
# 语义化版本
|
|
546
|
+
MAJOR.MINOR.PATCH
|
|
547
|
+
|
|
548
|
+
# 示例
|
|
549
|
+
v1.2.3
|
|
550
|
+
│ │ └─ 补丁版本(bug 修复)
|
|
551
|
+
│ └─── 次版本(新功能,向后兼容)
|
|
552
|
+
└───── 主版本(破坏性变更)
|
|
553
|
+
```
|
|
554
|
+
|
|
555
|
+
### 2. 配置管理
|
|
556
|
+
|
|
557
|
+
```typescript
|
|
558
|
+
// ✅ Good: 配置外部化
|
|
559
|
+
const config = {
|
|
560
|
+
database: process.env.DATABASE_URL,
|
|
561
|
+
apiKey: process.env.API_KEY,
|
|
562
|
+
logLevel: process.env.LOG_LEVEL || 'info'
|
|
563
|
+
}
|
|
564
|
+
|
|
565
|
+
// ❌ Bad: 硬编码配置
|
|
566
|
+
const config = {
|
|
567
|
+
database: 'postgres://localhost:5432/mydb',
|
|
568
|
+
apiKey: 'sk-1234567890'
|
|
569
|
+
}
|
|
570
|
+
```
|
|
571
|
+
|
|
572
|
+
### 3. 数据库迁移
|
|
573
|
+
|
|
574
|
+
```bash
|
|
575
|
+
# 向后兼容的迁移策略
|
|
576
|
+
# 阶段 1: 添加新列(可为空)
|
|
577
|
+
ALTER TABLE users ADD COLUMN email_verified BOOLEAN;
|
|
578
|
+
|
|
579
|
+
# 阶段 2: 部署新代码(同时支持新旧列)
|
|
580
|
+
# 阶段 3: 数据迁移
|
|
581
|
+
UPDATE users SET email_verified = true WHERE email IS NOT NULL;
|
|
582
|
+
|
|
583
|
+
# 阶段 4: 添加约束
|
|
584
|
+
ALTER TABLE users ALTER COLUMN email_verified SET NOT NULL;
|
|
585
|
+
|
|
586
|
+
# 阶段 5: 删除旧列(下个版本)
|
|
587
|
+
ALTER TABLE users DROP COLUMN old_email_field;
|
|
588
|
+
```
|
|
589
|
+
|
|
590
|
+
### 4. 特性开关
|
|
591
|
+
|
|
592
|
+
```typescript
|
|
593
|
+
// 使用特性开关控制新功能发布
|
|
594
|
+
if (featureFlags.isEnabled('new-checkout-flow', user)) {
|
|
595
|
+
return newCheckoutFlow()
|
|
596
|
+
} else {
|
|
597
|
+
return legacyCheckoutFlow()
|
|
598
|
+
}
|
|
599
|
+
```
|
|
600
|
+
|
|
601
|
+
---
|
|
602
|
+
|
|
603
|
+
## Command Options
|
|
604
|
+
|
|
605
|
+
- `--env <staging|production>`:指定部署环境
|
|
606
|
+
- `--skip-tests`:跳过测试阶段(仅用于紧急修复)
|
|
607
|
+
- `--rollback`:回滚到上一版本
|
|
608
|
+
- `--canary`:使用金丝雀发布策略
|
|
609
|
+
- `--dry-run`:模拟部署,不实际执行
|
|
610
|
+
|
|
611
|
+
---
|
|
612
|
+
|
|
613
|
+
## Success Metrics
|
|
614
|
+
|
|
615
|
+
- ✅ 部署频率:每天多次
|
|
616
|
+
- ✅ 变更前置时间:< 1 小时
|
|
617
|
+
- ✅ 变更失败率:< 15%
|
|
618
|
+
- ✅ 平均恢复时间(MTTR):< 1 小时
|
|
619
|
+
- ✅ 服务可用性:> 99.9%
|
|
620
|
+
|
|
621
|
+
---
|
|
622
|
+
|
|
623
|
+
## References
|
|
624
|
+
|
|
625
|
+
- Jez Humble & David Farley - *Continuous Delivery*
|
|
626
|
+
- Gene Kim - *The DevOps Handbook*
|
|
627
|
+
- Nicole Forsgren - *Accelerate*
|
|
628
|
+
- Martin Fowler - *Continuous Integration*
|