ccjk 14.1.10 → 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.
Files changed (119) hide show
  1. package/dist/chunks/agent-teams.mjs +1 -1
  2. package/dist/chunks/api-cli.mjs +1 -1
  3. package/dist/chunks/api-config-selector.mjs +3 -3
  4. package/dist/chunks/ccjk-all.mjs +1 -1
  5. package/dist/chunks/ccjk-mcp.mjs +1 -1
  6. package/dist/chunks/ccjk-setup.mjs +1 -1
  7. package/dist/chunks/ccr.mjs +8 -8
  8. package/dist/chunks/check-updates.mjs +1 -1
  9. package/dist/chunks/claude-code-incremental-manager.mjs +3 -3
  10. package/dist/chunks/claude-config.mjs +1 -1
  11. package/dist/chunks/codex-config-switch.mjs +1 -1
  12. package/dist/chunks/codex-provider-manager.mjs +1 -1
  13. package/dist/chunks/config-switch.mjs +1 -1
  14. package/dist/chunks/config.mjs +19 -3
  15. package/dist/chunks/config2.mjs +1 -1
  16. package/dist/chunks/config3.mjs +1 -1
  17. package/dist/chunks/doctor.mjs +175 -6
  18. package/dist/chunks/features.mjs +3 -3
  19. package/dist/chunks/index10.mjs +19 -5
  20. package/dist/chunks/init.mjs +5 -5
  21. package/dist/chunks/mcp-cli.mjs +3 -3
  22. package/dist/chunks/mcp.mjs +3 -3
  23. package/dist/chunks/package.mjs +1 -1
  24. package/dist/chunks/quick-provider.mjs +1 -1
  25. package/dist/chunks/quick-setup.mjs +5 -5
  26. package/dist/chunks/simple-config.mjs +1 -1
  27. package/dist/chunks/smart-guide.mjs +1 -1
  28. package/dist/chunks/update.mjs +6 -6
  29. package/dist/chunks/zero-config.mjs +7 -4
  30. package/dist/cli.mjs +0 -0
  31. package/dist/index.d.mts +3 -0
  32. package/dist/index.d.ts +3 -0
  33. package/dist/index.mjs +1 -1
  34. package/dist/shared/{ccjk.BJ3Zpjo5.mjs → ccjk.BCzOWT1L.mjs} +3 -2
  35. package/dist/shared/{ccjk.B8oqkakg.mjs → ccjk.BLsIiTqO.mjs} +1 -1
  36. package/dist/shared/{ccjk.Hwoicrh8.mjs → ccjk.BXv8aYs1.mjs} +1 -1
  37. package/dist/shared/{ccjk.B9OuS4xZ.mjs → ccjk.CfKJnpbB.mjs} +1 -1
  38. package/dist/shared/{ccjk.BzxpiEPF.mjs → ccjk.Cgv_cFVX.mjs} +2 -2
  39. package/dist/shared/{ccjk.Di1IYU3u.mjs → ccjk.DDL-4C-k.mjs} +47 -10
  40. package/dist/shared/{ccjk.BEiR3L4C.mjs → ccjk.DOw7Fawt.mjs} +3 -3
  41. package/dist/shared/{ccjk.tI_s2uSh.mjs → ccjk.f3TBLJSt.mjs} +1 -1
  42. package/dist/templates/agents/README.md +78 -0
  43. package/dist/templates/common/error-prevention.md +267 -0
  44. package/dist/templates/common/karpathy-baseline.md +83 -0
  45. package/dist/templates/common/output-styles/zh-CN/carmack-mode.md +381 -0
  46. package/dist/templates/common/output-styles/zh-CN/dhh-mode.md +265 -0
  47. package/dist/templates/common/output-styles/zh-CN/evan-you-mode.md +539 -0
  48. package/dist/templates/common/output-styles/zh-CN/jobs-mode.md +369 -0
  49. package/dist/templates/common/output-styles/zh-CN/linus-mode.md +135 -0
  50. package/dist/templates/common/output-styles/zh-CN/uncle-bob-mode.md +221 -0
  51. package/dist/templates/common/workflow/continuousDelivery/en/continuous-delivery.md +628 -0
  52. package/dist/templates/common/workflow/continuousDelivery/zh-CN/continuous-delivery.md +628 -0
  53. package/dist/templates/common/workflow/essential/en/agents/ccjk-config-agent.md +187 -0
  54. package/dist/templates/common/workflow/essential/en/agents/ccjk-mcp-agent.md +191 -0
  55. package/dist/templates/common/workflow/essential/en/agents/ccjk-skill-agent.md +249 -0
  56. package/dist/templates/common/workflow/essential/en/agents/ccjk-workflow-agent.md +277 -0
  57. package/dist/templates/common/workflow/essential/en/agents/get-current-datetime.md +29 -0
  58. package/dist/templates/common/workflow/essential/en/agents/init-architect.md +115 -0
  59. package/dist/templates/common/workflow/essential/en/agents/ui-ux-designer.md +91 -0
  60. package/dist/templates/common/workflow/essential/en/feat.md +92 -0
  61. package/dist/templates/common/workflow/essential/en/goal.md +147 -0
  62. package/dist/templates/common/workflow/essential/en/init-project.md +53 -0
  63. package/dist/templates/common/workflow/essential/zh-CN/agents/get-current-datetime.md +29 -0
  64. package/dist/templates/common/workflow/essential/zh-CN/agents/init-architect.md +115 -0
  65. package/dist/templates/common/workflow/essential/zh-CN/agents/ui-ux-designer.md +91 -0
  66. package/dist/templates/common/workflow/essential/zh-CN/feat.md +315 -0
  67. package/dist/templates/common/workflow/essential/zh-CN/goal.md +146 -0
  68. package/dist/templates/common/workflow/essential/zh-CN/init-project.md +53 -0
  69. package/dist/templates/common/workflow/git/en/git-cleanBranches.md +102 -0
  70. package/dist/templates/common/workflow/git/en/git-commit.md +205 -0
  71. package/dist/templates/common/workflow/git/en/git-rollback.md +90 -0
  72. package/dist/templates/common/workflow/git/en/git-worktree.md +276 -0
  73. package/dist/templates/common/workflow/git/zh-CN/git-cleanBranches.md +102 -0
  74. package/dist/templates/common/workflow/git/zh-CN/git-commit.md +205 -0
  75. package/dist/templates/common/workflow/git/zh-CN/git-rollback.md +90 -0
  76. package/dist/templates/common/workflow/git/zh-CN/git-worktree.md +276 -0
  77. package/dist/templates/common/workflow/interview/en/interview.md +67 -0
  78. package/dist/templates/common/workflow/interview/zh-CN/interview.md +67 -0
  79. package/dist/templates/common/workflow/linearMethod/en/linear-method.md +651 -0
  80. package/dist/templates/common/workflow/linearMethod/zh-CN/linear-method.md +752 -0
  81. package/dist/templates/common/workflow/refactoringMaster/en/refactoring-master.md +516 -0
  82. package/dist/templates/common/workflow/refactoringMaster/zh-CN/refactoring-master.md +812 -0
  83. package/dist/templates/common/workflow/sixStep/en/workflow.md +83 -0
  84. package/dist/templates/common/workflow/sixStep/zh-CN/workflow.md +359 -0
  85. package/dist/templates/common/workflow/specFirstTDD/en/spec-first-tdd.md +364 -0
  86. package/dist/templates/common/workflow/specFirstTDD/zh-CN/spec-first-tdd.md +366 -0
  87. package/dist/templates/hooks/README.md +212 -0
  88. package/dist/templates/hooks/git-workflow-hooks.md +551 -0
  89. package/dist/templates/hooks/post-test-coverage.md +434 -0
  90. package/dist/templates/hooks/pre-commit-black.md +274 -0
  91. package/dist/templates/hooks/pre-commit-eslint.md +153 -0
  92. package/dist/templates/hooks/pre-commit-gofmt.md +284 -0
  93. package/dist/templates/hooks/pre-commit-prettier.md +212 -0
  94. package/dist/templates/hooks/pre-commit-type-check.md +377 -0
  95. package/dist/templates/skills/ccjk-init.md +154 -0
  96. package/dist/templates/skills/ccjk-mcp-setup.md +205 -0
  97. package/dist/templates/skills/ccjk-troubleshoot.md +228 -0
  98. package/dist/templates/skills/django-patterns.md +1016 -0
  99. package/dist/templates/skills/git-workflow.md +748 -0
  100. package/dist/templates/skills/go-idioms.md +963 -0
  101. package/dist/templates/skills/nextjs-optimization.md +694 -0
  102. package/dist/templates/skills/python-pep8.md +852 -0
  103. package/dist/templates/skills/react-patterns.md +686 -0
  104. package/dist/templates/skills/rust-patterns.md +1057 -0
  105. package/dist/templates/skills/security-best-practices.md +1413 -0
  106. package/dist/templates/skills/testing-best-practices.md +1315 -0
  107. package/dist/templates/skills/ts-best-practices.md +354 -0
  108. package/package.json +40 -43
  109. package/templates/common/karpathy-baseline.md +83 -0
  110. package/templates/common/output-styles/zh-CN/carmack-mode.md +14 -0
  111. package/templates/common/output-styles/zh-CN/dhh-mode.md +14 -0
  112. package/templates/common/output-styles/zh-CN/evan-you-mode.md +14 -0
  113. package/templates/common/output-styles/zh-CN/jobs-mode.md +14 -0
  114. package/templates/common/output-styles/zh-CN/linus-mode.md +14 -0
  115. package/templates/common/output-styles/zh-CN/uncle-bob-mode.md +14 -0
  116. package/templates/common/workflow/linearMethod/zh-CN/linear-method.md +2 -0
  117. package/templates/common/workflow/refactoringMaster/zh-CN/refactoring-master.md +2 -0
  118. package/templates/common/workflow/sixStep/zh-CN/workflow.md +2 -0
  119. 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*