@umacloud/knowledge 1.0.1

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 (418) hide show
  1. package/00-governance/governance-capabilities.md +557 -0
  2. package/00-governance/knowledge-map.md +39 -0
  3. package/00-governance/maintenance-policy.md +76 -0
  4. package/00-governance/review-checklist.md +81 -0
  5. package/README.md +13 -0
  6. package/ai/01-standards/agent-development-complete.md +691 -0
  7. package/ai/01-standards/llm-application-complete.md +488 -0
  8. package/ai/01-standards/mlops-complete.md +798 -0
  9. package/ai/01-standards/prompt-engineering-complete.md +646 -0
  10. package/ai/01-standards/rag-architecture-complete.md +649 -0
  11. package/ai/02-playbooks/llm-evaluation-playbook.md +847 -0
  12. package/ai/03-checklists/ai-project-checklist.md +215 -0
  13. package/ai/04-antipatterns/ai-antipatterns.md +661 -0
  14. package/ai/05-cases/case-rag-production.md +147 -0
  15. package/ai/06-glossary/ai-glossary.md +162 -0
  16. package/ai/agent-evaluation-benchmark.md +53 -0
  17. package/ai/ai-agent-memory-context-management.md +41 -0
  18. package/ai/ai-cost-capacity-optimization-playbook.md +42 -0
  19. package/ai/ai-data-security-and-compliance-playbook.md +37 -0
  20. package/ai/ai-domain-index-and-checklist.md +40 -0
  21. package/ai/ai-governance-maturity-model.md +50 -0
  22. package/ai/ai-model-selection-and-routing-strategy.md +47 -0
  23. package/ai/ai-observability-and-oncall-runbook.md +52 -0
  24. package/ai/ai-rag-engineering-playbook.md +42 -0
  25. package/ai/ai-red-team-and-safety-evaluation.md +42 -0
  26. package/ai/ai-release-readiness-and-rollback-gate.md +42 -0
  27. package/ai/llm-agent-engineering-deep-dive.md +57 -0
  28. package/ai/prompt-and-tool-guardrails.md +52 -0
  29. package/api/01-standards/enterprise-api-standards.md +198 -0
  30. package/api/01-standards/rest-api-design-guide.md +63 -0
  31. package/api/02-playbooks/api-pagination-playbook.md +93 -0
  32. package/api/02-playbooks/graphql-production-playbook.md +176 -0
  33. package/api/03-checklists/api-review-checklist.md +55 -0
  34. package/api/04-antipatterns/api-antipatterns.md +112 -0
  35. package/architecture/01-standards/api-gateway-patterns.md +496 -0
  36. package/architecture/01-standards/cloud-native-patterns.md +644 -0
  37. package/architecture/01-standards/distributed-systems-patterns.md +591 -0
  38. package/architecture/01-standards/event-driven-architecture.md +595 -0
  39. package/architecture/01-standards/microservices-patterns-complete.md +968 -0
  40. package/architecture/01-standards/microservices-patterns.md +495 -0
  41. package/architecture/01-standards/system-design-interview.md +664 -0
  42. package/architecture/02-playbooks/microservices-patterns-playbook.md +137 -0
  43. package/architecture/02-playbooks/migration-playbook.md +780 -0
  44. package/architecture/02-playbooks/system-design-playbook.md +779 -0
  45. package/architecture/03-checklists/architecture-decision-checklist.md +297 -0
  46. package/architecture/04-antipatterns/architecture-antipatterns.md +417 -0
  47. package/architecture/05-cases/case-netflix-microservices.md +413 -0
  48. package/architecture/06-glossary/architecture-glossary.md +164 -0
  49. package/architecture/adr-template-and-examples.md +38 -0
  50. package/architecture/api-gateway-deep-dive.md +1291 -0
  51. package/architecture/configuration-management.md +1162 -0
  52. package/architecture/distributed-transactions.md +1220 -0
  53. package/architecture/microservices-complete.md +735 -0
  54. package/architecture/resilience-and-disaster-patterns.md +37 -0
  55. package/architecture/service-governance.md +1198 -0
  56. package/architecture/system-architecture-deep-dive.md +37 -0
  57. package/backend/01-standards/analytics-and-growth.md +65 -0
  58. package/backend/01-standards/api-and-error-conventions.md +120 -0
  59. package/backend/01-standards/application-layering-and-packaging.md +160 -0
  60. package/backend/01-standards/auth-implementation.md +104 -0
  61. package/backend/01-standards/backend-framework-idioms.md +74 -0
  62. package/backend/01-standards/background-jobs-and-async.md +66 -0
  63. package/backend/01-standards/caching-strategies-complete.md +390 -0
  64. package/backend/01-standards/config-and-observability.md +77 -0
  65. package/backend/01-standards/data-modeling-and-persistence.md +94 -0
  66. package/backend/01-standards/django-complete.md +1765 -0
  67. package/backend/01-standards/email-and-notifications.md +64 -0
  68. package/backend/01-standards/fastapi-complete.md +925 -0
  69. package/backend/01-standards/file-upload-and-storage.md +66 -0
  70. package/backend/01-standards/graphql-api-complete.md +416 -0
  71. package/backend/01-standards/llm-application-standard.md +78 -0
  72. package/backend/01-standards/message-queue-patterns.md +379 -0
  73. package/backend/01-standards/microservices-and-distributed.md +78 -0
  74. package/backend/01-standards/nestjs-complete.md +2167 -0
  75. package/backend/01-standards/payment-integration.md +80 -0
  76. package/backend/01-standards/rate-limiting-complete.md +451 -0
  77. package/backend/01-standards/realtime-and-websocket.md +65 -0
  78. package/backend/01-standards/search-and-filtering.md +64 -0
  79. package/backend/01-standards/spring-boot-complete.md +445 -0
  80. package/backend/02-playbooks/api-design-playbook.md +718 -0
  81. package/backend/02-playbooks/email-send-playbook.md +130 -0
  82. package/backend/02-playbooks/file-upload-s3-playbook.md +153 -0
  83. package/backend/02-playbooks/typescript-enterprise-playbook.md +133 -0
  84. package/backend/02-playbooks/websocket-realtime-playbook.md +154 -0
  85. package/backend/03-checklists/api-launch-checklist.md +189 -0
  86. package/backend/04-antipatterns/backend-antipatterns.md +1051 -0
  87. package/blockchain/01-standards/blockchain-basics.md +557 -0
  88. package/blockchain/01-standards/smart-contract-development.md +1315 -0
  89. package/cicd/01-standards/deployment-and-delivery-standard.md +96 -0
  90. package/cicd/01-standards/github-actions-complete.md +473 -0
  91. package/cicd/01-standards/release-and-store-submission.md +75 -0
  92. package/cicd/02-playbooks/cicd-pipeline-playbook.md +144 -0
  93. package/cicd/02-playbooks/release-management-playbook.md +605 -0
  94. package/cicd/03-checklists/pipeline-security-checklist.md +168 -0
  95. package/cicd/04-antipatterns/cicd-antipatterns.md +589 -0
  96. package/cicd/05-cases/case-deployment-automation.md +221 -0
  97. package/cicd/05-cases/case-gitops-transformation.md +212 -0
  98. package/cicd/06-glossary/cicd-glossary.md +114 -0
  99. package/cicd/cicd-blueprint-deep-dive.md +38 -0
  100. package/cicd/release-readiness-gate.md +37 -0
  101. package/cloud-native/01-standards/container-security.md +741 -0
  102. package/cloud-native/01-standards/kubernetes-complete.md +812 -0
  103. package/cloud-native/02-playbooks/api-gateway-playbook.md +155 -0
  104. package/cloud-native/02-playbooks/gitops-with-argocd.md +760 -0
  105. package/cloud-native/02-playbooks/k8s-troubleshooting-playbook.md +1942 -0
  106. package/cloud-native/02-playbooks/message-queue-playbook.md +129 -0
  107. package/cloud-native/02-playbooks/multicloud-governance.md +726 -0
  108. package/cloud-native/02-playbooks/serverless-patterns.md +788 -0
  109. package/cloud-native/02-playbooks/service-mesh-playbook.md +612 -0
  110. package/cloud-native/02-playbooks/terraform-iac-playbook.md +143 -0
  111. package/cloud-native/03-checklists/container-security-checklist.md +431 -0
  112. package/cloud-native/03-checklists/k8s-production-readiness-checklist.md +460 -0
  113. package/cloud-native/04-antipatterns/container-antipatterns.md +660 -0
  114. package/cloud-native/04-antipatterns/k8s-antipatterns.md +743 -0
  115. package/cloud-native/05-cases/case-k8s-migration.md +478 -0
  116. package/cloud-native/05-cases/case-k8s-scaling.md +642 -0
  117. package/cloud-native/05-cases/case-k8s-security-incident.md +397 -0
  118. package/cloud-native/06-glossary/cloud-native-glossary.md +337 -0
  119. package/cross-platform/01-standards/cross-platform-frameworks.md +83 -0
  120. package/cross-platform/01-standards/platform-selection-and-architecture.md +77 -0
  121. package/data/01-standards/elasticsearch-complete.md +2098 -0
  122. package/data/01-standards/postgresql-complete.md +1613 -0
  123. package/data/01-standards/redis-complete.md +1527 -0
  124. package/data/02-playbooks/database-optimization-playbook.md +403 -0
  125. package/data/02-playbooks/elasticsearch-production-playbook.md +132 -0
  126. package/data/03-checklists/database-launch-checklist.md +187 -0
  127. package/data/04-antipatterns/database-antipatterns.md +873 -0
  128. package/data/05-cases/case-database-migration.md +310 -0
  129. package/data/06-glossary/database-glossary.md +440 -0
  130. package/data/data-governance-and-modeling-deep-dive.md +39 -0
  131. package/data-engineering/01-standards/airflow-complete.md +523 -0
  132. package/data-engineering/01-standards/kafka-complete.md +1521 -0
  133. package/data-engineering/02-playbooks/spark-etl-playbook.md +496 -0
  134. package/data-engineering/03-checklists/pipeline-launch-checklist.md +194 -0
  135. package/data-engineering/04-antipatterns/data-pipeline-antipatterns.md +684 -0
  136. package/data-engineering/05-cases/case-real-time-pipeline.md +355 -0
  137. package/data-engineering/06-glossary/data-engineering-glossary.md +429 -0
  138. package/database/01-standards/database-schema-standards.md +147 -0
  139. package/database/02-playbooks/postgresql-optimization-quick.md +52 -0
  140. package/database/02-playbooks/postgresql-performance-optimization.md +58 -0
  141. package/database/02-playbooks/postgresql-production-playbook.md +146 -0
  142. package/database/02-playbooks/redis-caching-playbook.md +117 -0
  143. package/database/03-checklists/database-review-checklist.md +50 -0
  144. package/database/04-antipatterns/database-antipatterns.md +112 -0
  145. package/design/01-standards/ui-design-system-complete.md +423 -0
  146. package/design/02-playbooks/design-handoff-playbook.md +254 -0
  147. package/design/02-playbooks/design-review-playbook.md +388 -0
  148. package/design/03-checklists/design-review-checklist.md +246 -0
  149. package/design/04-antipatterns/design-antipatterns.md +378 -0
  150. package/design/05-cases/case-design-system-adoption.md +328 -0
  151. package/design/06-glossary/design-glossary.md +329 -0
  152. package/design/ui-full-lifecycle-cross-platform-playbook.md +571 -0
  153. package/design/ux-system-deep-dive.md +38 -0
  154. package/design-systems/00-craft-rules.md +71 -0
  155. package/design-systems/aesthetic-families.md +43 -0
  156. package/design-systems/anti-ai-slop.md +162 -0
  157. package/design-systems/bold-geometric.md +120 -0
  158. package/design-systems/brutalist-bold.md +103 -0
  159. package/design-systems/editorial-clean.md +109 -0
  160. package/design-systems/glass-aurora.md +108 -0
  161. package/design-systems/modern-minimal.md +145 -0
  162. package/design-systems/premium-luxury.md +106 -0
  163. package/design-systems/product-type-design-map.md +48 -0
  164. package/design-systems/soft-warm.md +123 -0
  165. package/design-systems/tech-utility.md +113 -0
  166. package/desktop/01-standards/desktop-app-standard.md +72 -0
  167. package/desktop/01-standards/desktop-design.md +71 -0
  168. package/development/00-governance/document-template.md +41 -0
  169. package/development/01-standards/api-versioning-strategies.md +432 -0
  170. package/development/01-standards/authentication-patterns-complete.md +479 -0
  171. package/development/01-standards/css-architecture-complete.md +550 -0
  172. package/development/01-standards/database-migration-strategies.md +484 -0
  173. package/development/01-standards/elasticsearch-complete.md +347 -0
  174. package/development/01-standards/git-complete.md +371 -0
  175. package/development/01-standards/golang-complete.md +1565 -0
  176. package/development/01-standards/graphql-complete.md +298 -0
  177. package/development/01-standards/javascript-bundlers-complete.md +469 -0
  178. package/development/01-standards/javascript-typescript-complete.md +528 -0
  179. package/development/01-standards/jest-complete.md +275 -0
  180. package/development/01-standards/linux-complete.md +234 -0
  181. package/development/01-standards/logging-observability-complete.md +526 -0
  182. package/development/01-standards/microservices-communication.md +502 -0
  183. package/development/01-standards/mongodb-complete.md +406 -0
  184. package/development/01-standards/oauth2-complete.md +285 -0
  185. package/development/01-standards/performance-optimization-complete.md +289 -0
  186. package/development/01-standards/playwright-complete.md +247 -0
  187. package/development/01-standards/postgresql-complete.md +456 -0
  188. package/development/01-standards/pytest-complete.md +340 -0
  189. package/development/01-standards/python-async-programming.md +902 -0
  190. package/development/01-standards/python-complete.md +956 -0
  191. package/development/01-standards/python-decorators-complete.md +799 -0
  192. package/development/01-standards/python-design-patterns.md +2854 -0
  193. package/development/01-standards/python-packaging-distribution.md +420 -0
  194. package/development/01-standards/python-testing-strategies.md +607 -0
  195. package/development/01-standards/python-web-frameworks-comparison.md +471 -0
  196. package/development/01-standards/redis-complete.md +317 -0
  197. package/development/01-standards/rest-api-complete.md +316 -0
  198. package/development/01-standards/rust-complete.md +578 -0
  199. package/development/01-standards/typescript-advanced-types.md +1513 -0
  200. package/development/01-standards/web-security-complete.md +292 -0
  201. package/development/02-playbooks/api-design-playbook.md +810 -0
  202. package/development/02-playbooks/database-migration-playbook.md +580 -0
  203. package/development/02-playbooks/debugging-playbook.md +692 -0
  204. package/development/02-playbooks/feature-delivery-playbook.md +430 -0
  205. package/development/02-playbooks/incident-hotfix-playbook.md +387 -0
  206. package/development/02-playbooks/performance-optimization-playbook.md +531 -0
  207. package/development/02-playbooks/performance-tuning-playbook.md +652 -0
  208. package/development/02-playbooks/refactor-playbook.md +403 -0
  209. package/development/02-playbooks/release-playbook.md +469 -0
  210. package/development/03-checklists/architecture-review-checklist.md +168 -0
  211. package/development/03-checklists/data-migration-checklist.md +157 -0
  212. package/development/03-checklists/oncall-handover-checklist.md +173 -0
  213. package/development/03-checklists/pr-checklist.md +158 -0
  214. package/development/03-checklists/production-readiness-checklist.md +190 -0
  215. package/development/03-checklists/release-readiness-checklist.md +154 -0
  216. package/development/03-checklists/security-review-checklist.md +182 -0
  217. package/development/04-antipatterns/api-antipatterns.md +657 -0
  218. package/development/04-antipatterns/architecture-antipatterns.md +686 -0
  219. package/development/04-antipatterns/backend-antipatterns.md +648 -0
  220. package/development/04-antipatterns/cicd-antipatterns.md +540 -0
  221. package/development/04-antipatterns/code-smell-antipatterns.md +571 -0
  222. package/development/04-antipatterns/data-antipatterns.md +658 -0
  223. package/development/04-antipatterns/database-antipatterns.md +578 -0
  224. package/development/04-antipatterns/frontend-antipatterns.md +635 -0
  225. package/development/04-antipatterns/reliability-antipatterns.md +700 -0
  226. package/development/04-antipatterns/security-antipatterns.md +747 -0
  227. package/development/05-cases/case-api-version-migration.md +428 -0
  228. package/development/05-cases/case-authorization-hardening.md +383 -0
  229. package/development/05-cases/case-bluegreen-rollback.md +466 -0
  230. package/development/05-cases/case-cache-snowball-protection.md +485 -0
  231. package/development/05-cases/case-ci-cd-pipeline.md +544 -0
  232. package/development/05-cases/case-database-scaling.md +500 -0
  233. package/development/05-cases/case-db-hotspot-optimization.md +487 -0
  234. package/development/05-cases/case-incident-mttr-reduction.md +563 -0
  235. package/development/05-cases/case-microservice-migration.md +375 -0
  236. package/development/05-cases/case-performance-optimization.md +406 -0
  237. package/development/05-cases/case-security-incident-response.md +345 -0
  238. package/development/06-glossary/full-stack-glossary.md +166 -0
  239. package/development/09-maturity/quarterly-audit-template.md +35 -0
  240. package/development/11-ui-excellence/ui-aesthetic-system.md +41 -0
  241. package/development/11-ui-excellence/ui-engineering-excellence.md +435 -0
  242. package/development/12-scenarios/development-scenarios-guide.md +565 -0
  243. package/development/13-implementation-assets/implementation-toolkit.md +282 -0
  244. package/development/13-implementation-assets/knowledge-gates-execution.md +43 -0
  245. package/development/14-full-lifecycle/software-lifecycle-gates.md +511 -0
  246. package/development/15-lifecycle-templates/project-templates-collection.md +791 -0
  247. package/development/api-contract-and-versioning-guide.md +36 -0
  248. package/development/api-governance-complete.md +43 -0
  249. package/development/backend-engineering-complete.md +43 -0
  250. package/development/code-review-quality-complete.md +43 -0
  251. package/development/concurrency-reliability-complete.md +43 -0
  252. package/development/database-engineering-complete.md +43 -0
  253. package/development/engineering-effectiveness-complete.md +43 -0
  254. package/development/engineering-standards-deep-dive.md +38 -0
  255. package/development/frontend-engineering-complete.md +43 -0
  256. package/development/performance-capacity-complete.md +43 -0
  257. package/development/refactor-migration-complete.md +42 -0
  258. package/development/refactoring-and-techdebt-playbook.md +37 -0
  259. package/development/security-in-development-complete.md +43 -0
  260. package/devops/01-standards/cicd-pipeline-complete.md +262 -0
  261. package/devops/01-standards/docker-complete.md +1490 -0
  262. package/devops/01-standards/github-actions-complete.md +337 -0
  263. package/devops/01-standards/kubernetes-complete.md +638 -0
  264. package/devops/01-standards/terraform-complete.md +2117 -0
  265. package/devops/02-playbooks/docker-compose-playbook.md +233 -0
  266. package/devops/02-playbooks/docker-k8s-production-playbook.md +186 -0
  267. package/devops/02-playbooks/docker-production-playbook.md +952 -0
  268. package/edge-iot/01-standards/edge-iot-complete.md +473 -0
  269. package/experts/architect/api-design.md +178 -0
  270. package/experts/architect/methodology.md +124 -0
  271. package/experts/architect/security.md +75 -0
  272. package/experts/backend-lead/methodology.md +216 -0
  273. package/experts/devops/methodology.md +160 -0
  274. package/experts/frontend-lead/methodology.md +178 -0
  275. package/experts/product-manager/industry/ecommerce.md +43 -0
  276. package/experts/product-manager/industry/saas.md +40 -0
  277. package/experts/product-manager/methodology.md +97 -0
  278. package/experts/qa-lead/methodology.md +123 -0
  279. package/experts/qa-lead/test-strategy.md +128 -0
  280. package/experts/uiux-designer/methodology.md +125 -0
  281. package/frontend/01-standards/accessibility-complete.md +532 -0
  282. package/frontend/01-standards/accessibility-standard.md +74 -0
  283. package/frontend/01-standards/admin-dashboard-and-crud.md +72 -0
  284. package/frontend/01-standards/design-tokens-complete.md +444 -0
  285. package/frontend/01-standards/forms-and-validation.md +77 -0
  286. package/frontend/01-standards/frontend-architecture-and-layering.md +119 -0
  287. package/frontend/01-standards/i18n-and-localization.md +65 -0
  288. package/frontend/01-standards/nextjs-complete.md +451 -0
  289. package/frontend/01-standards/react-complete.md +713 -0
  290. package/frontend/01-standards/react-hooks-complete-guide.md +1100 -0
  291. package/frontend/01-standards/react-hooks-complete.md +1171 -0
  292. package/frontend/01-standards/seo-and-web-vitals.md +77 -0
  293. package/frontend/01-standards/state-management-complete.md +444 -0
  294. package/frontend/01-standards/vue-complete.md +499 -0
  295. package/frontend/01-standards/vue3-complete.md +2002 -0
  296. package/frontend/01-standards/web-framework-best-practices.md +64 -0
  297. package/frontend/01-standards/web-performance-complete.md +495 -0
  298. package/frontend/02-playbooks/accessibility-a11y-playbook.md +161 -0
  299. package/frontend/02-playbooks/frontend-performance-playbook.md +707 -0
  300. package/frontend/02-playbooks/i18n-internationalization-playbook.md +120 -0
  301. package/frontend/02-playbooks/performance-optimization-playbook.md +163 -0
  302. package/frontend/02-playbooks/react-nextjs-production-playbook.md +167 -0
  303. package/frontend/02-playbooks/react-state-management-playbook.md +173 -0
  304. package/frontend/03-checklists/component-quality-checklist.md +166 -0
  305. package/frontend/03-checklists/frontend-launch-checklist.md +299 -0
  306. package/frontend/04-antipatterns/frontend-antipatterns.md +886 -0
  307. package/frontend/05-cases/case-performance-optimization.md +274 -0
  308. package/harmony/01-standards/harmonyos-arkts-standard.md +75 -0
  309. package/harmony/01-standards/harmonyos-design.md +65 -0
  310. package/high-quality-engineering-playbook.md +54 -0
  311. package/incident/01-standards/incident-response-complete.md +303 -0
  312. package/incident/02-playbooks/chaos-engineering-playbook.md +883 -0
  313. package/incident/02-playbooks/postmortem-playbook.md +398 -0
  314. package/incident/03-checklists/incident-readiness-checklist.md +181 -0
  315. package/incident/04-antipatterns/incident-antipatterns.md +490 -0
  316. package/incident/05-cases/case-cascade-failure.md +176 -0
  317. package/incident/06-glossary/incident-glossary.md +114 -0
  318. package/incident/postmortem-and-response-deep-dive.md +39 -0
  319. package/industries/ecommerce/ecommerce-complete.md +631 -0
  320. package/industries/education/education-complete.md +555 -0
  321. package/industries/fintech/fintech-complete.md +501 -0
  322. package/industries/gaming/gaming-complete.md +587 -0
  323. package/industries/healthcare/healthcare-complete.md +452 -0
  324. package/low-code/01-standards/low-code-complete.md +944 -0
  325. package/miniprogram/01-standards/ai-common-mistakes.md +61 -0
  326. package/miniprogram/01-standards/miniprogram-custom-navbar-capsule.md +77 -0
  327. package/miniprogram/01-standards/miniprogram-design.md +61 -0
  328. package/miniprogram/01-standards/miniprogram-standard.md +81 -0
  329. package/mobile/01-standards/android-material-design.md +70 -0
  330. package/mobile/01-standards/flutter-complete.md +384 -0
  331. package/mobile/01-standards/ios-design-hig.md +78 -0
  332. package/mobile/01-standards/mobile-app-standard.md +85 -0
  333. package/mobile/01-standards/react-native-complete.md +352 -0
  334. package/mobile/02-playbooks/mobile-cross-platform-playbook.md +175 -0
  335. package/mobile/02-playbooks/mobile-performance.md +473 -0
  336. package/mobile/03-checklists/mobile-release-checklist.md +234 -0
  337. package/mobile/04-antipatterns/mobile-antipatterns.md +798 -0
  338. package/mobile/05-cases/case-app-performance.md +500 -0
  339. package/mobile/05-cases/case-app-startup-optimization.md +218 -0
  340. package/mobile/06-glossary/mobile-glossary.md +484 -0
  341. package/observability/01-standards/observability-standards.md +103 -0
  342. package/observability/02-playbooks/prometheus-grafana-playbook.md +135 -0
  343. package/observability/02-playbooks/structured-logging-playbook.md +73 -0
  344. package/observability/03-checklists/observability-checklist.md +54 -0
  345. package/observability/04-antipatterns/observability-antipatterns.md +106 -0
  346. package/operations/01-standards/prometheus-monitoring-complete.md +1578 -0
  347. package/operations/02-playbooks/capacity-planning-playbook.md +620 -0
  348. package/operations/03-checklists/production-launch-checklist.md +365 -0
  349. package/operations/04-antipatterns/operations-antipatterns.md +664 -0
  350. package/operations/05-cases/case-sre-practices.md +581 -0
  351. package/operations/06-glossary/operations-glossary.md +120 -0
  352. package/operations/aiops-anomaly-detection.md +758 -0
  353. package/operations/capacity-planning.md +1061 -0
  354. package/operations/chaos-engineering.md +659 -0
  355. package/operations/incident-command-system.md +38 -0
  356. package/operations/observability-complete.md +442 -0
  357. package/operations/slo-sli-playbook.md +517 -0
  358. package/operations/sre-operations-deep-dive.md +39 -0
  359. package/package.json +8 -0
  360. package/performance/01-standards/performance-and-scalability.md +80 -0
  361. package/performance/01-standards/performance-standards.md +156 -0
  362. package/performance/02-playbooks/query-optimization-playbook.md +103 -0
  363. package/performance/03-checklists/performance-checklist.md +56 -0
  364. package/performance/04-antipatterns/performance-antipatterns.md +146 -0
  365. package/product/01-standards/product-management-complete.md +285 -0
  366. package/product/02-playbooks/feature-launch-playbook.md +207 -0
  367. package/product/02-playbooks/user-research-playbook.md +532 -0
  368. package/product/03-checklists/feature-launch-checklist.md +275 -0
  369. package/product/04-antipatterns/product-antipatterns.md +355 -0
  370. package/product/05-cases/case-mvp-to-scale.md +384 -0
  371. package/product/06-glossary/product-glossary.md +462 -0
  372. package/product/feature-prioritization-framework.md +40 -0
  373. package/product/kpi-and-metric-tree.md +37 -0
  374. package/product/product-discovery-and-prd-deep-dive.md +41 -0
  375. package/quantum/01-standards/quantum-complete.md +1186 -0
  376. package/security/01-standards/api-security-complete.md +511 -0
  377. package/security/01-standards/container-runtime-security.md +574 -0
  378. package/security/01-standards/data-protection-gdpr.md +543 -0
  379. package/security/01-standards/owasp-top10-complete.md +1890 -0
  380. package/security/01-standards/secure-coding-baseline.md +90 -0
  381. package/security/01-standards/supply-chain-security.md +441 -0
  382. package/security/01-standards/web-security-checklist.md +108 -0
  383. package/security/01-standards/zero-trust-architecture.md +521 -0
  384. package/security/02-playbooks/auth-sso-playbook.md +166 -0
  385. package/security/02-playbooks/incident-response-security-playbook.md +588 -0
  386. package/security/02-playbooks/owasp-api-security-playbook.md +129 -0
  387. package/security/02-playbooks/payment-integration-playbook.md +119 -0
  388. package/security/02-playbooks/penetration-testing-playbook.md +517 -0
  389. package/security/03-checklists/security-audit-checklist.md +356 -0
  390. package/security/04-antipatterns/security-coding-antipatterns.md +580 -0
  391. package/security/05-cases/case-log4shell-incident.md +537 -0
  392. package/security/05-cases/case-major-breaches.md +468 -0
  393. package/security/06-glossary/security-glossary.md +212 -0
  394. package/security/compliance-automation.md +993 -0
  395. package/security/container-security.md +680 -0
  396. package/security/devsecops-complete.md +426 -0
  397. package/security/sast-dast-sca.md +775 -0
  398. package/security/secrets-management.md +594 -0
  399. package/security/security-architecture-deep-dive.md +37 -0
  400. package/security/threat-modeling-stride-playbook.md +40 -0
  401. package/seed-templates/auth-system.md +59 -0
  402. package/seed-templates/blog-content.md +94 -0
  403. package/seed-templates/dashboard.md +89 -0
  404. package/seed-templates/docs-site.md +73 -0
  405. package/seed-templates/e-commerce.md +50 -0
  406. package/seed-templates/saas-landing.md +92 -0
  407. package/seed-templates/settings-page.md +51 -0
  408. package/testing/01-standards/test-strategy-and-layering.md +83 -0
  409. package/testing/01-standards/testing-strategy-complete.md +422 -0
  410. package/testing/01-standards/unit-testing-best-practices.md +118 -0
  411. package/testing/02-playbooks/e2e-testing-playbook.md +988 -0
  412. package/testing/02-playbooks/testing-strategy-playbook.md +126 -0
  413. package/testing/03-checklists/test-strategy-checklist.md +208 -0
  414. package/testing/04-antipatterns/testing-antipatterns.md +718 -0
  415. package/testing/05-cases/case-testing-transformation.md +300 -0
  416. package/testing/06-glossary/testing-glossary.md +110 -0
  417. package/testing/risk-based-test-matrix.md +36 -0
  418. package/testing/testing-strategy-deep-dive.md +37 -0
@@ -0,0 +1,310 @@
1
+ ---
2
+ id: case-database-migration
3
+ title: 数据库迁移案例:MySQL 到 PostgreSQL 的实战迁移
4
+ domain: data
5
+ category: 05-cases
6
+ difficulty: intermediate
7
+ tags: [10-11, agent, case, checklist, data, database, migration, 概述]
8
+ quality_score: 70
9
+ last_updated: 2026-06-15
10
+ ---
11
+ # 数据库迁移案例:MySQL 到 PostgreSQL 的实战迁移
12
+
13
+ ## 概述
14
+
15
+ 本案例记录一个中型 SaaS 平台从 MySQL 5.7 迁移到 PostgreSQL 15 的完整过程。系统包含 120 张表,总数据量 800GB,日均写入 500 万行。迁移目标:零数据丢失、停机时间 < 30 分钟。团队规模 4 人(2 后端 + 1 DBA + 1 QA),总周期 12 周。
16
+
17
+ ### 迁移动机
18
+
19
+ 1. MySQL 5.7 即将 EOL,升级到 MySQL 8.0 的兼容性问题多
20
+ 2. 业务需要 JSON 字段高级查询(PostgreSQL JSONB 支持更好)
21
+ 3. 需要 CTE(递归查询)处理组织树结构
22
+ 4. 需要物化视图支持复杂报表场景
23
+ 5. 许可成本考虑(团队更熟悉 PostgreSQL 生态)
24
+
25
+ ---
26
+
27
+ ## 第一阶段:评估与规划(第 1-2 周)
28
+
29
+ ### 兼容性评估
30
+
31
+ | MySQL 特性 | PostgreSQL 等价 | 迁移难度 |
32
+ |-----------|----------------|---------|
33
+ | AUTO_INCREMENT | SERIAL / IDENTITY | 低 |
34
+ | TINYINT(1) 布尔 | BOOLEAN | 低 |
35
+ | ENUM 类型 | CREATE TYPE ... AS ENUM | 中 |
36
+ | ON UPDATE CURRENT_TIMESTAMP | 触发器实现 | 中 |
37
+ | GROUP_CONCAT | STRING_AGG | 低 |
38
+ | IFNULL | COALESCE | 低 |
39
+ | LIMIT offset, count | LIMIT count OFFSET offset | 低 |
40
+ | 反引号标识符 | 双引号标识符 | 低 |
41
+ | utf8mb4 | UTF8(默认即 UTF-8) | 低 |
42
+ | 存储过程 | 需要重写(PL/pgSQL 语法不同) | 高 |
43
+ | 全文搜索 MATCH AGAINST | tsvector + tsquery | 高 |
44
+
45
+ ### 风险评估
46
+
47
+ | 风险项 | 概率 | 影响 | 缓解措施 |
48
+ |--------|------|------|---------|
49
+ | 数据类型不兼容 | 中 | 高 | 提前做类型映射表,逐表验证 |
50
+ | SQL 语法差异 | 高 | 中 | 应用层全面回归测试 |
51
+ | 性能差异 | 中 | 高 | 关键查询在 PG 上重新 benchmark |
52
+ | 迁移期间数据不一致 | 低 | 极高 | 双写 + 校验脚本 |
53
+ | 回滚复杂 | 低 | 高 | 保留 MySQL 实例 2 周不下线 |
54
+
55
+ ### 迁移方案选定
56
+
57
+ 经过评估,选择 **双写双读 + 灰度切换** 方案:
58
+
59
+ ```
60
+ 阶段 1:MySQL 为主,PG 为从(双写 MySQL + PG,读 MySQL)
61
+ 阶段 2:PG 为主,MySQL 为从(双写 PG + MySQL,读 PG)
62
+ 阶段 3:仅 PG(停止 MySQL 写入,保留观察期)
63
+ ```
64
+
65
+ ---
66
+
67
+ ## 第二阶段:Schema 迁移(第 3-4 周)
68
+
69
+ ### DDL 转换规则
70
+
71
+ ```sql
72
+ -- MySQL 原始表
73
+ CREATE TABLE orders (
74
+ id BIGINT UNSIGNED AUTO_INCREMENT PRIMARY KEY,
75
+ user_id BIGINT UNSIGNED NOT NULL,
76
+ status ENUM('pending', 'paid', 'shipped', 'completed', 'cancelled'),
77
+ total_amount DECIMAL(10,2) NOT NULL DEFAULT 0.00,
78
+ metadata JSON,
79
+ created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
80
+ updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
81
+ INDEX idx_user_status (user_id, status),
82
+ INDEX idx_created (created_at)
83
+ ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
84
+
85
+ -- PostgreSQL 转换后
86
+ CREATE TYPE order_status AS ENUM ('pending', 'paid', 'shipped', 'completed', 'cancelled');
87
+
88
+ CREATE TABLE orders (
89
+ id BIGINT GENERATED ALWAYS AS IDENTITY PRIMARY KEY,
90
+ user_id BIGINT NOT NULL,
91
+ status order_status,
92
+ total_amount NUMERIC(10,2) NOT NULL DEFAULT 0.00,
93
+ metadata JSONB,
94
+ created_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
95
+ updated_at TIMESTAMPTZ NOT NULL DEFAULT NOW()
96
+ );
97
+
98
+ CREATE INDEX idx_orders_user_status ON orders(user_id, status);
99
+ CREATE INDEX idx_orders_created ON orders(created_at);
100
+ CREATE INDEX idx_orders_metadata ON orders USING GIN (metadata);
101
+
102
+ -- updated_at 自动更新触发器
103
+ CREATE OR REPLACE FUNCTION update_updated_at()
104
+ RETURNS TRIGGER AS $$
105
+ BEGIN
106
+ NEW.updated_at = NOW();
107
+ RETURN NEW;
108
+ END;
109
+ $$ LANGUAGE plpgsql;
110
+
111
+ CREATE TRIGGER trg_orders_updated_at
112
+ BEFORE UPDATE ON orders
113
+ FOR EACH ROW EXECUTE FUNCTION update_updated_at();
114
+ ```
115
+
116
+ ### 关键类型映射
117
+
118
+ | MySQL 类型 | PostgreSQL 类型 | 注意事项 |
119
+ |-----------|----------------|---------|
120
+ | BIGINT UNSIGNED | BIGINT | PG 无 unsigned,值域需确认 |
121
+ | TINYINT(1) | BOOLEAN | 需转换 0/1 为 false/true |
122
+ | DATETIME | TIMESTAMPTZ | 统一使用带时区类型 |
123
+ | DOUBLE | DOUBLE PRECISION | 精度一致 |
124
+ | DECIMAL(M,D) | NUMERIC(M,D) | 语法兼容 |
125
+ | TEXT / LONGTEXT | TEXT | PG 无长度限制 |
126
+ | BLOB | BYTEA | 二进制存储 |
127
+ | JSON | JSONB | 推荐用 JSONB(支持索引) |
128
+ | ENUM | CREATE TYPE AS ENUM | 需先创建类型 |
129
+
130
+ ### Schema 迁移工具
131
+
132
+ 使用 `pgloader` 自动转换 + 手动修正:
133
+
134
+ ```bash
135
+ pgloader mysql://user:pass@mysql-host/mydb postgresql://user:pass@pg-host/mydb
136
+
137
+ # pgloader 自动处理:类型映射、索引转换、数据迁移
138
+ # 手动修正:ENUM 类型、触发器、存储过程、全文搜索索引
139
+ ```
140
+
141
+ ---
142
+
143
+ ## 第三阶段:应用层适配(第 5-7 周)
144
+
145
+ ### ORM 层修改
146
+
147
+ ```
148
+ 1. 数据库驱动切换
149
+ - mysql2 → pg (Node.js)
150
+ - 或 Prisma / TypeORM 切换 provider
151
+
152
+ 2. 原生 SQL 修改(共 47 处)
153
+ - 反引号 → 双引号(标识符)
154
+ - IFNULL → COALESCE
155
+ - GROUP_CONCAT → STRING_AGG
156
+ - LIMIT x, y → LIMIT y OFFSET x
157
+ - NOW() → NOW()(兼容,无需改)
158
+ - DATE_FORMAT → TO_CHAR
159
+ - STR_TO_DATE → TO_TIMESTAMP
160
+
161
+ 3. 布尔值处理
162
+ - MySQL 的 0/1 → PostgreSQL 的 true/false
163
+ - ORM 层自动处理,原生 SQL 需修改
164
+
165
+ 4. 自增 ID 获取
166
+ - MySQL: LAST_INSERT_ID()
167
+ - PostgreSQL: RETURNING id(INSERT ... RETURNING id)
168
+ ```
169
+
170
+ ### 双写层实现
171
+
172
+ ```
173
+ 架构:
174
+ Application → WriteProxy → MySQL (主)
175
+ → PostgreSQL (从)
176
+
177
+ WriteProxy 逻辑:
178
+ 1. 先写 MySQL(主库)
179
+ 2. 异步写 PostgreSQL(失败记入重试队列)
180
+ 3. 写入结果以 MySQL 为准
181
+ 4. 定期校验两库数据一致性
182
+ ```
183
+
184
+ ### 全面回归测试
185
+
186
+ - 单元测试:将数据库 mock 切换为 PostgreSQL 行为验证
187
+ - 集成测试:全部对 PostgreSQL 运行,覆盖 120 个 API 端点
188
+ - 数据校验脚本:逐表对比行数、校验和、采样数据
189
+
190
+ ---
191
+
192
+ ## 第四阶段:数据全量迁移(第 8-9 周)
193
+
194
+ ### 迁移步骤
195
+
196
+ ```
197
+ 1. 停止非关键写入(维护窗口外的批处理任务)
198
+ 2. 使用 pgloader 全量迁移 800GB 数据
199
+ - 耗时约 6 小时(使用 8 并行线程)
200
+ - 迁移期间 MySQL 正常服务
201
+
202
+ 3. 启用增量同步
203
+ - 使用 Debezium 监听 MySQL binlog
204
+ - 实时同步增量变更到 PostgreSQL
205
+ - 延迟 < 5 秒
206
+
207
+ 4. 数据校验
208
+ - 全表行数对比(120 表全部匹配)
209
+ - 关键表随机采样 10000 行对比(无差异)
210
+ - 聚合数据校验(SUM/COUNT/MAX/MIN)
211
+ ```
212
+
213
+ ### 迁移遇到的问题
214
+
215
+ | 问题 | 原因 | 解决方案 |
216
+ |------|------|---------|
217
+ | 字符编码错误 | MySQL 中存在非法 UTF-8 字符 | 迁移前清洗数据 |
218
+ | 自增序列不连续 | pgloader 不自动设置序列起始值 | 手动 `SELECT setval()` |
219
+ | ENUM 值大小写 | MySQL ENUM 不区分大小写 | 应用层统一为小写 |
220
+ | 时区问题 | MySQL DATETIME 无时区 | 确认服务器时区一致后迁移为 TIMESTAMPTZ |
221
+ | 外键约束失败 | 迁移顺序不当 | 先禁用外键,全部迁移后再启用并验证 |
222
+
223
+ ---
224
+
225
+ ## 第五阶段:灰度切换(第 10-11 周)
226
+
227
+ ### 切换步骤
228
+
229
+ ```
230
+ 第 10 周:10% 读流量切到 PostgreSQL
231
+ - 监控响应时间、错误率
232
+ - 发现 3 个查询性能劣化,优化索引后解决
233
+
234
+ 第 10.5 周:50% 读流量切到 PostgreSQL
235
+ - 稳定运行 3 天
236
+ - 无异常
237
+
238
+ 第 11 周:100% 读流量切到 PostgreSQL
239
+ - 写仍走 MySQL,双写到 PostgreSQL
240
+ - 稳定运行 3 天
241
+
242
+ 第 11.5 周:写流量切到 PostgreSQL
243
+ - 停止 MySQL 写入
244
+ - PostgreSQL 成为唯一主库
245
+ - MySQL 保留只读,作为回滚保险
246
+ ```
247
+
248
+ ### 性能对比
249
+
250
+ | 查询类型 | MySQL 延迟 | PostgreSQL 延迟 | 变化 |
251
+ |---------|-----------|----------------|------|
252
+ | 简单主键查询 | 0.8ms | 0.6ms | -25% |
253
+ | 复杂 JOIN 查询 | 45ms | 32ms | -29% |
254
+ | JSON 字段查询 | 120ms | 18ms | -85% |
255
+ | 聚合报表查询 | 3200ms | 980ms | -69% |
256
+ | 全文搜索 | 85ms | 42ms | -51% |
257
+
258
+ ---
259
+
260
+ ## 第六阶段:收尾与清理(第 12 周)
261
+
262
+ ### 操作清单
263
+
264
+ - [ ] 确认 MySQL 停止接收写入已超过 7 天
265
+ - [ ] 最终数据一致性校验通过
266
+ - [ ] 移除应用中的双写逻辑和 MySQL 连接配置
267
+ - [ ] 移除 Debezium 增量同步
268
+ - [ ] MySQL 实例做最终全量备份后下线
269
+ - [ ] 更新运维文档(监控、备份、恢复流程)
270
+ - [ ] 更新开发者文档(连接信息、SQL 方言差异)
271
+ - [ ] 回顾会议总结经验教训
272
+
273
+ ---
274
+
275
+ ## 迁移总结
276
+
277
+ ### 最终成果
278
+
279
+ | 指标 | 迁移前(MySQL) | 迁移后(PostgreSQL) |
280
+ |------|-----------------|---------------------|
281
+ | 平均查询延迟 | 35ms | 22ms(-37%) |
282
+ | JSON 查询延迟 | 120ms | 18ms(-85%) |
283
+ | 报表生成时间 | 3.2s | 0.98s(-69%) |
284
+ | 停机时间 | - | 22 分钟(写切换窗口) |
285
+ | 数据丢失 | - | 0 行 |
286
+
287
+ ### 经验教训
288
+
289
+ 1. **双写方案虽复杂但安全** - 相比大爆炸切换,灰度切换让我们有足够信心
290
+ 2. **数据校验是核心** - 投入在校验脚本上的时间回报最高
291
+ 3. **SQL 兼容性低估** - 47 处原生 SQL 修改超出预期,应更早开始审查
292
+ 4. **性能不是问题** - PostgreSQL 在所有场景下性能持平或更好
293
+ 5. **保留旧库是保险** - MySQL 保留 2 周给了团队安全感
294
+
295
+ ---
296
+
297
+ ## Agent Checklist
298
+
299
+ 以下为 AI Agent 在执行数据库迁移任务时必须遵循的硬约束:
300
+
301
+ - [ ] 迁移前完成源库全量备份
302
+ - [ ] 建立完整的类型映射表并逐表验证
303
+ - [ ] 所有原生 SQL 语句审查并标记需修改项
304
+ - [ ] 迁移后运行全表行数对比校验
305
+ - [ ] 迁移后运行关键表采样数据校验
306
+ - [ ] 迁移后运行聚合数据校验(SUM/COUNT)
307
+ - [ ] 关键查询在目标库的 EXPLAIN ANALYZE 结果已确认
308
+ - [ ] 灰度切换方案已定义(不允许一次性全切)
309
+ - [ ] 回滚方案已验证可执行
310
+ - [ ] 生成迁移报告包含:数据校验结果、性能对比、问题记录