@k2works/claude-code-booster 3.6.1 → 3.7.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 (713) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +42 -42
  3. package/bin/claude-code-booster +90 -90
  4. package/lib/assets/.claude/README.md +258 -239
  5. package/lib/assets/.claude/agent-memory/xp-programmer/MEMORY.md +6 -0
  6. package/lib/assets/.claude/agent-memory/xp-programmer/project_cargo_tracker.md +11 -0
  7. package/lib/assets/.claude/agent-memory/xp-programmer/project_ddd_patterns.md +27 -0
  8. package/lib/assets/.claude/agent-memory/xp-programmer/project_us07_route_assignment.md +19 -0
  9. package/lib/assets/.claude/scripts/generate-inception-deck.mjs +911 -911
  10. package/lib/assets/.claude/settings.json +11 -11
  11. package/lib/assets/.claude/skills/ai-agent-guidelines/SKILL.md +111 -111
  12. package/lib/assets/.claude/skills/analyzing-architecture/SKILL.md +83 -83
  13. package/lib/assets/.claude/skills/analyzing-business/SKILL.md +95 -95
  14. package/lib/assets/.claude/skills/analyzing-data-model/SKILL.md +77 -77
  15. package/lib/assets/.claude/skills/analyzing-domain-model/SKILL.md +117 -117
  16. package/lib/assets/.claude/skills/analyzing-inception-deck/SKILL.md +84 -84
  17. package/lib/assets/.claude/skills/analyzing-non-functional/SKILL.md +95 -95
  18. package/lib/assets/.claude/skills/analyzing-operation/SKILL.md +95 -95
  19. package/lib/assets/.claude/skills/analyzing-requirements/SKILL.md +91 -91
  20. package/lib/assets/.claude/skills/analyzing-tech-stack/SKILL.md +101 -101
  21. package/lib/assets/.claude/skills/analyzing-test-strategy/SKILL.md +89 -89
  22. package/lib/assets/.claude/skills/analyzing-ui-design/SKILL.md +80 -80
  23. package/lib/assets/.claude/skills/analyzing-usecases/SKILL.md +72 -72
  24. package/lib/assets/.claude/skills/creating-adr/SKILL.md +113 -113
  25. package/lib/assets/.claude/skills/developing-backend/SKILL.md +100 -100
  26. package/lib/assets/.claude/skills/developing-frontend/SKILL.md +93 -93
  27. package/lib/assets/.claude/skills/developing-release/SKILL.md +120 -120
  28. package/lib/assets/.claude/skills/generating-bmc/SKILL.md +97 -0
  29. package/lib/assets/.claude/skills/generating-slides/SKILL.md +94 -94
  30. package/lib/assets/.claude/skills/git-commit/SKILL.md +81 -81
  31. package/lib/assets/.claude/skills/killing-processes/SKILL.md +44 -44
  32. package/lib/assets/.claude/skills/operating-backup/SKILL.md +59 -59
  33. package/lib/assets/.claude/skills/operating-cicd/SKILL.md +54 -54
  34. package/lib/assets/.claude/skills/operating-deploy/SKILL.md +67 -67
  35. package/lib/assets/.claude/skills/operating-docs/SKILL.md +219 -219
  36. package/lib/assets/.claude/skills/operating-provision/SKILL.md +77 -77
  37. package/lib/assets/.claude/skills/operating-setup/SKILL.md +63 -63
  38. package/lib/assets/.claude/skills/orchestrating-analysis/SKILL.md +104 -104
  39. package/lib/assets/.claude/skills/orchestrating-development/SKILL.md +162 -162
  40. package/lib/assets/.claude/skills/orchestrating-operation/SKILL.md +158 -158
  41. package/lib/assets/.claude/skills/orchestrating-project/SKILL.md +144 -144
  42. package/lib/assets/.claude/skills/planning-releases/SKILL.md +119 -119
  43. package/lib/assets/.claude/skills/syncing-github-project/SKILL.md +151 -151
  44. package/lib/assets/.claude/skills/tracking-progress/SKILL.md +91 -91
  45. package/lib/assets/.claude/skills/validating-iteration-plan/SKILL.md +215 -215
  46. package/lib/assets/.devcontainer/devcontainer.json +34 -34
  47. package/lib/assets/.env.example +17 -17
  48. package/lib/assets/.gitattributes +4 -4
  49. package/lib/assets/.github/workflows/docker-publish.yml +77 -77
  50. package/lib/assets/.github/workflows/mkdocs.yml +39 -39
  51. package/lib/assets/AGENTS.md +94 -94
  52. package/lib/assets/CLAUDE.md +1 -0
  53. package/lib/assets/README.md +254 -254
  54. package/lib/assets/docker-compose.yml +33 -33
  55. package/lib/assets/docs/adr/index.md +10 -10
  56. package/lib/assets/docs/article/functional-desgin-ppp/all/01-immutability-and-data-transformation.md +475 -475
  57. package/lib/assets/docs/article/functional-desgin-ppp/all/02-function-composition.md +519 -519
  58. package/lib/assets/docs/article/functional-desgin-ppp/all/03-polymorphism.md +537 -537
  59. package/lib/assets/docs/article/functional-desgin-ppp/all/04-data-validation.md +300 -300
  60. package/lib/assets/docs/article/functional-desgin-ppp/all/05-property-based-testing.md +320 -320
  61. package/lib/assets/docs/article/functional-desgin-ppp/all/06-tdd-and-functional.md +498 -498
  62. package/lib/assets/docs/article/functional-desgin-ppp/all/07-composite-pattern.md +298 -298
  63. package/lib/assets/docs/article/functional-desgin-ppp/all/08-decorator-pattern.md +291 -291
  64. package/lib/assets/docs/article/functional-desgin-ppp/all/09-adapter-pattern.md +336 -336
  65. package/lib/assets/docs/article/functional-desgin-ppp/all/10-strategy-pattern.md +303 -303
  66. package/lib/assets/docs/article/functional-desgin-ppp/all/11-command-pattern.md +286 -286
  67. package/lib/assets/docs/article/functional-desgin-ppp/all/12-visitor-pattern.md +322 -322
  68. package/lib/assets/docs/article/functional-desgin-ppp/all/13-abstract-factory-pattern.md +319 -319
  69. package/lib/assets/docs/article/functional-desgin-ppp/all/14-abstract-server-pattern.md +365 -365
  70. package/lib/assets/docs/article/functional-desgin-ppp/all/15-gossiping-bus-drivers.md +156 -156
  71. package/lib/assets/docs/article/functional-desgin-ppp/all/16-payroll-system.md +178 -178
  72. package/lib/assets/docs/article/functional-desgin-ppp/all/17-video-rental-system.md +312 -312
  73. package/lib/assets/docs/article/functional-desgin-ppp/all/18-concurrency-system.md +287 -287
  74. package/lib/assets/docs/article/functional-desgin-ppp/all/19-wa-tor-simulation.md +286 -286
  75. package/lib/assets/docs/article/functional-desgin-ppp/all/20-pattern-interactions.md +274 -274
  76. package/lib/assets/docs/article/functional-desgin-ppp/all/21-best-practices.md +294 -294
  77. package/lib/assets/docs/article/functional-desgin-ppp/all/22-oo-to-fp-migration.md +337 -337
  78. package/lib/assets/docs/article/functional-desgin-ppp/all/index.md +388 -388
  79. package/lib/assets/docs/article/functional-desgin-ppp/clojure/01-immutability-and-data-transformation.md +273 -273
  80. package/lib/assets/docs/article/functional-desgin-ppp/clojure/02-function-composition.md +380 -380
  81. package/lib/assets/docs/article/functional-desgin-ppp/clojure/03-polymorphism.md +384 -384
  82. package/lib/assets/docs/article/functional-desgin-ppp/clojure/04-clojure-spec.md +350 -350
  83. package/lib/assets/docs/article/functional-desgin-ppp/clojure/05-property-based-testing.md +352 -352
  84. package/lib/assets/docs/article/functional-desgin-ppp/clojure/06-tdd-in-functional.md +383 -383
  85. package/lib/assets/docs/article/functional-desgin-ppp/clojure/07-composite-pattern.md +529 -529
  86. package/lib/assets/docs/article/functional-desgin-ppp/clojure/08-decorator-pattern.md +395 -395
  87. package/lib/assets/docs/article/functional-desgin-ppp/clojure/09-adapter-pattern.md +399 -399
  88. package/lib/assets/docs/article/functional-desgin-ppp/clojure/10-strategy-pattern.md +485 -485
  89. package/lib/assets/docs/article/functional-desgin-ppp/clojure/11-command-pattern.md +566 -566
  90. package/lib/assets/docs/article/functional-desgin-ppp/clojure/12-visitor-pattern.md +567 -567
  91. package/lib/assets/docs/article/functional-desgin-ppp/clojure/13-abstract-factory-pattern.md +475 -475
  92. package/lib/assets/docs/article/functional-desgin-ppp/clojure/14-abstract-server-pattern.md +462 -462
  93. package/lib/assets/docs/article/functional-desgin-ppp/clojure/15-gossiping-bus-drivers.md +325 -325
  94. package/lib/assets/docs/article/functional-desgin-ppp/clojure/16-payroll-system.md +401 -401
  95. package/lib/assets/docs/article/functional-desgin-ppp/clojure/17-video-rental-system.md +450 -450
  96. package/lib/assets/docs/article/functional-desgin-ppp/clojure/18-concurrency-system.md +475 -475
  97. package/lib/assets/docs/article/functional-desgin-ppp/clojure/19-wator-simulation.md +739 -739
  98. package/lib/assets/docs/article/functional-desgin-ppp/clojure/20-pattern-interactions.md +567 -567
  99. package/lib/assets/docs/article/functional-desgin-ppp/clojure/21-best-practices.md +518 -518
  100. package/lib/assets/docs/article/functional-desgin-ppp/clojure/22-oo-to-fp-migration.md +532 -532
  101. package/lib/assets/docs/article/functional-desgin-ppp/clojure/index.md +241 -241
  102. package/lib/assets/docs/article/functional-desgin-ppp/elixir/01-immutability-and-data-transformation.md +383 -383
  103. package/lib/assets/docs/article/functional-desgin-ppp/elixir/02-function-composition.md +374 -374
  104. package/lib/assets/docs/article/functional-desgin-ppp/elixir/03-polymorphism.md +375 -375
  105. package/lib/assets/docs/article/functional-desgin-ppp/elixir/04-data-validation.md +195 -195
  106. package/lib/assets/docs/article/functional-desgin-ppp/elixir/05-property-based-testing.md +268 -268
  107. package/lib/assets/docs/article/functional-desgin-ppp/elixir/06-tdd-and-fp.md +294 -294
  108. package/lib/assets/docs/article/functional-desgin-ppp/elixir/07-effects-and-pure-functions.md +164 -164
  109. package/lib/assets/docs/article/functional-desgin-ppp/elixir/08-error-handling-strategies.md +168 -168
  110. package/lib/assets/docs/article/functional-desgin-ppp/elixir/09-io-and-external-systems.md +254 -254
  111. package/lib/assets/docs/article/functional-desgin-ppp/elixir/10-concurrency-patterns.md +269 -269
  112. package/lib/assets/docs/article/functional-desgin-ppp/elixir/11-command-pattern.md +148 -148
  113. package/lib/assets/docs/article/functional-desgin-ppp/elixir/12-visitor-pattern.md +176 -176
  114. package/lib/assets/docs/article/functional-desgin-ppp/elixir/13-abstract-factory-pattern.md +604 -604
  115. package/lib/assets/docs/article/functional-desgin-ppp/elixir/14-abstract-server-pattern.md +729 -729
  116. package/lib/assets/docs/article/functional-desgin-ppp/elixir/15-gossiping-bus-drivers.md +291 -291
  117. package/lib/assets/docs/article/functional-desgin-ppp/elixir/16-payroll-system.md +420 -420
  118. package/lib/assets/docs/article/functional-desgin-ppp/elixir/17-video-rental-system.md +319 -319
  119. package/lib/assets/docs/article/functional-desgin-ppp/elixir/18-concurrency-system.md +466 -466
  120. package/lib/assets/docs/article/functional-desgin-ppp/elixir/19-wator-simulation.md +523 -523
  121. package/lib/assets/docs/article/functional-desgin-ppp/elixir/20-pattern-interactions.md +287 -287
  122. package/lib/assets/docs/article/functional-desgin-ppp/elixir/21-best-practices.md +340 -340
  123. package/lib/assets/docs/article/functional-desgin-ppp/elixir/22-oo-to-fp-migration.md +395 -395
  124. package/lib/assets/docs/article/functional-desgin-ppp/elixir/index.md +248 -248
  125. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/01-immutability-and-data-transformation.md +384 -384
  126. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/02-function-composition.md +452 -452
  127. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/03-polymorphism.md +495 -495
  128. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/04-data-validation.md +416 -416
  129. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/05-property-based-testing.md +382 -382
  130. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/06-tdd-functional.md +687 -687
  131. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/07-composite-pattern.md +442 -442
  132. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/08-decorator-pattern.md +479 -479
  133. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/09-adapter-pattern.md +479 -479
  134. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/10-strategy-pattern.md +427 -427
  135. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/11-command-pattern.md +428 -428
  136. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/12-visitor-pattern.md +339 -339
  137. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/13-abstract-factory-pattern.md +309 -309
  138. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/14-abstract-server-pattern.md +596 -596
  139. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/15-gossiping-bus-drivers.md +355 -355
  140. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/16-payroll-system.md +350 -350
  141. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/17-video-rental-system.md +414 -414
  142. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/18-concurrency-system.md +367 -367
  143. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/19-wator-simulation.md +403 -403
  144. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/20-pattern-interactions.md +291 -291
  145. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/21-best-practices.md +324 -324
  146. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/22-oo-to-fp-migration.md +332 -332
  147. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/index.md +274 -274
  148. package/lib/assets/docs/article/functional-desgin-ppp/haskell/01-immutability-and-data-transformation.md +298 -298
  149. package/lib/assets/docs/article/functional-desgin-ppp/haskell/02-function-composition.md +304 -304
  150. package/lib/assets/docs/article/functional-desgin-ppp/haskell/03-polymorphism.md +362 -362
  151. package/lib/assets/docs/article/functional-desgin-ppp/haskell/04-data-validation.md +257 -257
  152. package/lib/assets/docs/article/functional-desgin-ppp/haskell/05-property-based-testing.md +254 -254
  153. package/lib/assets/docs/article/functional-desgin-ppp/haskell/06-tdd-functional.md +283 -283
  154. package/lib/assets/docs/article/functional-desgin-ppp/haskell/07-composite-pattern.md +395 -395
  155. package/lib/assets/docs/article/functional-desgin-ppp/haskell/08-decorator-pattern.md +319 -319
  156. package/lib/assets/docs/article/functional-desgin-ppp/haskell/09-adapter-pattern.md +382 -382
  157. package/lib/assets/docs/article/functional-desgin-ppp/haskell/10-strategy-pattern.md +287 -287
  158. package/lib/assets/docs/article/functional-desgin-ppp/haskell/11-command-pattern.md +303 -303
  159. package/lib/assets/docs/article/functional-desgin-ppp/haskell/12-visitor-pattern.md +326 -326
  160. package/lib/assets/docs/article/functional-desgin-ppp/haskell/13-abstract-factory-pattern.md +332 -332
  161. package/lib/assets/docs/article/functional-desgin-ppp/haskell/14-abstract-server-pattern.md +379 -379
  162. package/lib/assets/docs/article/functional-desgin-ppp/haskell/15-gossiping-bus-drivers.md +177 -177
  163. package/lib/assets/docs/article/functional-desgin-ppp/haskell/16-payroll-system.md +219 -219
  164. package/lib/assets/docs/article/functional-desgin-ppp/haskell/17-video-rental-system.md +244 -244
  165. package/lib/assets/docs/article/functional-desgin-ppp/haskell/18-concurrency-system.md +363 -363
  166. package/lib/assets/docs/article/functional-desgin-ppp/haskell/19-wator-simulation.md +438 -438
  167. package/lib/assets/docs/article/functional-desgin-ppp/haskell/20-pattern-interactions.md +325 -325
  168. package/lib/assets/docs/article/functional-desgin-ppp/haskell/21-best-practices.md +403 -403
  169. package/lib/assets/docs/article/functional-desgin-ppp/haskell/22-oo-to-fp-migration.md +469 -469
  170. package/lib/assets/docs/article/functional-desgin-ppp/haskell/index.md +174 -174
  171. package/lib/assets/docs/article/functional-desgin-ppp/index.md +90 -90
  172. package/lib/assets/docs/article/functional-desgin-ppp/rust/01-immutability-and-data-transformation.md +450 -450
  173. package/lib/assets/docs/article/functional-desgin-ppp/rust/02-function-composition.md +463 -463
  174. package/lib/assets/docs/article/functional-desgin-ppp/rust/03-polymorphism.md +425 -425
  175. package/lib/assets/docs/article/functional-desgin-ppp/rust/04-data-validation.md +273 -273
  176. package/lib/assets/docs/article/functional-desgin-ppp/rust/05-property-based-testing.md +247 -247
  177. package/lib/assets/docs/article/functional-desgin-ppp/rust/06-tdd-and-functional.md +841 -841
  178. package/lib/assets/docs/article/functional-desgin-ppp/rust/07-composite-pattern.md +384 -384
  179. package/lib/assets/docs/article/functional-desgin-ppp/rust/08-decorator-pattern.md +383 -383
  180. package/lib/assets/docs/article/functional-desgin-ppp/rust/09-adapter-pattern.md +339 -339
  181. package/lib/assets/docs/article/functional-desgin-ppp/rust/10-strategy-pattern.md +331 -331
  182. package/lib/assets/docs/article/functional-desgin-ppp/rust/11-command-pattern.md +356 -356
  183. package/lib/assets/docs/article/functional-desgin-ppp/rust/12-visitor-pattern.md +379 -379
  184. package/lib/assets/docs/article/functional-desgin-ppp/rust/13-abstract-factory-pattern.md +361 -361
  185. package/lib/assets/docs/article/functional-desgin-ppp/rust/14-abstract-server-pattern.md +392 -392
  186. package/lib/assets/docs/article/functional-desgin-ppp/rust/15-gossiping-bus-drivers.md +300 -300
  187. package/lib/assets/docs/article/functional-desgin-ppp/rust/16-payroll-system.md +297 -297
  188. package/lib/assets/docs/article/functional-desgin-ppp/rust/17-video-rental-system.md +304 -304
  189. package/lib/assets/docs/article/functional-desgin-ppp/rust/18-concurrency-system.md +315 -315
  190. package/lib/assets/docs/article/functional-desgin-ppp/rust/19-wator-simulation.md +311 -311
  191. package/lib/assets/docs/article/functional-desgin-ppp/rust/20-pattern-interactions.md +304 -304
  192. package/lib/assets/docs/article/functional-desgin-ppp/rust/21-best-practices.md +336 -336
  193. package/lib/assets/docs/article/functional-desgin-ppp/rust/22-oo-to-fp-migration.md +349 -349
  194. package/lib/assets/docs/article/functional-desgin-ppp/rust/index.md +243 -243
  195. package/lib/assets/docs/article/functional-desgin-ppp/scala/01-immutability-and-data-transformation.md +328 -328
  196. package/lib/assets/docs/article/functional-desgin-ppp/scala/02-function-composition.md +348 -348
  197. package/lib/assets/docs/article/functional-desgin-ppp/scala/03-polymorphism.md +357 -357
  198. package/lib/assets/docs/article/functional-desgin-ppp/scala/04-data-validation.md +364 -364
  199. package/lib/assets/docs/article/functional-desgin-ppp/scala/05-property-based-testing.md +515 -515
  200. package/lib/assets/docs/article/functional-desgin-ppp/scala/06-tdd-functional.md +557 -557
  201. package/lib/assets/docs/article/functional-desgin-ppp/scala/07-composite-pattern.md +363 -363
  202. package/lib/assets/docs/article/functional-desgin-ppp/scala/08-decorator-pattern.md +327 -327
  203. package/lib/assets/docs/article/functional-desgin-ppp/scala/09-adapter-pattern.md +517 -517
  204. package/lib/assets/docs/article/functional-desgin-ppp/scala/10-strategy-pattern.md +441 -441
  205. package/lib/assets/docs/article/functional-desgin-ppp/scala/11-command-pattern.md +407 -407
  206. package/lib/assets/docs/article/functional-desgin-ppp/scala/12-visitor-pattern.md +379 -379
  207. package/lib/assets/docs/article/functional-desgin-ppp/scala/13-abstract-factory-pattern.md +398 -398
  208. package/lib/assets/docs/article/functional-desgin-ppp/scala/14-abstract-server-pattern.md +476 -476
  209. package/lib/assets/docs/article/functional-desgin-ppp/scala/15-gossiping-bus-drivers.md +391 -391
  210. package/lib/assets/docs/article/functional-desgin-ppp/scala/16-payroll-system.md +342 -342
  211. package/lib/assets/docs/article/functional-desgin-ppp/scala/17-video-rental-system.md +324 -324
  212. package/lib/assets/docs/article/functional-desgin-ppp/scala/18-concurrency-system.md +730 -730
  213. package/lib/assets/docs/article/functional-desgin-ppp/scala/19-wator-simulation.md +624 -624
  214. package/lib/assets/docs/article/functional-desgin-ppp/scala/20-pattern-interactions.md +512 -512
  215. package/lib/assets/docs/article/functional-desgin-ppp/scala/21-best-practices.md +433 -433
  216. package/lib/assets/docs/article/functional-desgin-ppp/scala/22-oo-to-fp-migration.md +688 -688
  217. package/lib/assets/docs/article/functional-desgin-ppp/scala/index.md +243 -243
  218. package/lib/assets/docs/article/getting-start-tdd/clojure/01-todo-list-and-first-test.md +166 -166
  219. package/lib/assets/docs/article/getting-start-tdd/clojure/02-fake-it-and-triangulation.md +162 -162
  220. package/lib/assets/docs/article/getting-start-tdd/clojure/03-obvious-implementation-and-refactoring.md +135 -135
  221. package/lib/assets/docs/article/getting-start-tdd/clojure/04-version-control-and-conventional-commits.md +88 -88
  222. package/lib/assets/docs/article/getting-start-tdd/clojure/05-package-management-and-static-analysis.md +299 -299
  223. package/lib/assets/docs/article/getting-start-tdd/clojure/06-task-runner-and-ci-cd.md +241 -241
  224. package/lib/assets/docs/article/getting-start-tdd/clojure/07-protocols-and-records.md +131 -131
  225. package/lib/assets/docs/article/getting-start-tdd/clojure/08-multimethods-and-design-patterns.md +130 -130
  226. package/lib/assets/docs/article/getting-start-tdd/clojure/09-namespaces-and-module-design.md +127 -127
  227. package/lib/assets/docs/article/getting-start-tdd/clojure/10-higher-order-functions-and-composition.md +114 -114
  228. package/lib/assets/docs/article/getting-start-tdd/clojure/11-persistent-data-and-pipeline.md +138 -138
  229. package/lib/assets/docs/article/getting-start-tdd/clojure/12-error-handling-and-spec.md +161 -161
  230. package/lib/assets/docs/article/getting-start-tdd/clojure/index.md +65 -65
  231. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter01.md +232 -232
  232. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter02.md +244 -244
  233. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter03.md +202 -202
  234. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter04.md +92 -92
  235. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter05.md +256 -256
  236. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter06.md +195 -195
  237. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter07.md +214 -214
  238. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter08.md +249 -249
  239. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter09.md +174 -174
  240. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter10.md +166 -166
  241. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter11.md +192 -192
  242. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter12.md +211 -211
  243. package/lib/assets/docs/article/getting-start-tdd/csharp/index.md +83 -83
  244. package/lib/assets/docs/article/getting-start-tdd/elixir/01-todo-list-and-first-test.md +87 -87
  245. package/lib/assets/docs/article/getting-start-tdd/elixir/02-fake-it-and-triangulation.md +95 -95
  246. package/lib/assets/docs/article/getting-start-tdd/elixir/03-obvious-implementation-and-refactoring.md +109 -109
  247. package/lib/assets/docs/article/getting-start-tdd/elixir/04-version-control-and-conventional-commits.md +96 -96
  248. package/lib/assets/docs/article/getting-start-tdd/elixir/05-package-management-and-static-analysis.md +88 -88
  249. package/lib/assets/docs/article/getting-start-tdd/elixir/06-task-runner-and-ci-cd.md +71 -71
  250. package/lib/assets/docs/article/getting-start-tdd/elixir/07-structs-and-protocols.md +110 -110
  251. package/lib/assets/docs/article/getting-start-tdd/elixir/08-pattern-matching-and-guards.md +108 -108
  252. package/lib/assets/docs/article/getting-start-tdd/elixir/09-module-design-and-behaviours.md +104 -104
  253. package/lib/assets/docs/article/getting-start-tdd/elixir/10-higher-order-functions-and-pipeline.md +178 -178
  254. package/lib/assets/docs/article/getting-start-tdd/elixir/11-stream-and-lazy-evaluation.md +142 -142
  255. package/lib/assets/docs/article/getting-start-tdd/elixir/12-error-handling-and-with.md +145 -145
  256. package/lib/assets/docs/article/getting-start-tdd/elixir/index.md +35 -35
  257. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter01.md +202 -202
  258. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter02.md +246 -246
  259. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter03.md +218 -218
  260. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter04.md +179 -179
  261. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter05.md +267 -267
  262. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter06.md +190 -190
  263. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter07.md +161 -161
  264. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter08.md +175 -175
  265. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter09.md +222 -222
  266. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter10.md +189 -189
  267. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter11.md +212 -212
  268. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter12.md +215 -215
  269. package/lib/assets/docs/article/getting-start-tdd/fsharp/index.md +71 -71
  270. package/lib/assets/docs/article/getting-start-tdd/go/01-todo-list-and-first-test.md +213 -213
  271. package/lib/assets/docs/article/getting-start-tdd/go/02-fake-it-and-triangulation.md +302 -302
  272. package/lib/assets/docs/article/getting-start-tdd/go/03-obvious-implementation-and-refactoring.md +339 -339
  273. package/lib/assets/docs/article/getting-start-tdd/go/04-version-control-and-conventional-commits.md +112 -112
  274. package/lib/assets/docs/article/getting-start-tdd/go/05-package-management-and-static-analysis.md +272 -272
  275. package/lib/assets/docs/article/getting-start-tdd/go/06-task-runner-and-ci-cd.md +233 -233
  276. package/lib/assets/docs/article/getting-start-tdd/go/07-encapsulation-and-polymorphism.md +394 -394
  277. package/lib/assets/docs/article/getting-start-tdd/go/08-design-patterns.md +422 -422
  278. package/lib/assets/docs/article/getting-start-tdd/go/09-solid-principles-and-module-design.md +400 -400
  279. package/lib/assets/docs/article/getting-start-tdd/go/10-higher-order-functions-and-composition.md +226 -226
  280. package/lib/assets/docs/article/getting-start-tdd/go/11-immutable-data-and-pipeline.md +296 -296
  281. package/lib/assets/docs/article/getting-start-tdd/go/12-error-handling-and-type-safety.md +411 -411
  282. package/lib/assets/docs/article/getting-start-tdd/go/index.md +83 -83
  283. package/lib/assets/docs/article/getting-start-tdd/haskell/01-todo-list-and-first-test.md +279 -279
  284. package/lib/assets/docs/article/getting-start-tdd/haskell/02-fake-it-and-triangulation.md +337 -337
  285. package/lib/assets/docs/article/getting-start-tdd/haskell/03-obvious-implementation-and-refactoring.md +257 -257
  286. package/lib/assets/docs/article/getting-start-tdd/haskell/04-version-control-and-conventional-commits.md +182 -182
  287. package/lib/assets/docs/article/getting-start-tdd/haskell/05-package-management-and-static-analysis.md +313 -313
  288. package/lib/assets/docs/article/getting-start-tdd/haskell/06-task-runner-and-ci-cd.md +309 -309
  289. package/lib/assets/docs/article/getting-start-tdd/haskell/07-algebraic-data-types-and-type-classes.md +412 -412
  290. package/lib/assets/docs/article/getting-start-tdd/haskell/08-pattern-matching-and-guards.md +390 -390
  291. package/lib/assets/docs/article/getting-start-tdd/haskell/09-module-design-and-smart-constructors.md +461 -461
  292. package/lib/assets/docs/article/getting-start-tdd/haskell/10-higher-order-functions-and-currying.md +434 -434
  293. package/lib/assets/docs/article/getting-start-tdd/haskell/11-function-composition-and-point-free.md +392 -392
  294. package/lib/assets/docs/article/getting-start-tdd/haskell/12-monad-and-error-handling.md +631 -631
  295. package/lib/assets/docs/article/getting-start-tdd/haskell/index.md +49 -49
  296. package/lib/assets/docs/article/getting-start-tdd/index.md +93 -93
  297. package/lib/assets/docs/article/getting-start-tdd/integration/01-language-overview.md +375 -375
  298. package/lib/assets/docs/article/getting-start-tdd/integration/02-test-framework-comparison.md +349 -349
  299. package/lib/assets/docs/article/getting-start-tdd/integration/03-tdd-pattern-comparison.md +445 -445
  300. package/lib/assets/docs/article/getting-start-tdd/integration/04-type-system-comparison.md +409 -409
  301. package/lib/assets/docs/article/getting-start-tdd/integration/05-dev-environment-comparison.md +330 -330
  302. package/lib/assets/docs/article/getting-start-tdd/integration/06-learning-roadmap.md +290 -290
  303. package/lib/assets/docs/article/getting-start-tdd/integration/index.md +69 -69
  304. package/lib/assets/docs/article/getting-start-tdd/java/01-todo-list-and-first-test.md +234 -234
  305. package/lib/assets/docs/article/getting-start-tdd/java/02-fake-it-and-triangulation.md +261 -261
  306. package/lib/assets/docs/article/getting-start-tdd/java/03-obvious-implementation-and-refactoring.md +185 -185
  307. package/lib/assets/docs/article/getting-start-tdd/java/04-version-control-and-conventional-commits.md +115 -115
  308. package/lib/assets/docs/article/getting-start-tdd/java/05-package-management-and-static-analysis.md +382 -382
  309. package/lib/assets/docs/article/getting-start-tdd/java/06-task-runner-and-ci-cd.md +272 -272
  310. package/lib/assets/docs/article/getting-start-tdd/java/07-encapsulation-and-polymorphism.md +626 -626
  311. package/lib/assets/docs/article/getting-start-tdd/java/08-design-patterns.md +393 -393
  312. package/lib/assets/docs/article/getting-start-tdd/java/09-solid-principles-and-module-design.md +310 -310
  313. package/lib/assets/docs/article/getting-start-tdd/java/10-higher-order-functions-and-composition.md +188 -188
  314. package/lib/assets/docs/article/getting-start-tdd/java/11-immutable-data-and-pipeline.md +167 -167
  315. package/lib/assets/docs/article/getting-start-tdd/java/12-error-handling-and-type-safety.md +205 -205
  316. package/lib/assets/docs/article/getting-start-tdd/java/index.md +61 -61
  317. package/lib/assets/docs/article/getting-start-tdd/node/01-todo-list-and-first-test.md +244 -244
  318. package/lib/assets/docs/article/getting-start-tdd/node/02-fake-it-and-triangulation.md +262 -262
  319. package/lib/assets/docs/article/getting-start-tdd/node/03-obvious-implementation-and-refactoring.md +169 -169
  320. package/lib/assets/docs/article/getting-start-tdd/node/04-version-control-and-conventional-commits.md +112 -112
  321. package/lib/assets/docs/article/getting-start-tdd/node/05-package-management-and-static-analysis.md +314 -314
  322. package/lib/assets/docs/article/getting-start-tdd/node/06-task-runner-and-ci-cd.md +235 -235
  323. package/lib/assets/docs/article/getting-start-tdd/node/07-encapsulation-and-polymorphism.md +327 -327
  324. package/lib/assets/docs/article/getting-start-tdd/node/08-design-patterns.md +322 -322
  325. package/lib/assets/docs/article/getting-start-tdd/node/09-solid-principles-and-module-design.md +285 -285
  326. package/lib/assets/docs/article/getting-start-tdd/node/10-higher-order-functions-and-composition.md +199 -199
  327. package/lib/assets/docs/article/getting-start-tdd/node/11-immutable-data-and-pipeline.md +207 -207
  328. package/lib/assets/docs/article/getting-start-tdd/node/12-error-handling-and-type-safety.md +295 -295
  329. package/lib/assets/docs/article/getting-start-tdd/node/index.md +56 -56
  330. package/lib/assets/docs/article/getting-start-tdd/php/01-todo-list-and-first-test.md +259 -259
  331. package/lib/assets/docs/article/getting-start-tdd/php/02-fake-it-and-triangulation.md +200 -200
  332. package/lib/assets/docs/article/getting-start-tdd/php/03-obvious-implementation-and-refactoring.md +248 -248
  333. package/lib/assets/docs/article/getting-start-tdd/php/04-version-control-and-conventional-commits.md +141 -141
  334. package/lib/assets/docs/article/getting-start-tdd/php/05-package-management-and-static-analysis.md +410 -410
  335. package/lib/assets/docs/article/getting-start-tdd/php/06-task-runner-and-ci-cd.md +321 -321
  336. package/lib/assets/docs/article/getting-start-tdd/php/07-encapsulation-and-polymorphism.md +372 -372
  337. package/lib/assets/docs/article/getting-start-tdd/php/08-design-patterns.md +453 -453
  338. package/lib/assets/docs/article/getting-start-tdd/php/09-solid-principles-and-module-design.md +460 -460
  339. package/lib/assets/docs/article/getting-start-tdd/php/10-higher-order-functions-and-composition.md +182 -182
  340. package/lib/assets/docs/article/getting-start-tdd/php/11-immutable-data-and-pipeline.md +266 -266
  341. package/lib/assets/docs/article/getting-start-tdd/php/12-error-handling-and-type-safety.md +308 -308
  342. package/lib/assets/docs/article/getting-start-tdd/php/index.md +84 -84
  343. package/lib/assets/docs/article/getting-start-tdd/python/01-todo-list-and-first-test.md +201 -201
  344. package/lib/assets/docs/article/getting-start-tdd/python/02-fake-it-and-triangulation.md +247 -247
  345. package/lib/assets/docs/article/getting-start-tdd/python/03-obvious-implementation-and-refactoring.md +199 -199
  346. package/lib/assets/docs/article/getting-start-tdd/python/04-version-control-and-conventional-commits.md +87 -87
  347. package/lib/assets/docs/article/getting-start-tdd/python/05-package-management-and-static-analysis.md +274 -274
  348. package/lib/assets/docs/article/getting-start-tdd/python/06-task-runner-and-ci-cd.md +190 -190
  349. package/lib/assets/docs/article/getting-start-tdd/python/07-encapsulation-and-polymorphism.md +208 -208
  350. package/lib/assets/docs/article/getting-start-tdd/python/08-design-patterns.md +172 -172
  351. package/lib/assets/docs/article/getting-start-tdd/python/09-solid-principles-and-module-design.md +130 -130
  352. package/lib/assets/docs/article/getting-start-tdd/python/10-higher-order-functions-and-composition.md +122 -122
  353. package/lib/assets/docs/article/getting-start-tdd/python/11-immutable-data-and-pipeline.md +116 -116
  354. package/lib/assets/docs/article/getting-start-tdd/python/12-error-handling-and-type-safety.md +126 -126
  355. package/lib/assets/docs/article/getting-start-tdd/python/index.md +55 -55
  356. package/lib/assets/docs/article/getting-start-tdd/ruby/01-todo-list-and-first-test.md +231 -231
  357. package/lib/assets/docs/article/getting-start-tdd/ruby/02-fake-it-and-triangulation.md +238 -238
  358. package/lib/assets/docs/article/getting-start-tdd/ruby/03-obvious-implementation-and-refactoring.md +228 -228
  359. package/lib/assets/docs/article/getting-start-tdd/ruby/04-version-control-and-conventional-commits.md +112 -112
  360. package/lib/assets/docs/article/getting-start-tdd/ruby/05-package-management-and-static-analysis.md +287 -287
  361. package/lib/assets/docs/article/getting-start-tdd/ruby/06-task-runner-and-ci-cd.md +248 -248
  362. package/lib/assets/docs/article/getting-start-tdd/ruby/07-encapsulation-and-polymorphism.md +279 -279
  363. package/lib/assets/docs/article/getting-start-tdd/ruby/08-design-patterns.md +329 -329
  364. package/lib/assets/docs/article/getting-start-tdd/ruby/09-solid-principles-and-module-design.md +196 -196
  365. package/lib/assets/docs/article/getting-start-tdd/ruby/10-higher-order-functions-and-composition.md +175 -175
  366. package/lib/assets/docs/article/getting-start-tdd/ruby/11-immutable-data-and-pipeline.md +237 -237
  367. package/lib/assets/docs/article/getting-start-tdd/ruby/12-error-handling-and-type-safety.md +398 -398
  368. package/lib/assets/docs/article/getting-start-tdd/ruby/index.md +83 -83
  369. package/lib/assets/docs/article/getting-start-tdd/rust/01-todo-list-and-first-test.md +211 -211
  370. package/lib/assets/docs/article/getting-start-tdd/rust/02-fake-it-and-triangulation.md +264 -264
  371. package/lib/assets/docs/article/getting-start-tdd/rust/03-obvious-implementation-and-refactoring.md +233 -233
  372. package/lib/assets/docs/article/getting-start-tdd/rust/04-version-control-and-conventional-commits.md +92 -92
  373. package/lib/assets/docs/article/getting-start-tdd/rust/05-package-management-and-static-analysis.md +212 -212
  374. package/lib/assets/docs/article/getting-start-tdd/rust/06-task-runner-and-ci-cd.md +164 -164
  375. package/lib/assets/docs/article/getting-start-tdd/rust/07-encapsulation-and-polymorphism.md +142 -142
  376. package/lib/assets/docs/article/getting-start-tdd/rust/08-design-patterns.md +145 -145
  377. package/lib/assets/docs/article/getting-start-tdd/rust/09-solid-principles-and-module-design.md +110 -110
  378. package/lib/assets/docs/article/getting-start-tdd/rust/10-higher-order-functions-and-composition.md +94 -94
  379. package/lib/assets/docs/article/getting-start-tdd/rust/11-immutable-data-and-pipeline.md +105 -105
  380. package/lib/assets/docs/article/getting-start-tdd/rust/12-error-handling-and-type-safety.md +112 -112
  381. package/lib/assets/docs/article/getting-start-tdd/rust/index.md +83 -83
  382. package/lib/assets/docs/article/getting-start-tdd/scala/01-todo-list-and-first-test.md +111 -111
  383. package/lib/assets/docs/article/getting-start-tdd/scala/02-fake-it-and-triangulation.md +107 -107
  384. package/lib/assets/docs/article/getting-start-tdd/scala/03-obvious-implementation-and-refactoring.md +99 -99
  385. package/lib/assets/docs/article/getting-start-tdd/scala/04-version-control-and-conventional-commits.md +123 -123
  386. package/lib/assets/docs/article/getting-start-tdd/scala/05-package-management-and-static-analysis.md +196 -196
  387. package/lib/assets/docs/article/getting-start-tdd/scala/06-task-runner-and-ci-cd.md +186 -186
  388. package/lib/assets/docs/article/getting-start-tdd/scala/07-case-classes-and-traits.md +139 -139
  389. package/lib/assets/docs/article/getting-start-tdd/scala/08-pattern-matching-and-sealed-traits.md +106 -106
  390. package/lib/assets/docs/article/getting-start-tdd/scala/09-packages-and-module-design.md +75 -75
  391. package/lib/assets/docs/article/getting-start-tdd/scala/10-higher-order-functions-and-composition.md +104 -104
  392. package/lib/assets/docs/article/getting-start-tdd/scala/11-collections-and-lazy-evaluation.md +94 -94
  393. package/lib/assets/docs/article/getting-start-tdd/scala/12-error-handling-and-type-safety.md +92 -92
  394. package/lib/assets/docs/article/getting-start-tdd/scala/index.md +65 -65
  395. package/lib/assets/docs/article/grokking-concurrency/all/index.md +404 -404
  396. package/lib/assets/docs/article/grokking-concurrency/all/part-1-ch02-sequential.md +554 -554
  397. package/lib/assets/docs/article/grokking-concurrency/all/part-2-ch04-05-threads.md +469 -469
  398. package/lib/assets/docs/article/grokking-concurrency/all/part-3-ch06-multitasking.md +520 -520
  399. package/lib/assets/docs/article/grokking-concurrency/all/part-4-ch07-parallel-patterns.md +420 -420
  400. package/lib/assets/docs/article/grokking-concurrency/all/part-5-ch08-09-synchronization.md +510 -510
  401. package/lib/assets/docs/article/grokking-concurrency/all/part-6-ch10-11-nonblocking-io.md +435 -435
  402. package/lib/assets/docs/article/grokking-concurrency/all/part-7-ch12-async.md +465 -465
  403. package/lib/assets/docs/article/grokking-concurrency/all/part-8-ch13-mapreduce.md +377 -377
  404. package/lib/assets/docs/article/grokking-concurrency/clojure/index.md +116 -116
  405. package/lib/assets/docs/article/grokking-concurrency/clojure/part-1.md +108 -108
  406. package/lib/assets/docs/article/grokking-concurrency/clojure/part-2.md +101 -101
  407. package/lib/assets/docs/article/grokking-concurrency/clojure/part-3.md +122 -122
  408. package/lib/assets/docs/article/grokking-concurrency/clojure/part-4.md +123 -123
  409. package/lib/assets/docs/article/grokking-concurrency/clojure/part-5.md +118 -118
  410. package/lib/assets/docs/article/grokking-concurrency/clojure/part-6.md +89 -89
  411. package/lib/assets/docs/article/grokking-concurrency/clojure/part-7.md +100 -100
  412. package/lib/assets/docs/article/grokking-concurrency/clojure/part-8.md +120 -120
  413. package/lib/assets/docs/article/grokking-concurrency/csharp/index.md +101 -101
  414. package/lib/assets/docs/article/grokking-concurrency/csharp/part-1.md +97 -97
  415. package/lib/assets/docs/article/grokking-concurrency/csharp/part-2.md +123 -123
  416. package/lib/assets/docs/article/grokking-concurrency/csharp/part-3.md +101 -101
  417. package/lib/assets/docs/article/grokking-concurrency/csharp/part-4.md +112 -112
  418. package/lib/assets/docs/article/grokking-concurrency/csharp/part-5.md +99 -99
  419. package/lib/assets/docs/article/grokking-concurrency/csharp/part-6.md +61 -61
  420. package/lib/assets/docs/article/grokking-concurrency/csharp/part-7.md +84 -84
  421. package/lib/assets/docs/article/grokking-concurrency/csharp/part-8.md +92 -92
  422. package/lib/assets/docs/article/grokking-concurrency/fsharp/index.md +65 -65
  423. package/lib/assets/docs/article/grokking-concurrency/fsharp/part-1.md +80 -80
  424. package/lib/assets/docs/article/grokking-concurrency/fsharp/part-2.md +103 -103
  425. package/lib/assets/docs/article/grokking-concurrency/fsharp/part-3.md +94 -94
  426. package/lib/assets/docs/article/grokking-concurrency/fsharp/part-4.md +110 -110
  427. package/lib/assets/docs/article/grokking-concurrency/fsharp/part-5.md +104 -104
  428. package/lib/assets/docs/article/grokking-concurrency/fsharp/part-6.md +93 -93
  429. package/lib/assets/docs/article/grokking-concurrency/fsharp/part-7.md +121 -121
  430. package/lib/assets/docs/article/grokking-concurrency/fsharp/part-8.md +107 -107
  431. package/lib/assets/docs/article/grokking-concurrency/haskell/index.md +248 -248
  432. package/lib/assets/docs/article/grokking-concurrency/haskell/part-1.md +96 -96
  433. package/lib/assets/docs/article/grokking-concurrency/haskell/part-2.md +96 -96
  434. package/lib/assets/docs/article/grokking-concurrency/haskell/part-3.md +91 -91
  435. package/lib/assets/docs/article/grokking-concurrency/haskell/part-4.md +106 -106
  436. package/lib/assets/docs/article/grokking-concurrency/haskell/part-5.md +99 -99
  437. package/lib/assets/docs/article/grokking-concurrency/haskell/part-6.md +95 -95
  438. package/lib/assets/docs/article/grokking-concurrency/haskell/part-7.md +111 -111
  439. package/lib/assets/docs/article/grokking-concurrency/haskell/part-8.md +118 -118
  440. package/lib/assets/docs/article/grokking-concurrency/index.md +66 -66
  441. package/lib/assets/docs/article/grokking-concurrency/java/index.md +102 -102
  442. package/lib/assets/docs/article/grokking-concurrency/java/part-1.md +308 -308
  443. package/lib/assets/docs/article/grokking-concurrency/java/part-2.md +334 -334
  444. package/lib/assets/docs/article/grokking-concurrency/java/part-3.md +221 -221
  445. package/lib/assets/docs/article/grokking-concurrency/java/part-4.md +213 -213
  446. package/lib/assets/docs/article/grokking-concurrency/java/part-5.md +112 -112
  447. package/lib/assets/docs/article/grokking-concurrency/java/part-6.md +69 -69
  448. package/lib/assets/docs/article/grokking-concurrency/java/part-7.md +101 -101
  449. package/lib/assets/docs/article/grokking-concurrency/java/part-8.md +101 -101
  450. package/lib/assets/docs/article/grokking-concurrency/python/index.md +313 -313
  451. package/lib/assets/docs/article/grokking-concurrency/python/part-1.md +239 -239
  452. package/lib/assets/docs/article/grokking-concurrency/python/part-2.md +418 -418
  453. package/lib/assets/docs/article/grokking-concurrency/python/part-3.md +227 -227
  454. package/lib/assets/docs/article/grokking-concurrency/python/part-4.md +299 -299
  455. package/lib/assets/docs/article/grokking-concurrency/python/part-5.md +315 -315
  456. package/lib/assets/docs/article/grokking-concurrency/python/part-6.md +297 -297
  457. package/lib/assets/docs/article/grokking-concurrency/python/part-7.md +314 -314
  458. package/lib/assets/docs/article/grokking-concurrency/python/part-8.md +360 -360
  459. package/lib/assets/docs/article/grokking-concurrency/rust/index.md +270 -270
  460. package/lib/assets/docs/article/grokking-concurrency/rust/part-1.md +108 -108
  461. package/lib/assets/docs/article/grokking-concurrency/rust/part-2.md +120 -120
  462. package/lib/assets/docs/article/grokking-concurrency/rust/part-3.md +126 -126
  463. package/lib/assets/docs/article/grokking-concurrency/rust/part-4.md +175 -175
  464. package/lib/assets/docs/article/grokking-concurrency/rust/part-5.md +158 -158
  465. package/lib/assets/docs/article/grokking-concurrency/rust/part-6.md +94 -94
  466. package/lib/assets/docs/article/grokking-concurrency/rust/part-7.md +133 -133
  467. package/lib/assets/docs/article/grokking-concurrency/rust/part-8.md +155 -155
  468. package/lib/assets/docs/article/grokking-concurrency/scala/index.md +69 -69
  469. package/lib/assets/docs/article/grokking-concurrency/scala/part-1.md +78 -78
  470. package/lib/assets/docs/article/grokking-concurrency/scala/part-2.md +112 -112
  471. package/lib/assets/docs/article/grokking-concurrency/scala/part-3.md +93 -93
  472. package/lib/assets/docs/article/grokking-concurrency/scala/part-4.md +110 -110
  473. package/lib/assets/docs/article/grokking-concurrency/scala/part-5.md +119 -119
  474. package/lib/assets/docs/article/grokking-concurrency/scala/part-6.md +83 -83
  475. package/lib/assets/docs/article/grokking-concurrency/scala/part-7.md +131 -131
  476. package/lib/assets/docs/article/grokking-concurrency/scala/part-8.md +129 -129
  477. package/lib/assets/docs/article/grokkingfp/all/index.md +368 -368
  478. package/lib/assets/docs/article/grokkingfp/all/part-1-ch01-fp-introduction.md +530 -530
  479. package/lib/assets/docs/article/grokkingfp/all/part-1-ch02-pure-functions.md +923 -923
  480. package/lib/assets/docs/article/grokkingfp/all/part-2-ch03-immutable-data.md +1128 -1128
  481. package/lib/assets/docs/article/grokkingfp/all/part-2-ch04-higher-order-functions.md +1104 -1104
  482. package/lib/assets/docs/article/grokkingfp/all/part-2-ch05-flatmap.md +1026 -1026
  483. package/lib/assets/docs/article/grokkingfp/all/part-3-ch06-option.md +785 -785
  484. package/lib/assets/docs/article/grokkingfp/all/part-3-ch07-either-adt.md +871 -871
  485. package/lib/assets/docs/article/grokkingfp/all/part-4-ch08-io-monad.md +972 -972
  486. package/lib/assets/docs/article/grokkingfp/all/part-4-ch09-streams.md +926 -926
  487. package/lib/assets/docs/article/grokkingfp/all/part-5-ch10-concurrency.md +870 -870
  488. package/lib/assets/docs/article/grokkingfp/all/part-6-ch11-application.md +715 -715
  489. package/lib/assets/docs/article/grokkingfp/all/part-6-ch12-testing.md +626 -626
  490. package/lib/assets/docs/article/grokkingfp/all/writing-plan.md +712 -712
  491. package/lib/assets/docs/article/grokkingfp/clojure/index.md +276 -276
  492. package/lib/assets/docs/article/grokkingfp/clojure/part-1.md +667 -667
  493. package/lib/assets/docs/article/grokkingfp/clojure/part-2.md +643 -643
  494. package/lib/assets/docs/article/grokkingfp/clojure/part-3.md +620 -620
  495. package/lib/assets/docs/article/grokkingfp/clojure/part-4.md +697 -697
  496. package/lib/assets/docs/article/grokkingfp/clojure/part-5.md +751 -751
  497. package/lib/assets/docs/article/grokkingfp/clojure/part-6.md +721 -721
  498. package/lib/assets/docs/article/grokkingfp/csharp/index.md +246 -246
  499. package/lib/assets/docs/article/grokkingfp/csharp/part-1.md +811 -811
  500. package/lib/assets/docs/article/grokkingfp/csharp/part-2.md +971 -971
  501. package/lib/assets/docs/article/grokkingfp/csharp/part-3.md +981 -981
  502. package/lib/assets/docs/article/grokkingfp/csharp/part-4.md +949 -949
  503. package/lib/assets/docs/article/grokkingfp/csharp/part-5.md +947 -947
  504. package/lib/assets/docs/article/grokkingfp/csharp/part-6.md +739 -739
  505. package/lib/assets/docs/article/grokkingfp/elixir/index.md +203 -203
  506. package/lib/assets/docs/article/grokkingfp/elixir/part-1.md +712 -712
  507. package/lib/assets/docs/article/grokkingfp/elixir/part-2.md +838 -838
  508. package/lib/assets/docs/article/grokkingfp/elixir/part-3.md +985 -985
  509. package/lib/assets/docs/article/grokkingfp/elixir/part-4.md +974 -974
  510. package/lib/assets/docs/article/grokkingfp/elixir/part-5.md +1286 -1286
  511. package/lib/assets/docs/article/grokkingfp/elixir/part-6.md +1049 -1049
  512. package/lib/assets/docs/article/grokkingfp/fsharp/index.md +210 -210
  513. package/lib/assets/docs/article/grokkingfp/fsharp/part-1.md +714 -714
  514. package/lib/assets/docs/article/grokkingfp/fsharp/part-2.md +961 -961
  515. package/lib/assets/docs/article/grokkingfp/fsharp/part-3.md +972 -972
  516. package/lib/assets/docs/article/grokkingfp/fsharp/part-4.md +832 -832
  517. package/lib/assets/docs/article/grokkingfp/fsharp/part-5.md +911 -911
  518. package/lib/assets/docs/article/grokkingfp/fsharp/part-6.md +922 -922
  519. package/lib/assets/docs/article/grokkingfp/haskell/index.md +234 -234
  520. package/lib/assets/docs/article/grokkingfp/haskell/part-1.md +591 -591
  521. package/lib/assets/docs/article/grokkingfp/haskell/part-2.md +866 -866
  522. package/lib/assets/docs/article/grokkingfp/haskell/part-3.md +915 -915
  523. package/lib/assets/docs/article/grokkingfp/haskell/part-4.md +878 -878
  524. package/lib/assets/docs/article/grokkingfp/haskell/part-5.md +845 -845
  525. package/lib/assets/docs/article/grokkingfp/haskell/part-6.md +844 -844
  526. package/lib/assets/docs/article/grokkingfp/index.md +143 -143
  527. package/lib/assets/docs/article/grokkingfp/java/index.md +211 -211
  528. package/lib/assets/docs/article/grokkingfp/java/part-1.md +648 -648
  529. package/lib/assets/docs/article/grokkingfp/java/part-2.md +675 -675
  530. package/lib/assets/docs/article/grokkingfp/java/part-3.md +672 -672
  531. package/lib/assets/docs/article/grokkingfp/java/part-4.md +771 -771
  532. package/lib/assets/docs/article/grokkingfp/java/part-5.md +959 -959
  533. package/lib/assets/docs/article/grokkingfp/java/part-6.md +1328 -1328
  534. package/lib/assets/docs/article/grokkingfp/python/index.md +258 -258
  535. package/lib/assets/docs/article/grokkingfp/python/part-1.md +443 -443
  536. package/lib/assets/docs/article/grokkingfp/python/part-2.md +958 -958
  537. package/lib/assets/docs/article/grokkingfp/python/part-3.md +1004 -1004
  538. package/lib/assets/docs/article/grokkingfp/python/part-4.md +765 -765
  539. package/lib/assets/docs/article/grokkingfp/python/part-5.md +747 -747
  540. package/lib/assets/docs/article/grokkingfp/python/part-6.md +861 -861
  541. package/lib/assets/docs/article/grokkingfp/ruby/index.md +330 -330
  542. package/lib/assets/docs/article/grokkingfp/ruby/part-1.md +755 -755
  543. package/lib/assets/docs/article/grokkingfp/ruby/part-2.md +938 -938
  544. package/lib/assets/docs/article/grokkingfp/ruby/part-3.md +946 -946
  545. package/lib/assets/docs/article/grokkingfp/ruby/part-4.md +921 -921
  546. package/lib/assets/docs/article/grokkingfp/ruby/part-5.md +908 -908
  547. package/lib/assets/docs/article/grokkingfp/ruby/part-6.md +1412 -1412
  548. package/lib/assets/docs/article/grokkingfp/rust/index.md +242 -242
  549. package/lib/assets/docs/article/grokkingfp/rust/part-1.md +634 -634
  550. package/lib/assets/docs/article/grokkingfp/rust/part-2.md +1060 -1060
  551. package/lib/assets/docs/article/grokkingfp/rust/part-3.md +994 -994
  552. package/lib/assets/docs/article/grokkingfp/rust/part-4.md +573 -573
  553. package/lib/assets/docs/article/grokkingfp/rust/part-5.md +705 -705
  554. package/lib/assets/docs/article/grokkingfp/rust/part-6.md +508 -508
  555. package/lib/assets/docs/article/grokkingfp/scala/index.md +171 -171
  556. package/lib/assets/docs/article/grokkingfp/scala/part-1.md +543 -543
  557. package/lib/assets/docs/article/grokkingfp/scala/part-2.md +946 -946
  558. package/lib/assets/docs/article/grokkingfp/scala/part-3.md +919 -919
  559. package/lib/assets/docs/article/grokkingfp/scala/part-4.md +742 -742
  560. package/lib/assets/docs/article/grokkingfp/scala/part-5.md +722 -722
  561. package/lib/assets/docs/article/grokkingfp/scala/part-6.md +867 -867
  562. package/lib/assets/docs/article/grokkingfp/typescript/index.md +273 -273
  563. package/lib/assets/docs/article/grokkingfp/typescript/part-1.md +561 -561
  564. package/lib/assets/docs/article/grokkingfp/typescript/part-2.md +1129 -1129
  565. package/lib/assets/docs/article/grokkingfp/typescript/part-3.md +842 -842
  566. package/lib/assets/docs/article/grokkingfp/typescript/part-4.md +1087 -1087
  567. package/lib/assets/docs/article/grokkingfp/typescript/part-5.md +717 -717
  568. package/lib/assets/docs/article/grokkingfp/typescript/part-6.md +982 -982
  569. package/lib/assets/docs/article/practical-database-design/index.md +121 -121
  570. package/lib/assets/docs/article/practical-database-design/part1/chapter01.md +288 -288
  571. package/lib/assets/docs/article/practical-database-design/part1/chapter02.md +518 -518
  572. package/lib/assets/docs/article/practical-database-design/part1/chapter03.md +557 -557
  573. package/lib/assets/docs/article/practical-database-design/part2/chapter04.md +924 -924
  574. package/lib/assets/docs/article/practical-database-design/part2/chapter05.md +1627 -1627
  575. package/lib/assets/docs/article/practical-database-design/part2/chapter06.md +2716 -2716
  576. package/lib/assets/docs/article/practical-database-design/part2/chapter07.md +2082 -2082
  577. package/lib/assets/docs/article/practical-database-design/part2/chapter08.md +2105 -2105
  578. package/lib/assets/docs/article/practical-database-design/part2/chapter09.md +2031 -2031
  579. package/lib/assets/docs/article/practical-database-design/part2/chapter10.md +1387 -1387
  580. package/lib/assets/docs/article/practical-database-design/part2/chapter11.md +1677 -1677
  581. package/lib/assets/docs/article/practical-database-design/part2/chapter12.md +1417 -1417
  582. package/lib/assets/docs/article/practical-database-design/part2/chapter13.md +1434 -1434
  583. package/lib/assets/docs/article/practical-database-design/part3/chapter14.md +667 -667
  584. package/lib/assets/docs/article/practical-database-design/part3/chapter15.md +1625 -1625
  585. package/lib/assets/docs/article/practical-database-design/part3/chapter16.md +1915 -1915
  586. package/lib/assets/docs/article/practical-database-design/part3/chapter17.md +1708 -1708
  587. package/lib/assets/docs/article/practical-database-design/part3/chapter18.md +2095 -2095
  588. package/lib/assets/docs/article/practical-database-design/part3/chapter19.md +1123 -1123
  589. package/lib/assets/docs/article/practical-database-design/part3/chapter20.md +1031 -1031
  590. package/lib/assets/docs/article/practical-database-design/part3/chapter21.md +1382 -1382
  591. package/lib/assets/docs/article/practical-database-design/part3-orm/chapter14-orm.md +991 -991
  592. package/lib/assets/docs/article/practical-database-design/part3-orm/chapter15-orm.md +1300 -1300
  593. package/lib/assets/docs/article/practical-database-design/part3-orm/chapter16-orm.md +1166 -1166
  594. package/lib/assets/docs/article/practical-database-design/part3-orm/chapter17-orm.md +1584 -1584
  595. package/lib/assets/docs/article/practical-database-design/part3-orm/chapter18-orm.md +1183 -1183
  596. package/lib/assets/docs/article/practical-database-design/part3-orm/chapter19-orm.md +1016 -1016
  597. package/lib/assets/docs/article/practical-database-design/part3-orm/chapter20-orm.md +1753 -1753
  598. package/lib/assets/docs/article/practical-database-design/part3-orm/chapter21-orm.md +1447 -1447
  599. package/lib/assets/docs/article/practical-database-design/part3-orm/chapter22-orm.md +1878 -1878
  600. package/lib/assets/docs/article/practical-database-design/part4/chapter22.md +965 -965
  601. package/lib/assets/docs/article/practical-database-design/part4/chapter23.md +2069 -2069
  602. package/lib/assets/docs/article/practical-database-design/part4/chapter24.md +2439 -2439
  603. package/lib/assets/docs/article/practical-database-design/part4/chapter25.md +3661 -3661
  604. package/lib/assets/docs/article/practical-database-design/part4/chapter26.md +2916 -2916
  605. package/lib/assets/docs/article/practical-database-design/part4/chapter27.md +3105 -3105
  606. package/lib/assets/docs/article/practical-database-design/part4/chapter28.md +2697 -2697
  607. package/lib/assets/docs/article/practical-database-design/part4/chapter29.md +2544 -2544
  608. package/lib/assets/docs/article/practical-database-design/part4/chapter30.md +2180 -2180
  609. package/lib/assets/docs/article/practical-database-design/part4/chapter31.md +1192 -1192
  610. package/lib/assets/docs/article/practical-database-design/part4/chapter32.md +2101 -2101
  611. package/lib/assets/docs/article/practical-database-design/part5/chapter33.md +1032 -1032
  612. package/lib/assets/docs/article/practical-database-design/part5/chapter34.md +1609 -1609
  613. package/lib/assets/docs/article/practical-database-design/part5/chapter35.md +1453 -1453
  614. package/lib/assets/docs/article/practical-database-design/part5/chapter36.md +1292 -1292
  615. package/lib/assets/docs/article/practical-database-design/part5/chapter37.md +1470 -1470
  616. package/lib/assets/docs/article/practical-database-design/part5/chapter38.md +1698 -1698
  617. package/lib/assets/docs/article/practical-database-design/part5/chapter39.md +2334 -2334
  618. package/lib/assets/docs/article/practical-database-design/study/study2-1.md +1693 -1693
  619. package/lib/assets/docs/article/practical-database-design/study/study2-2.md +1347 -1347
  620. package/lib/assets/docs/article/practical-database-design/study/study2-3.md +2044 -2044
  621. package/lib/assets/docs/article/practical-database-design/study/study2-4.md +2229 -2229
  622. package/lib/assets/docs/article/practical-database-design/study/study2-5.md +2418 -2418
  623. package/lib/assets/docs/article/practical-database-design/study/study3-1.md +2205 -2205
  624. package/lib/assets/docs/article/practical-database-design/study/study3-2.md +2221 -2221
  625. package/lib/assets/docs/article/practical-database-design/study/study3-3.md +2253 -2253
  626. package/lib/assets/docs/article/practical-database-design/study/study3-4.md +2106 -2106
  627. package/lib/assets/docs/article/practical-database-design/study/study3-5.md +2507 -2507
  628. package/lib/assets/docs/article/practical-database-design/study/study4-1.md +2587 -2587
  629. package/lib/assets/docs/article/practical-database-design/study/study4-2.md +2075 -2075
  630. package/lib/assets/docs/article/practical-database-design/study/study4-3.md +1805 -1805
  631. package/lib/assets/docs/article/practical-database-design/study/study4-4.md +1895 -1895
  632. package/lib/assets/docs/article/practical-database-design/study/study4-5.md +2878 -2878
  633. package/lib/assets/docs/assets/css/extra.css +29 -29
  634. package/lib/assets/docs/assets/js/extra.js +44 -44
  635. package/lib/assets/docs/development/index.md +39 -39
  636. package/lib/assets/docs/operation/index.md +11 -11
  637. package/lib/assets/docs/reference/CodexCLIMCP/343/202/242/343/203/227/343/203/252/343/202/261/343/203/274/343/202/267/343/203/247/343/203/263/351/226/213/347/231/272/343/203/225/343/203/255/343/203/274.md +532 -532
  638. package/lib/assets/docs/reference/CodexCLIMCP/343/202/265/343/203/274/343/203/220/343/203/274/350/250/255/345/256/232/346/211/213/351/240/206.md +341 -341
  639. package/lib/assets/docs/reference/Java/343/202/242/343/203/227/343/203/252/343/202/261/343/203/274/343/202/267/343/203/247/343/203/263/347/222/260/345/242/203/346/247/213/347/257/211/343/202/254/343/202/244/343/203/211.md +581 -581
  640. package/lib/assets/docs/reference/SonarQube/343/203/255/343/203/274/343/202/253/343/203/253/347/222/260/345/242/203/343/202/273/343/203/203/343/203/210/343/202/242/343/203/203/343/203/227/346/211/213/351/240/206/346/233/270.md +642 -642
  641. package/lib/assets/docs/reference/TypeScript/343/202/242/343/203/227/343/203/252/343/202/261/343/203/274/343/202/267/343/203/247/343/203/263/347/222/260/345/242/203/346/247/213/347/257/211/343/202/254/343/202/244/343/203/211.md +465 -465
  642. package/lib/assets/docs/reference/UI/350/250/255/350/250/210/343/202/254/343/202/244/343/203/211.md +450 -450
  643. package/lib/assets/docs/reference/images/Ansoff.drawio.svg +3 -3
  644. package/lib/assets/docs/reference/images/BrandBasicStrategy.drawio.svg +3 -3
  645. package/lib/assets/docs/reference/images/BrandCategorization.drawio.svg +3 -3
  646. package/lib/assets/docs/reference/images/BrandRecurutementStrategy.drawio.svg +3 -3
  647. package/lib/assets/docs/reference/images/BrandValue.drawio.svg +3 -3
  648. package/lib/assets/docs/reference/images/BusinessActivitiy.svg +3 -3
  649. package/lib/assets/docs/reference/images/HRM.drawio.svg +3 -3
  650. package/lib/assets/docs/reference/images/MarketingStructure.drawio.svg +3 -3
  651. package/lib/assets/docs/reference/images/OrganizationElemnts.svg +3 -3
  652. package/lib/assets/docs/reference/images/PPM.drawio.svg +3 -3
  653. package/lib/assets/docs/reference/images/PositioningMap.drawio.svg +3 -3
  654. package/lib/assets/docs/reference/images/ProductLayer.drawio.svg +3 -3
  655. package/lib/assets/docs/reference/images/ProductMix.drawio.svg +3 -3
  656. package/lib/assets/docs/reference/images/SWOT.drawio.svg +3 -3
  657. package/lib/assets/docs/reference/images/TargetMarket.drawio.svg +3 -3
  658. package/lib/assets/docs/reference/images/ThreeGenericStrategies.drawio.svg +3 -3
  659. package/lib/assets/docs/reference/images/VRIO.drawio.svg +3 -3
  660. package/lib/assets/docs/reference/images/ValueChain.drawio.svg +3 -3
  661. package/lib/assets/docs/reference/index.md +52 -52
  662. package/lib/assets/docs/reference//343/202/210/343/201/204/343/202/275/343/203/225/343/203/210/343/202/246/343/202/247/343/202/242/343/201/250/343/201/257.md +250 -250
  663. package/lib/assets/docs/reference//343/202/242/343/203/274/343/202/255/343/203/206/343/202/257/343/203/201/343/203/243/350/250/255/350/250/210/343/202/254/343/202/244/343/203/211.md +2216 -2216
  664. package/lib/assets/docs/reference//343/202/244/343/203/263/343/203/225/343/203/251/350/250/255/350/250/210/343/202/254/343/202/244/343/203/211.md +1878 -1878
  665. package/lib/assets/docs/reference//343/202/250/343/202/257/343/202/271/343/203/210/343/203/252/343/203/274/343/203/240/343/203/227/343/203/255/343/202/260/343/203/251/343/203/237/343/203/263/343/202/260.md +550 -550
  666. package/lib/assets/docs/reference//343/202/263/343/203/274/343/203/207/343/202/243/343/203/263/343/202/260/343/201/250/343/203/206/343/202/271/343/203/210/343/202/254/343/202/244/343/203/211.md +705 -705
  667. package/lib/assets/docs/reference//343/203/206/343/202/271/343/203/210/346/210/246/347/225/245/343/202/254/343/202/244/343/203/211.md +1313 -1313
  668. package/lib/assets/docs/reference//343/203/207/343/203/274/343/202/277/343/203/242/343/203/207/343/203/253/350/250/255/350/250/210/343/202/254/343/202/244/343/203/211.md +311 -311
  669. package/lib/assets/docs/reference//343/203/211/343/203/241/343/202/244/343/203/263/343/203/242/343/203/207/343/203/253/350/250/255/350/250/210/343/202/254/343/202/244/343/203/211.md +599 -599
  670. package/lib/assets/docs/reference//343/203/223/343/202/270/343/203/215/343/202/271/343/202/242/343/203/274/343/202/255/343/203/206/343/202/257/343/203/201/343/203/243/345/210/206/346/236/220/343/202/254/343/202/244/343/203/211.md +528 -528
  671. package/lib/assets/docs/reference//343/203/246/343/203/274/343/202/271/343/202/261/343/203/274/343/202/271/344/275/234/346/210/220/343/202/254/343/202/244/343/203/211.md +689 -689
  672. package/lib/assets/docs/reference//343/203/252/343/203/252/343/203/274/343/202/271/343/202/254/343/202/244/343/203/211.md +461 -461
  673. package/lib/assets/docs/reference//343/203/252/343/203/252/343/203/274/343/202/271/343/203/273/343/202/244/343/203/206/343/203/254/343/203/274/343/202/267/343/203/247/343/203/263/350/250/210/347/224/273/343/202/254/343/202/244/343/203/211.md +580 -580
  674. package/lib/assets/docs/reference//343/203/255/343/202/270/343/202/253/343/203/253/343/202/267/343/203/263/343/202/255/343/203/263/343/202/260.md +1367 -1367
  675. package/lib/assets/docs/reference//344/274/201/346/245/255/347/265/214/345/226/266/350/253/226.md +2637 -2637
  676. package/lib/assets/docs/reference//347/222/260/345/242/203/345/244/211/346/225/260/347/256/241/347/220/206/343/202/254/343/202/244/343/203/211.md +665 -665
  677. package/lib/assets/docs/reference//350/246/201/344/273/266/345/256/232/347/276/251/343/202/254/343/202/244/343/203/211.md +1248 -1248
  678. package/lib/assets/docs/reference//350/250/200/350/252/236/345/210/245/351/226/213/347/231/272/343/202/254/343/202/244/343/203/211.md +518 -518
  679. package/lib/assets/docs/reference//351/201/213/345/226/266/347/256/241/347/220/206.md +1482 -1482
  680. package/lib/assets/docs/reference//351/201/213/347/224/250/343/202/271/343/202/257/343/203/252/343/203/227/343/203/210/344/275/234/346/210/220/343/202/254/343/202/244/343/203/211.md +421 -421
  681. package/lib/assets/docs/reference//351/201/213/347/224/250/350/246/201/344/273/266/345/256/232/347/276/251/343/202/254/343/202/244/343/203/211.md +392 -392
  682. package/lib/assets/docs/reference//351/226/213/347/231/272/343/202/254/343/202/244/343/203/211.md +299 -299
  683. package/lib/assets/docs/reference//351/235/236/346/251/237/350/203/275/350/246/201/344/273/266/345/256/232/347/276/251/343/202/254/343/202/244/343/203/211.md +1236 -1236
  684. package/lib/assets/docs/review/index.md +5 -5
  685. package/lib/assets/docs/strategy/index.md +1 -1
  686. package/lib/assets/docs/template/ADR.md +30 -30
  687. package/lib/assets/docs/template/AWS/343/202/271/343/203/206/343/203/274/343/202/270/343/203/263/343/202/260/347/222/260/345/242/203/343/202/273/343/203/203/343/203/210/343/202/242/343/203/203/343/203/227/346/211/213/351/240/206/346/233/270.md +1366 -1366
  688. package/lib/assets/docs/template/AWS/343/203/227/343/203/255/343/203/200/343/202/257/343/202/267/343/203/247/343/203/263/347/222/260/345/242/203/343/202/273/343/203/203/343/203/210/343/202/242/343/203/203/343/203/227/346/211/213/351/240/206/346/233/270.md +634 -634
  689. package/lib/assets/docs/template/README.md +50 -50
  690. package/lib/assets/docs/template/index.md +23 -23
  691. package/lib/assets/docs/template//343/201/276/343/201/232/343/201/223/343/202/214/343/202/222/350/252/255/343/202/202/343/201/206/343/203/252/343/202/271/343/203/210.md +12 -12
  692. package/lib/assets/docs/template//343/202/242/343/203/227/343/203/252/343/202/261/343/203/274/343/202/267/343/203/247/343/203/263/351/226/213/347/231/272/347/222/260/345/242/203/343/202/273/343/203/203/343/203/210/343/202/242/343/203/203/343/203/227/346/211/213/351/240/206/346/233/270.md +547 -547
  693. package/lib/assets/docs/template//343/202/244/343/203/206/343/203/254/343/203/274/343/202/267/343/203/247/343/203/263/345/256/214/344/272/206/345/240/261/345/221/212/346/233/270.md +58 -58
  694. package/lib/assets/docs/template//343/202/244/343/203/263/343/202/273/343/203/227/343/202/267/343/203/247/343/203/263/343/203/207/343/203/203/343/202/255.md +13 -13
  695. package/lib/assets/docs/template//343/203/223/343/202/270/343/203/215/343/202/271/343/202/242/343/203/274/343/202/255/343/203/206/343/202/257/343/203/201/343/203/243.md +379 -379
  696. package/lib/assets/docs/template//344/274/201/346/245/255/345/210/206/346/236/220.md +573 -573
  697. package/lib/assets/docs/template//345/256/214/345/205/250/345/275/242/345/274/217/343/201/256/343/203/246/343/203/274/343/202/271/343/202/261/343/203/274/343/202/271.md +69 -69
  698. package/lib/assets/docs/template//350/246/201/344/273/266/345/256/232/347/276/251.md +669 -669
  699. package/lib/assets/docs/template//350/250/255/350/250/210.md +173 -173
  700. package/lib/assets/docs/template//351/226/213/347/231/272/347/222/260/345/242/203/343/202/273/343/203/203/343/203/210/343/202/242/343/203/203/343/203/227/346/211/213/351/240/206/346/233/270.md +688 -688
  701. package/lib/assets/gulpfile.js +25 -25
  702. package/lib/assets/mkdocs.yml +136 -136
  703. package/lib/assets/ops/docker/mkdoc/Dockerfile +19 -19
  704. package/lib/assets/ops/scripts/journal.js +180 -180
  705. package/lib/assets/ops/scripts/mkdocs.js +82 -82
  706. package/lib/assets/ops/scripts/release.js +431 -431
  707. package/lib/assets/ops/scripts/sonar_local.js +726 -726
  708. package/lib/assets/ops/scripts/ssh.js +190 -190
  709. package/lib/assets/ops/scripts/vault.js +299 -299
  710. package/lib/assets/package-lock.json +1653 -1653
  711. package/lib/assets/package.json +40 -40
  712. package/lib/gulpfile.js +37 -37
  713. package/package.json +41 -41
@@ -1,2217 +1,2217 @@
1
- # アーキテクチャ設計ガイド
2
-
3
- ## 概要
4
-
5
- 本ガイドは、システム開発におけるアーキテクチャ設計の指針を提供します。バックエンドでは業務領域の特性とデータ構造の複雑さに基づいたアーキテクチャパターンの選択を、フロントエンドでは現代的なWebアプリケーション開発のベストプラクティスを定義します。
6
-
7
- ## アーキテクチャ設計の原則
8
-
9
- ### 基本方針
10
-
11
- - **モノレポ構成**: 単一リポジトリでフロントエンド・バックエンドを統合管理
12
- - **関心事の分離**: 明確な責務分離によるメンテナンス性向上
13
- - **依存関係の方向性**: 外側から内側(ドメイン)への単方向依存
14
- - **テストしやすい設計**: 各層が独立してテスト可能な構造
15
-
16
- ## 全体構成
17
-
18
- ```plantuml
19
- @startuml
20
- package "インフラストラクチャ" {
21
- package "ネットワーク" {
22
- package "アプリケーション" {
23
- package "フロントエンド" {
24
- [Webアプリケーション] as WebApp
25
- }
26
-
27
- package "バックエンド" {
28
- [APIサーバー] as API
29
- database "データベース" as DB
30
- }
31
-
32
- WebApp --> API : HTTP/REST
33
- API --> DB : SQL/NoSQL
34
- }
35
- }
36
- }
37
- @endtuml
38
- ```
39
-
40
- ### コンポーネント責務
41
-
42
- #### アプリケーション
43
-
44
- ##### フロントエンド
45
-
46
- - **UI/UX**: ユーザーインターフェース・ユーザー体験
47
- - **状態管理**: アプリケーション状態とサーバー状態の管理
48
- - **API連携**: バックエンドとのデータ通信
49
- - **レンダリング**: 効率的な画面描画とユーザーインタラクション
50
-
51
- ##### バックエンド
52
-
53
- - **ビジネスロジック**: 業務ルール・制約の実装
54
- - **データ永続化**: データの保存・取得・更新・削除
55
- - **セキュリティ**: 認証・認可・データ保護
56
- - **外部システム連携**: API・メッセージング・ファイル処理
57
-
58
- #### インフラストラクチャ
59
-
60
- - **ネットワーク**: 負荷分散・DNS・CDN
61
- - **アプリケーション**: ホスティング: サーバー・コンテナ管理
62
-
63
- # バックエンドアーキテクチャ
64
-
65
- ## バックエンドアーキテクチャパターン選択フロー
66
-
67
- ```plantuml
68
- @startuml
69
- !define DECISION_COLOR #FFE6CC
70
- !define PROCESS_COLOR #E6F3FF
71
- !define TERMINAL_COLOR #E6FFE6
72
-
73
- skinparam roundcorner 10
74
- skinparam shadowing false
75
-
76
- start
77
-
78
- if (業務領域のカテゴリー) then (補完、一般との連携)
79
- if (データ構造が複雑か?) then (いいえ)
80
- :トランザクションスクリプト;
81
- :逆ピラミッド形のテスト;
82
- if (永続化モデルは複数か?) then (いいえ)
83
- :レイヤードアーキテクチャ 3層;
84
- else (はい)
85
- :レイヤードアーキテクチャ 4層;
86
- endif
87
- else (はい)
88
- :アクティブレコード;
89
- :ダイヤモンド形のテスト;
90
- if (永続化モデルは複数か?) then (いいえ)
91
- :レイヤードアーキテクチャ 3層;
92
- else (はい)
93
- :レイヤードアーキテクチャ 4層;
94
- endif
95
- endif
96
- else (中核の業務領域)
97
- if (金額を扱う/分析/監査記録が必要か?) then (いいえ)
98
- :ドメインモデル;
99
- :ピラミッド形のテスト;
100
- if (永続化モデルは複数か?) then (いいえ)
101
- :ポートとアダプター;
102
- else (はい)
103
- :CQRS;
104
- endif
105
- else (はい)
106
- :イベント履歴式ドメインモデル;
107
- :ピラミッド形のテスト;
108
- :CQRS;
109
- endif
110
- endif
111
-
112
- stop
113
- @enduml
114
- ```
115
-
116
- ### 判断基準
117
-
118
- #### 業務領域カテゴリー
119
-
120
- | カテゴリー | 特徴 | 例 |
121
- |-----------|------|-----|
122
- | **中核の業務領域** | 組織の競争優位性を決定する領域 | 商品管理、顧客管理、受注処理 |
123
- | **補完、一般との連携** | 中核を支援する補助的な領域 | レポート出力、バッチ処理、外部連携 |
124
-
125
- #### データ構造の複雑さ
126
-
127
- | 複雑さ | 判定基準 |
128
- |--------|----------|
129
- | **複雑** | エンティティ間の関係が多く、ビジネスルールが複雑 |
130
- | **シンプル** | 単純なCRUD操作が中心、関係性が少ない |
131
-
132
- #### 特殊要件
133
-
134
- - **金額を扱う**: 会計・決済・金融関連の処理
135
- - **分析**: 大量データの集計・分析処理
136
- - **監査記録が必要**: コンプライアンス・規制対応
137
-
138
- ## アーキテクチャパターン詳細
139
-
140
- ### 1. トランザクションスクリプトパターン
141
-
142
- #### 適用場面
143
- - **業務領域**: 補完・一般との連携
144
- - **データ構造**: シンプル
145
- - **システム規模**: 小規模
146
-
147
- #### 特徴
148
- ```plantuml
149
- @startuml
150
- package "トランザクションスクリプト" {
151
- [スクリプト1] as s1
152
- [スクリプト2] as s2
153
- [スクリプト3] as s3
154
- database "データベース" as db
155
- }
156
-
157
- s1 --> db
158
- s2 --> db
159
- s3 --> db
160
- @enduml
161
- ```
162
-
163
- **メリット**:
164
-
165
- - 実装が直感的でわかりやすい
166
- - 開発速度が早い
167
- - 小規模チームでも扱いやすい
168
-
169
- **デメリット**:
170
-
171
- - コードの重複が発生しやすい
172
- - 大規模化すると保守が困難
173
- - ビジネスロジックが散在する
174
-
175
- #### 実装指針
176
-
177
- ```java
178
- // 例:会議室予約処理
179
- public class ReservationService {
180
- public void makeReservation(ReservationRequest request) {
181
- // 1. バリデーション
182
- validateRequest(request);
183
-
184
- // 2. 重複チェック
185
- checkConflicts(request);
186
-
187
- // 3. 予約作成
188
- createReservation(request);
189
-
190
- // 4. 通知送信
191
- sendNotification(request);
192
- }
193
- }
194
- ```
195
-
196
- ### 2. アクティブレコードパターン
197
-
198
- #### 適用場面
199
- - **業務領域**: 補完・一般との連携
200
- - **データ構造**: 複雑
201
- - **システム規模**: 中規模
202
-
203
- #### 特徴
204
- ```plantuml
205
- @startuml
206
- allow_mixing
207
-
208
- class User {
209
- +id: Long
210
- +name: String
211
- +email: String
212
- +save()
213
- +delete()
214
- +findById()
215
- }
216
-
217
- class Reservation {
218
- +id: Long
219
- +userId: Long
220
- +roomId: Long
221
- +save()
222
- +cancel()
223
- +findByUser()
224
- }
225
-
226
- database "データベース" as db
227
-
228
- User --> db : CRUD操作
229
- Reservation --> db : CRUD操作
230
- @enduml
231
- ```
232
-
233
- **メリット**:
234
-
235
- - オブジェクトとデータベースの対応が明確
236
- - ORMとの相性が良い
237
- - 理解しやすい構造
238
-
239
- **デメリット**:
240
-
241
- - データアクセスとビジネスロジックが密結合
242
- - テストが困難
243
- - ドメインロジックが薄くなる傾向
244
-
245
- #### 実装指針
246
-
247
- ```java
248
- // 例:予約エンティティ
249
- @Entity
250
- public class Reservation {
251
- @Id
252
- private Long id;
253
- private Long userId;
254
- private Long roomId;
255
- private LocalDateTime startTime;
256
- private LocalDateTime endTime;
257
-
258
- // ビジネスロジックを含む
259
- public void cancel() {
260
- if (canCancel()) {
261
- this.status = CANCELLED;
262
- this.save();
263
- }
264
- }
265
-
266
- public boolean canCancel() {
267
- return startTime.isAfter(LocalDateTime.now().plusHours(2));
268
- }
269
- }
270
- ```
271
-
272
- ### 3. ドメインモデルパターン
273
-
274
- #### 適用場面
275
- - **業務領域**: 中核の業務領域
276
- - **特殊要件**: 金額を扱わない、監査記録不要
277
- - **システム規模**: 中規模〜大規模
278
-
279
- #### 特徴
280
- ```plantuml
281
- @startuml
282
- package "ドメイン層" {
283
- class User
284
- class Reservation
285
- class MeetingRoom
286
- class ReservationService
287
- }
288
-
289
- package "アプリケーション層" {
290
- class ReservationUseCase
291
- }
292
-
293
- package "インフラストラクチャ層" {
294
- class UserRepository
295
- class ReservationRepository
296
- }
297
-
298
- ReservationUseCase --> ReservationService
299
- ReservationService --> User
300
- ReservationService --> Reservation
301
- ReservationService --> MeetingRoom
302
- ReservationUseCase --> UserRepository
303
- ReservationUseCase --> ReservationRepository
304
- @enduml
305
- ```
306
-
307
- **メリット**:
308
-
309
- - リッチなドメインモデル
310
- - ビジネスロジックの集約
311
- - 高い保守性・拡張性
312
- - テスト容易性
313
-
314
- **デメリット**:
315
-
316
- - 初期の学習コストが高い
317
- - 設計の複雑さ
318
- - 開発速度が遅い場合がある
319
-
320
- #### 実装指針
321
-
322
- ```java
323
- // ドメインモデル例
324
- public class Reservation {
325
- private ReservationId id;
326
- private UserId userId;
327
- private MeetingRoomId roomId;
328
- private TimeSlot timeSlot;
329
- private ReservationStatus status;
330
-
331
- // ファクトリーメソッド
332
- public static Reservation create(UserId userId, MeetingRoomId roomId, TimeSlot timeSlot) {
333
- validateTimeSlot(timeSlot);
334
- return new Reservation(ReservationId.generate(), userId, roomId, timeSlot, CONFIRMED);
335
- }
336
-
337
- // ビジネスロジック
338
- public void cancel(CancellationPolicy policy) {
339
- if (!policy.canCancel(this.timeSlot)) {
340
- throw new CancellationNotAllowedException();
341
- }
342
- this.status = CANCELLED;
343
- }
344
- }
345
- ```
346
-
347
- ### 4. イベント履歴式ドメインモデルパターン
348
-
349
- #### 適用場面
350
- - **業務領域**: 中核の業務領域
351
- - **特殊要件**: 金額を扱う、分析・監査記録が必要
352
- - **システム規模**: 大規模
353
-
354
- #### 特徴
355
- ```plantuml
356
- @startuml
357
- package "コマンド側" {
358
- class ReservationAggregate
359
- class DomainEvent
360
- }
361
-
362
- package "イベントストア" {
363
- class EventStream
364
- }
365
-
366
- package "クエリ側" {
367
- class ReservationProjection
368
- class ReadModel
369
- }
370
-
371
- ReservationAggregate --> EventStream : イベント保存
372
- EventStream --> ReservationProjection : イベント再生
373
- ReservationProjection --> ReadModel : プロジェクション更新
374
- @enduml
375
- ```
376
-
377
- **メリット**:
378
-
379
- - 完全な監査証跡
380
- - 時系列分析が可能
381
- - 高いスケーラビリティ
382
- - 複雑なクエリに対応
383
-
384
- **デメリット**:
385
-
386
- - 実装の複雑さ
387
- - 高い学習コスト
388
- - 結果整合性の考慮が必要
389
-
390
- #### 実装指針
391
-
392
- ```java
393
- // イベント例
394
- public class ReservationCreatedEvent extends DomainEvent {
395
- private final ReservationId reservationId;
396
- private final UserId userId;
397
- private final MeetingRoomId roomId;
398
- private final TimeSlot timeSlot;
399
- private final LocalDateTime occurredAt;
400
- }
401
-
402
- // 集約例
403
- public class ReservationAggregate {
404
- private ReservationId id;
405
- private List<DomainEvent> changes = new ArrayList<>();
406
-
407
- public void create(UserId userId, MeetingRoomId roomId, TimeSlot timeSlot) {
408
- var event = new ReservationCreatedEvent(id, userId, roomId, timeSlot, LocalDateTime.now());
409
- apply(event);
410
- }
411
-
412
- private void apply(DomainEvent event) {
413
- changes.add(event);
414
- // 状態更新ロジック
415
- }
416
- }
417
- ```
418
-
419
- ## アーキテクチャスタイル詳細
420
-
421
- ### 1. レイヤードアーキテクチャ(3層)
422
-
423
- #### 適用場面
424
- - **永続化モデル**: 単一
425
- - **システム特性**: 標準的なエンタープライズアプリケーション
426
-
427
- #### 構造
428
- ```plantuml
429
- @startuml
430
- package "プレゼンテーション層" {
431
- [コントローラー]
432
- [UI]
433
- }
434
-
435
- package "ビジネスロジック層" {
436
- [サービス]
437
- [ドメインモデル]
438
- }
439
-
440
- package "データアクセス層" {
441
- [リポジトリ]
442
- [DAO]
443
- }
444
-
445
- database "データベース"
446
-
447
- [コントローラー] --> [サービス]
448
- [UI] --> [コントローラー]
449
- [サービス] --> [リポジトリ]
450
- [リポジトリ] --> [データベース]
451
- @enduml
452
- ```
453
-
454
- #### 実装指針
455
-
456
- ```java
457
- // プレゼンテーション層
458
- @RestController
459
- public class ReservationController {
460
- private final ReservationService service;
461
-
462
- @PostMapping("/reservations")
463
- public ResponseEntity<Reservation> create(@RequestBody CreateReservationRequest request) {
464
- var reservation = service.createReservation(request);
465
- return ResponseEntity.ok(reservation);
466
- }
467
- }
468
-
469
- // ビジネスロジック層
470
- @Service
471
- public class ReservationService {
472
- private final ReservationRepository repository;
473
-
474
- public Reservation createReservation(CreateReservationRequest request) {
475
- // ビジネスロジック実行
476
- var reservation = new Reservation(request);
477
- return repository.save(reservation);
478
- }
479
- }
480
-
481
- // データアクセス層
482
- @Repository
483
- public interface ReservationRepository extends JpaRepository<Reservation, Long> {
484
- List<Reservation> findByUserId(Long userId);
485
- }
486
- ```
487
-
488
- ### 2. レイヤードアーキテクチャ(4層)
489
-
490
- #### 適用場面
491
- - **永続化モデル**: 複数
492
- - **システム特性**: 大規模エンタープライズアプリケーション
493
-
494
- #### 構造
495
- ```plantuml
496
- @startuml
497
- package "プレゼンテーション層" {
498
- [コントローラー]
499
- }
500
-
501
- package "アプリケーション層" {
502
- [アプリケーションサービス]
503
- [ユースケース]
504
- }
505
-
506
- package "ドメイン層" {
507
- [ドメインサービス]
508
- [エンティティ]
509
- }
510
-
511
- package "インフラストラクチャ層" {
512
- [リポジトリ実装]
513
- [外部API]
514
- }
515
-
516
- [コントローラー] --> [アプリケーションサービス]
517
- [アプリケーションサービス] --> [ドメインサービス]
518
- [アプリケーションサービス] --> [リポジトリ実装]
519
- @enduml
520
- ```
521
-
522
- #### レイヤー責務
523
-
524
- | レイヤー | 責務 |
525
- |----------|------|
526
- | **プレゼンテーション** | HTTP要求/応答、入力検証、認証 |
527
- | **アプリケーション** | ユースケース制御、トランザクション境界 |
528
- | **ドメイン** | ビジネスルール、不変条件、ドメインサービス |
529
- | **インフラストラクチャ** | 外部システム連携、永続化、技術的関心事 |
530
-
531
- ### 3. ポートとアダプターアーキテクチャ(ヘキサゴナル)
532
-
533
- #### 適用場面
534
- - **ドメインモデル**: あり
535
- - **永続化モデル**: 単一
536
- - **システム特性**: マイクロサービス、高いテスト容易性が要求される
537
-
538
- #### 構造
539
- ```plantuml
540
- @startuml
541
- hexagon "ドメイン\nモデル" as domain
542
-
543
- interface "入力ポート" as inport
544
- interface "出力ポート" as outport
545
-
546
- [Webアダプター] as web
547
- [CLIアダプター] as cli
548
- [データベースアダプター] as db
549
- [外部APIアダプター] as api
550
-
551
- web --> inport
552
- cli --> inport
553
- inport --> domain
554
- domain --> outport
555
- outport <|-- db
556
- outport <|-- api
557
- @enduml
558
- ```
559
-
560
- #### 実装指針
561
-
562
- ```java
563
- // 入力ポート(ユースケース)
564
- public interface CreateReservationUseCase {
565
- ReservationId execute(CreateReservationCommand command);
566
- }
567
-
568
- // 出力ポート(リポジトリインターフェース)
569
- public interface ReservationRepository {
570
- void save(Reservation reservation);
571
- Optional<Reservation> findById(ReservationId id);
572
- }
573
-
574
- // ドメインサービス(実装)
575
- @Service
576
- public class ReservationService implements CreateReservationUseCase {
577
- private final ReservationRepository repository;
578
-
579
- @Override
580
- public ReservationId execute(CreateReservationCommand command) {
581
- var reservation = Reservation.create(command);
582
- repository.save(reservation);
583
- return reservation.getId();
584
- }
585
- }
586
-
587
- // アダプター(インフラストラクチャ)
588
- @Repository
589
- public class JpaReservationRepository implements ReservationRepository {
590
- private final SpringDataReservationRepository jpaRepository;
591
-
592
- @Override
593
- public void save(Reservation reservation) {
594
- var entity = toEntity(reservation);
595
- jpaRepository.save(entity);
596
- }
597
- }
598
- ```
599
-
600
- ### 4. CQRSアーキテクチャ
601
-
602
- #### 適用場面
603
- - **永続化モデル**: 複数
604
- - **特殊要件**: イベント履歴式、高スケーラビリティ
605
- - **システム特性**: 複雑なクエリ要件、読み書き分離
606
-
607
- #### 構造
608
- ```plantuml
609
- @startuml
610
- package "コマンド側" {
611
- [コマンドハンドラー] as ch
612
- [書き込みモデル] as wm
613
- [コマンドストア] as cs
614
- }
615
-
616
- package "クエリ側" {
617
- [クエリハンドラー] as qh
618
- [読み取りモデル] as rm
619
- [クエリストア] as qs
620
- }
621
-
622
- package "イベント" {
623
- [イベントバス] as eb
624
- }
625
-
626
- [コマンド] --> ch
627
- ch --> wm
628
- wm --> cs
629
- wm --> eb
630
- eb --> rm
631
- rm --> qs
632
- [クエリ] --> qh
633
- qh --> rm
634
- @enduml
635
- ```
636
-
637
- #### 実装指針
638
-
639
- ```java
640
- // コマンド側
641
- @CommandHandler
642
- public class CreateReservationHandler {
643
- private final ReservationWriteRepository writeRepository;
644
- private final EventBus eventBus;
645
-
646
- public void handle(CreateReservationCommand command) {
647
- var reservation = new ReservationAggregate(command);
648
- writeRepository.save(reservation);
649
-
650
- var events = reservation.getUncommittedEvents();
651
- eventBus.publishAll(events);
652
- }
653
- }
654
-
655
- // クエリ側
656
- @QueryHandler
657
- public class ReservationQueryHandler {
658
- private final ReservationReadRepository readRepository;
659
-
660
- public List<ReservationView> handle(FindReservationsByUserQuery query) {
661
- return readRepository.findByUserId(query.getUserId());
662
- }
663
- }
664
-
665
- // イベントハンドラー(プロジェクション更新)
666
- @EventHandler
667
- public class ReservationProjectionHandler {
668
- private final ReservationReadRepository readRepository;
669
-
670
- public void on(ReservationCreatedEvent event) {
671
- var view = new ReservationView(event);
672
- readRepository.save(view);
673
- }
674
- }
675
- ```
676
-
677
- ## テスト戦略とアーキテクチャの関係
678
-
679
- ### ピラミッド形テスト(ドメインモデル・イベント履歴式)
680
-
681
- ```plantuml
682
- @startuml
683
- rectangle "E2Eテスト\n(少数)" as e2e #lightcoral
684
- rectangle "統合テスト\n(中程度)" as integration #orange
685
- rectangle "ユニットテスト\n(多数)" as unit #lightgreen
686
-
687
- unit -up-> integration
688
- integration -up-> e2e
689
- @enduml
690
- ```
691
-
692
- **特徴**:
693
-
694
- - ユニットテスト中心(80%)
695
- - ドメインロジックの徹底検証
696
- - 高品質なビジネスルール実装
697
-
698
- ### ダイヤモンド形テスト(アクティブレコード)
699
-
700
- ```plantuml
701
- @startuml
702
- rectangle "E2Eテスト\n(中程度)" as e2e #orange
703
- rectangle "統合テスト\n(多数)" as integration #lightgreen
704
- rectangle "ユニットテスト\n(中程度)" as unit #orange
705
-
706
- unit -up-> integration
707
- integration -up-> e2e
708
- @enduml
709
- ```
710
-
711
- **特徴**:
712
-
713
- - 統合テスト中心(60%)
714
- - データアクセスロジックの重点検証
715
- - ORMとの連携確認
716
-
717
- ### 逆ピラミッド形テスト(トランザクションスクリプト)
718
-
719
- ```plantuml
720
- @startuml
721
- rectangle "E2Eテスト\n(多数)" as e2e #lightgreen
722
- rectangle "統合テスト\n(中程度)" as integration #orange
723
- rectangle "ユニットテスト\n(少数)" as unit #lightcoral
724
-
725
- unit -up-> integration
726
- integration -up-> e2e
727
- @enduml
728
- ```
729
-
730
- **特徴**:
731
-
732
- - E2Eテスト中心(70%)
733
- - エンドツーエンドの動作確認
734
- - シナリオベースの検証
735
-
736
- ## アーキテクチャ評価基準
737
-
738
- ### 品質属性評価マトリックス
739
-
740
- | 品質属性 | トランザクション<br>スクリプト | アクティブ<br>レコード | ドメイン<br>モデル | イベント履歴式<br>ドメインモデル |
741
- |----------|:---:|:---:|:---:|:---:|
742
- | **開発速度** | ⭐⭐⭐⭐⭐ | ⭐⭐⭐⭐ | ⭐⭐ | ⭐ |
743
- | **保守性** | ⭐⭐ | ⭐⭐⭐ | ⭐⭐⭐⭐⭐ | ⭐⭐⭐⭐ |
744
- | **テスト容易性** | ⭐⭐ | ⭐⭐ | ⭐⭐⭐⭐⭐ | ⭐⭐⭐⭐ |
745
- | **スケーラビリティ** | ⭐⭐ | ⭐⭐⭐ | ⭐⭐⭐⭐ | ⭐⭐⭐⭐⭐ |
746
- | **複雑さ対応** | ⭐ | ⭐⭐ | ⭐⭐⭐⭐⭐ | ⭐⭐⭐⭐⭐ |
747
- | **監査要件** | ⭐ | ⭐⭐ | ⭐⭐⭐ | ⭐⭐⭐⭐⭐ |
748
-
749
- ### アーキテクチャスタイル評価マトリックス
750
-
751
- | 品質属性 | レイヤード<br>3層 | レイヤード<br>4層 | ポートと<br>アダプター | CQRS |
752
- |----------|:---:|:---:|:---:|:---:|
753
- | **学習容易性** | ⭐⭐⭐⭐⭐ | ⭐⭐⭐⭐ | ⭐⭐⭐ | ⭐⭐ |
754
- | **テスト容易性** | ⭐⭐⭐ | ⭐⭐⭐⭐ | ⭐⭐⭐⭐⭐ | ⭐⭐⭐⭐ |
755
- | **関心事分離** | ⭐⭐⭐ | ⭐⭐⭐⭐ | ⭐⭐⭐⭐⭐ | ⭐⭐⭐⭐⭐ |
756
- | **パフォーマンス** | ⭐⭐⭐ | ⭐⭐⭐ | ⭐⭐⭐ | ⭐⭐⭐⭐⭐ |
757
- | **スケーラビリティ** | ⭐⭐ | ⭐⭐⭐ | ⭐⭐⭐⭐ | ⭐⭐⭐⭐⭐ |
758
- | **進化性** | ⭐⭐ | ⭐⭐⭐ | ⭐⭐⭐⭐⭐ | ⭐⭐⭐⭐ |
759
-
760
- ## 実装ベストプラクティス
761
-
762
- ### 1. 依存関係管理
763
-
764
- ```java
765
- // ✅ 良い例:インターフェースに依存
766
- public class ReservationService {
767
- private final ReservationRepository repository; // インターフェース
768
- private final NotificationService notificationService; // インターフェース
769
- }
770
-
771
- // ❌ 悪い例:具象クラスに依存
772
- public class ReservationService {
773
- private final JpaReservationRepository repository; // 具象クラス
774
- private final EmailService emailService; // 具象クラス
775
- }
776
- ```
777
-
778
- ### 2. レイヤー分離
779
-
780
- ```java
781
- // ✅ 良い例:適切なレイヤー分離
782
- @RestController
783
- public class ReservationController {
784
- @PostMapping("/reservations")
785
- public ResponseEntity<ReservationResponse> create(@RequestBody CreateReservationRequest request) {
786
- // プレゼンテーション層の責務のみ
787
- var command = toCommand(request);
788
- var result = useCase.execute(command);
789
- return ResponseEntity.ok(toResponse(result));
790
- }
791
- }
792
-
793
- // ❌ 悪い例:レイヤー違反
794
- @RestController
795
- public class ReservationController {
796
- @PostMapping("/reservations")
797
- public ResponseEntity<ReservationResponse> create(@RequestBody CreateReservationRequest request) {
798
- // ビジネスロジックをコントローラーに記述(レイヤー違反)
799
- if (request.getStartTime().isBefore(LocalDateTime.now().plusHours(2))) {
800
- throw new ValidationException("2時間前までの予約が必要です");
801
- }
802
- // ...
803
- }
804
- }
805
- ```
806
-
807
- ### 3. エラーハンドリング
808
-
809
- ```java
810
- // ✅ 良い例:適切なエラー伝播
811
- public class ReservationService {
812
- public ReservationId createReservation(CreateReservationCommand command) {
813
- try {
814
- var reservation = Reservation.create(command);
815
- repository.save(reservation);
816
- return reservation.getId();
817
- } catch (DomainException e) {
818
- // ドメイン例外は適切にハンドリング
819
- throw new ReservationException("予約作成に失敗しました", e);
820
- }
821
- }
822
- }
823
-
824
- // ❌ 悪い例:例外の隠蔽
825
- public class ReservationService {
826
- public ReservationId createReservation(CreateReservationCommand command) {
827
- try {
828
- var reservation = Reservation.create(command);
829
- repository.save(reservation);
830
- return reservation.getId();
831
- } catch (Exception e) {
832
- // すべての例外を隠蔽(問題の特定が困難)
833
- return null;
834
- }
835
- }
836
- }
837
- ```
838
-
839
- # フロントエンドアーキテクチャ
840
-
841
- ## フロントエンドアーキテクチャ決定フロー
842
-
843
- ### 主要アーキテクチャ決定ポイント
844
-
845
- ```plantuml
846
- @startuml
847
- start
848
-
849
- :プロジェクト分析;
850
-
851
- if (プロジェクト規模) then (大規模)
852
- :11フォルダ標準構造;
853
- note right
854
- components/config/features/layouts/
855
- lib/pages/providers/stores/
856
- testing/types/utils/
857
- end note
858
- else (中小規模)
859
- :6フォルダシンプル構造;
860
- note right
861
- components/pages/hooks/
862
- utils/types/config/
863
- end note
864
- endif
865
-
866
- if (レンダリング戦略) then (SEO重要)
867
- if (更新頻度) then (高頻度)
868
- :サーバーサイドレンダリング;
869
- note right: Next.js
870
- else (低頻度)
871
- :静的生成;
872
- note right: Gatsby/Next.js SSG
873
- endif
874
- else (内部ツール・ダッシュボード)
875
- :SPA;
876
- note right: React SPA
877
- endif
878
-
879
- if (状態管理複雑性) then (複雑)
880
- if (更新頻度) then (高頻度)
881
- :Atom系(Recoil/Jotai);
882
- note right: stores/フォルダに集約
883
- else (共有多い)
884
- :Redux with RTK;
885
- note right: stores/フォルダに集約
886
- endif
887
- else (シンプル)
888
- :Context API + hooks / Zustand;
889
- note right: providers/フォルダに集約
890
- endif
891
-
892
- if (パフォーマンス重要度) then (高)
893
- :CSS/SCSS/Tailwind;
894
- note right: 頻繁レンダリング対応
895
- else (開発速度重視)
896
- :CSS-in-JS (Styled Components);
897
- note right: components/内で管理
898
- endif
899
-
900
- stop
901
- @enduml
902
- ```
903
-
904
- ## フロントエンド設計原則
905
-
906
- ### 良いアーキテクチャ決定
907
-
908
- #### 1. **プロジェクト構造**
909
-
910
- ##### 標準的なフロントエンドプロジェクト構造
911
- ```
912
- src/
913
- ├── components/ # (1) 共通UIコンポーネント
914
- │ ├── ui/ # 基本UIパーツ(Button, Input, Modal等)
915
- │ └── layout/ # レイアウトコンポーネント
916
- ├── config/ # (2) アプリケーション設定
917
- │ ├── constants.ts # 定数定義
918
- │ ├── env.ts # 環境変数管理
919
- │ └── api.ts # API設定
920
- ├── features/ # (3) フィーチャー単位のコンポーネント
921
- │ ├── auth/ # 認証機能
922
- │ ├── reservation/ # 予約機能
923
- │ └── meeting-room/# 会議室管理機能
924
- ├── layouts/ # (4) アプリケーションレイアウト
925
- │ ├── AppLayout.tsx
926
- │ ├── AuthLayout.tsx
927
- │ └── DashboardLayout.tsx
928
- ├── lib/ # (5) 外部ライブラリ設定・ユーティリティ
929
- │ ├── auth.ts # 認証ライブラリ設定
930
- │ ├── api-client.ts# API クライアント
931
- │ └── utils.ts # ヘルパー関数
932
- ├── pages/ # (6) ページコンポーネント(ルーティング)
933
- │ ├── LoginPage.tsx
934
- │ ├── DashboardPage.tsx
935
- │ └── ReservationPage.tsx
936
- ├── providers/ # (7) Context Provider
937
- │ ├── AuthProvider.tsx
938
- │ ├── ThemeProvider.tsx
939
- │ └── AppProviders.tsx
940
- ├── stores/ # (8) 状態管理
941
- │ ├── authStore.ts
942
- │ ├── uiStore.ts
943
- │ └── index.ts
944
- ├── testing/ # (9) テスト用ユーティリティ
945
- │ ├── setup.ts # テスト環境設定
946
- │ ├── mocks/ # モックデータ
947
- │ └── utils.ts # テストヘルパー
948
- ├── types/ # (10) TypeScript型定義
949
- │ ├── api.ts # API型定義
950
- │ ├── auth.ts # 認証関連型
951
- │ └── common.ts # 共通型定義
952
- └── utils/ # (11) 汎用ユーティリティ関数
953
- ├── format.ts # フォーマット関数
954
- ├── validation.ts# バリデーション
955
- └── date.ts # 日付操作
956
- ```
957
-
958
- ##### プロジェクト規模による使い分け
959
-
960
- **小規模プロジェクト (シンプル構造)**:
961
- ```
962
- src/
963
- ├── components/ # UI コンポーネント
964
- ├── pages/ # ページコンポーネント
965
- ├── hooks/ # カスタムフック
966
- ├── utils/ # ユーティリティ
967
- ├── types/ # 型定義
968
- └── config/ # 設定
969
- ```
970
-
971
- **大規模プロジェクト (フル構造)**:
972
- 上記の標準11フォルダ構成を使用
973
-
974
- #### 2. **コンポーネント設計**
975
- - **小さなコンポーネント**: 単一責任の原則に従った分割
976
- - **関心事の分離**: UI・ロジック・状態管理の明確な分離
977
- - **再利用性**: 汎用コンポーネントの適切な抽象化
978
-
979
- #### 3. **状態管理戦略**
980
-
981
- ```plantuml
982
- @startuml
983
- package "状態管理レイヤー" {
984
- rectangle "サーバー状態" as server #lightblue
985
- rectangle "クライアント状態" as client #lightgreen
986
- rectangle "UI状態" as ui #lightyellow
987
- }
988
-
989
- package "管理ツール" {
990
- rectangle "React Query / SWR" as rq
991
- rectangle "Redux / Zustand" as global
992
- rectangle "useState / useReducer" as local
993
- }
994
-
995
- server --> rq : キャッシュ・同期
996
- client --> global : グローバル共有
997
- ui --> local : ローカル管理
998
- @enduml
999
- ```
1000
-
1001
- #### 4. **レンダリング戦略**
1002
-
1003
- | 戦略 | 適用場面 | 特徴 | 例 |
1004
- |------|----------|------|-----|
1005
- | **SPA** | ダッシュボード・管理画面 | 高いインタラクティビティ | React |
1006
- | **SSR** | SEO重要・高更新頻度 | 初期表示高速・SEO対応 | Next.js |
1007
- | **SSG** | SEO重要・低更新頻度 | 最高のパフォーマンス | Gatsby |
1008
-
1009
- ### 悪いアーキテクチャ決定
1010
-
1011
- #### ❌ **避けるべき設計**
1012
-
1013
- 1. **フラットなプロジェクト構造**
1014
- ```
1015
- src/
1016
- ├── LoginPage.tsx # 管理困難
1017
- ├── Button.tsx # コンポーネント分類なし
1018
- ├── UserService.ts # ロジック散在
1019
- ├── constants.ts # 設定管理なし
1020
- ├── utils.ts # 目的不明
1021
- ├── types.ts # 型定義混在
1022
- └── ... # 数十個のファイル(役割不明)
1023
- ```
1024
-
1025
- 2. **不適切な責務分散**
1026
- ```
1027
- src/
1028
- ├── components/ # 全コンポーネント混在
1029
- │ ├── LoginPage.tsx # ページなのにcomponents内
1030
- │ ├── Button.tsx # UIコンポーネント
1031
- │ ├── AuthProvider.tsx # Providerなのにcomponents内
1032
- │ └── authStore.ts # ストアなのにcomponents内
1033
- └── utils/ # 何でも入れる場所
1034
- ├── api.ts # API設定
1035
- ├── constants.ts # 定数
1036
- ├── types.ts # 型定義
1037
- └── validation.ts # バリデーション
1038
- ```
1039
-
1040
- 2. **巨大で密結合なコンポーネント**
1041
- ```tsx
1042
- // ❌ 悪い例
1043
- function MegaComponent() {
1044
- // 500行以上のコンポーネント
1045
- // 複数の責務を持つ
1046
- // テストが困難
1047
- }
1048
- ```
1049
-
1050
- 3. **不適切な状態管理**
1051
- ```tsx
1052
- // ❌ 悪い例:すべてをグローバル状態に
1053
- const globalState = {
1054
- user: {},
1055
- reservations: [],
1056
- modalOpen: false, // UI状態もグローバル化
1057
- buttonColor: 'blue' // 一時的な状態もグローバル化
1058
- }
1059
- ```
1060
-
1061
- 4. **セキュリティの軽視**
1062
- ```tsx
1063
- // ❌ 悪い例:入力値のサニタイジング不備
1064
- function UserInput({ input }) {
1065
- return <div dangerouslySetInnerHTML={{__html: input}} />
1066
- }
1067
- ```
1068
-
1069
- ## フロントエンド実装パターン
1070
-
1071
- ### 1. **コンポーネント設計パターン**
1072
-
1073
- #### Container/Presentational パターン
1074
-
1075
- ```
1076
- // ファイル配置例
1077
- src/
1078
- ├── features/reservation/
1079
- │ ├── components/
1080
- │ │ ├── ReservationContainer.tsx # Container
1081
- │ │ └── ReservationList.tsx # Presentational
1082
- │ ├── hooks/
1083
- │ │ └── useReservations.ts # Custom Hook
1084
- │ └── types/
1085
- │ └── reservation.ts # 型定義
1086
- ```
1087
-
1088
- ```tsx
1089
- // ✅ Container: ロジック担当 (features/reservation/components/ReservationContainer.tsx)
1090
- import { useReservations } from '../hooks/useReservations';
1091
- import { ReservationList } from './ReservationList';
1092
-
1093
- export function ReservationContainer() {
1094
- const { reservations, loading, createReservation } = useReservations();
1095
- const handleCreate = useCallback((data) => {
1096
- createReservation(data);
1097
- }, [createReservation]);
1098
-
1099
- return (
1100
- <ReservationList
1101
- reservations={reservations}
1102
- loading={loading}
1103
- onCreate={handleCreate}
1104
- />
1105
- );
1106
- }
1107
-
1108
- // ✅ Presentational: UI担当 (features/reservation/components/ReservationList.tsx)
1109
- import { LoadingSpinner } from '@/components/ui/LoadingSpinner';
1110
- import { CreateButton } from '@/components/ui/CreateButton';
1111
- import type { Reservation } from '../types/reservation';
1112
-
1113
- interface Props {
1114
- reservations: Reservation[];
1115
- loading: boolean;
1116
- onCreate: (data: CreateReservationData) => void;
1117
- }
1118
-
1119
- export function ReservationList({ reservations, loading, onCreate }: Props) {
1120
- if (loading) return <LoadingSpinner />;
1121
-
1122
- return (
1123
- <div>
1124
- {reservations.map(reservation =>
1125
- <ReservationItem key={reservation.id} data={reservation} />
1126
- )}
1127
- <CreateButton onClick={onCreate} />
1128
- </div>
1129
- );
1130
- }
1131
- ```
1132
-
1133
- #### Custom Hooks パターン
1134
- ```tsx
1135
- // ✅ ビジネスロジックの分離
1136
- function useReservation() {
1137
- const [reservations, setReservations] = useState([]);
1138
- const [loading, setLoading] = useState(false);
1139
-
1140
- const createReservation = useCallback(async (data) => {
1141
- setLoading(true);
1142
- try {
1143
- const result = await api.createReservation(data);
1144
- setReservations(prev => [...prev, result]);
1145
- } catch (error) {
1146
- handleError(error);
1147
- } finally {
1148
- setLoading(false);
1149
- }
1150
- }, []);
1151
-
1152
- return { reservations, loading, createReservation };
1153
- }
1154
- ```
1155
-
1156
- ### 2. **状態管理パターン**
1157
-
1158
- #### Context + Reducer パターン
1159
- ```tsx
1160
- // ✅ 状態とアクションの型安全な管理
1161
- interface AppState {
1162
- user: User | null;
1163
- theme: 'light' | 'dark';
1164
- }
1165
-
1166
- type AppAction =
1167
- | { type: 'SET_USER'; payload: User }
1168
- | { type: 'SET_THEME'; payload: 'light' | 'dark' };
1169
-
1170
- function appReducer(state: AppState, action: AppAction): AppState {
1171
- switch (action.type) {
1172
- case 'SET_USER':
1173
- return { ...state, user: action.payload };
1174
- case 'SET_THEME':
1175
- return { ...state, theme: action.payload };
1176
- default:
1177
- return state;
1178
- }
1179
- }
1180
-
1181
- const AppContext = createContext<{
1182
- state: AppState;
1183
- dispatch: Dispatch<AppAction>;
1184
- } | null>(null);
1185
- ```
1186
-
1187
- ### 3. **パフォーマンス最適化パターン**
1188
-
1189
- #### 遅延読み込み
1190
- ```tsx
1191
- // ✅ コード分割
1192
- const ReservationPage = lazy(() => import('./pages/ReservationPage'));
1193
- const UserManagementPage = lazy(() => import('./pages/UserManagementPage'));
1194
-
1195
- function App() {
1196
- return (
1197
- <Router>
1198
- <Suspense fallback={<LoadingSpinner />}>
1199
- <Routes>
1200
- <Route path="/reservations" element={<ReservationPage />} />
1201
- <Route path="/users" element={<UserManagementPage />} />
1202
- </Routes>
1203
- </Suspense>
1204
- </Router>
1205
- );
1206
- }
1207
- ```
1208
-
1209
- #### メモ化
1210
- ```tsx
1211
- // ✅ 適切なメモ化
1212
- const ExpensiveList = memo(function ExpensiveList({ items, filter }) {
1213
- const filteredItems = useMemo(
1214
- () => items.filter(item => item.type === filter),
1215
- [items, filter]
1216
- );
1217
-
1218
- return (
1219
- <ul>
1220
- {filteredItems.map(item =>
1221
- <ExpensiveListItem key={item.id} item={item} />
1222
- )}
1223
- </ul>
1224
- );
1225
- });
1226
- ```
1227
-
1228
- ## フロントエンド品質保証
1229
-
1230
- ### 1. **TypeScript活用**
1231
-
1232
- ```tsx
1233
- // ✅ 型安全なAPI呼び出し
1234
- interface CreateReservationRequest {
1235
- roomId: string;
1236
- startTime: string;
1237
- endTime: string;
1238
- purpose: string;
1239
- }
1240
-
1241
- interface ReservationResponse {
1242
- id: string;
1243
- status: 'confirmed' | 'pending' | 'cancelled';
1244
- createdAt: string;
1245
- }
1246
-
1247
- async function createReservation(
1248
- request: CreateReservationRequest
1249
- ): Promise<ReservationResponse> {
1250
- const response = await fetch('/api/reservations', {
1251
- method: 'POST',
1252
- headers: { 'Content-Type': 'application/json' },
1253
- body: JSON.stringify(request)
1254
- });
1255
-
1256
- if (!response.ok) {
1257
- throw new Error('予約作成に失敗しました');
1258
- }
1259
-
1260
- return response.json();
1261
- }
1262
- ```
1263
-
1264
- ### 2. **テスト戦略**
1265
-
1266
- #### ユニットテスト
1267
- ```tsx
1268
- // ✅ Custom Hooksのテスト
1269
- import { renderHook, act } from '@testing-library/react';
1270
- import { useReservation } from './useReservation';
1271
-
1272
- test('should create reservation successfully', async () => {
1273
- const { result } = renderHook(() => useReservation());
1274
-
1275
- await act(async () => {
1276
- await result.current.createReservation({
1277
- roomId: '1',
1278
- startTime: '2024-01-01T10:00:00Z',
1279
- endTime: '2024-01-01T11:00:00Z',
1280
- purpose: 'ミーティング'
1281
- });
1282
- });
1283
-
1284
- expect(result.current.reservations).toHaveLength(1);
1285
- });
1286
- ```
1287
-
1288
- #### 統合テスト
1289
- ```tsx
1290
- // ✅ コンポーネント統合テスト
1291
- import { render, screen, fireEvent, waitFor } from '@testing-library/react';
1292
- import { ReservationForm } from './ReservationForm';
1293
-
1294
- test('should submit reservation form', async () => {
1295
- const mockOnSubmit = jest.fn();
1296
-
1297
- render(<ReservationForm onSubmit={mockOnSubmit} />);
1298
-
1299
- fireEvent.change(screen.getByLabelText('会議室'), {
1300
- target: { value: '会議室A' }
1301
- });
1302
- fireEvent.click(screen.getByText('予約する'));
1303
-
1304
- await waitFor(() => {
1305
- expect(mockOnSubmit).toHaveBeenCalledWith(
1306
- expect.objectContaining({
1307
- roomName: '会議室A'
1308
- })
1309
- );
1310
- });
1311
- });
1312
- ```
1313
-
1314
- ## フロントエンド移行戦略
1315
-
1316
- ### 段階的移行アプローチ
1317
-
1318
- ```plantuml
1319
- @startuml
1320
- start
1321
-
1322
- :現行フロントエンド分析;
1323
-
1324
- if (移行戦略) then (段階的)
1325
- :新機能を新アーキテクチャで実装;
1326
- :既存機能の段階的リファクタリング;
1327
- else (リライト)
1328
- :新システムを並行開発;
1329
- :フィーチャーフラグによる切り替え;
1330
- endif
1331
-
1332
- :共通ライブラリの整備;
1333
- :コンポーネントライブラリの移行;
1334
- :状態管理の統合;
1335
-
1336
- :E2Eテストによる動作確認;
1337
- :パフォーマンステスト;
1338
-
1339
- :本番環境移行;
1340
- :監視・メトリクス設定;
1341
-
1342
- stop
1343
- @enduml
1344
- ```
1345
-
1346
- ## アーキテクチャ移行戦略
1347
-
1348
- ### 段階的移行アプローチ
1349
-
1350
- ```plantuml
1351
- @startuml
1352
- start
1353
-
1354
- :現状アーキテクチャ分析;
1355
- :移行計画策定;
1356
-
1357
- fork
1358
- :既存機能の段階的抽出;
1359
- fork again
1360
- :新機能の新アーキテクチャ実装;
1361
- end fork
1362
-
1363
- :境界コンテキスト定義;
1364
- :データ移行計画;
1365
- :テスト戦略見直し;
1366
-
1367
- fork
1368
- :モジュール単位での移行;
1369
- fork again
1370
- :継続的統合の維持;
1371
- end fork
1372
-
1373
- :移行完了確認;
1374
- :旧システム廃棄;
1375
-
1376
- stop
1377
- @enduml
1378
- ```
1379
-
1380
- ### 移行時の注意点
1381
-
1382
- #### バックエンド移行
1383
- 1. **段階的移行**: ビッグバン移行は避け、モジュール単位で実施
1384
- 2. **後方互換性**: 既存のAPIやインターフェースの維持
1385
- 3. **データ整合性**: 移行期間中のデータ同期戦略
1386
- 4. **テストカバレッジ**: 移行前後でのテスト品質維持
1387
- 5. **パフォーマンス監視**: 移行による性能劣化の早期検知
1388
-
1389
- #### フロントエンド移行
1390
- 1. **フィーチャーフラグ**: 新旧機能の段階的切り替え
1391
- 2. **コンポーネント移行**: デザインシステムの統一
1392
- 3. **状態管理移行**: データフローの一貫性維持
1393
- 4. **バンドルサイズ監視**: パフォーマンス劣化防止
1394
- 5. **ブラウザ互換性**: サポート対象ブラウザでの動作確認
1395
-
1396
- # インフラストラクチャアーキテクチャ
1397
-
1398
- ## インフラストラクチャ設計の原則
1399
-
1400
- ### 基本方針
1401
-
1402
- - **Infrastructure as Code (IaC)**: インフラの設定をコード化し、バージョン管理
1403
- - **自動化**: デプロイ・スケーリング・復旧の自動化
1404
- - **モニタリングとオブザーバビリティ**: システム状態の可視化と追跡
1405
- - **セキュリティファースト**: 設計段階からのセキュリティ考慮
1406
- - **コスト最適化**: リソース利用の効率化とコスト管理
1407
-
1408
- ## デプロイメントアーキテクチャパターン
1409
-
1410
- ### 1. モノリシックデプロイメント
1411
-
1412
- #### 適用場面
1413
- - **システム規模**: 小規模〜中規模
1414
- - **チーム規模**: 小規模チーム
1415
- - **特性**: 単一アプリケーション、シンプルなデプロイ
1416
-
1417
- #### 構造
1418
- ```plantuml
1419
- @startuml
1420
- node "Webサーバー" {
1421
- [アプリケーション]
1422
- }
1423
-
1424
- database "データベース" as DB
1425
-
1426
- cloud "ロードバランサー" as LB
1427
-
1428
- LB --> [アプリケーション]
1429
- [アプリケーション] --> DB
1430
- @enduml
1431
- ```
1432
-
1433
- **メリット**:
1434
-
1435
- - シンプルな構成
1436
- - 低い運用コスト
1437
- - デプロイが容易
1438
-
1439
- **デメリット**:
1440
-
1441
- - スケーリングの柔軟性が低い
1442
- - 単一障害点
1443
- - 大規模化時の制約
1444
-
1445
- ### 2. マイクロサービスデプロイメント
1446
-
1447
- #### 適用場面
1448
- - **システム規模**: 大規模
1449
- - **チーム規模**: 複数チーム
1450
- - **特性**: 独立したサービス、高いスケーラビリティ
1451
-
1452
- #### 構造
1453
- ```plantuml
1454
- @startuml
1455
- cloud "APIゲートウェイ" as gateway
1456
-
1457
- node "認証サービス" {
1458
- [Auth Service]
1459
- }
1460
-
1461
- node "予約サービス" {
1462
- [Reservation Service]
1463
- }
1464
-
1465
- node "会議室サービス" {
1466
- [Room Service]
1467
- }
1468
-
1469
- database "Auth DB" as authdb
1470
- database "Reservation DB" as resdb
1471
- database "Room DB" as roomdb
1472
-
1473
- gateway --> [Auth Service]
1474
- gateway --> [Reservation Service]
1475
- gateway --> [Room Service]
1476
- [Auth Service] --> authdb
1477
- [Reservation Service] --> resdb
1478
- [Room Service] --> roomdb
1479
- @enduml
1480
- ```
1481
-
1482
- **メリット**:
1483
-
1484
- - 独立したデプロイとスケーリング
1485
- - 技術スタックの柔軟性
1486
- - 障害の局所化
1487
-
1488
- **デメリット**:
1489
-
1490
- - 複雑な運用
1491
- - 分散システムの課題
1492
- - デバッグの困難さ
1493
-
1494
- ### 3. コンテナオーケストレーション
1495
-
1496
- #### 適用場面
1497
- - **デプロイ頻度**: 高頻度
1498
- - **スケーリング要件**: 動的スケーリング
1499
- - **特性**: Kubernetes、Docker等のコンテナ技術
1500
-
1501
- #### 構造
1502
- ```plantuml
1503
- @startuml
1504
- package "Kubernetesクラスター" {
1505
- node "マスターノード" {
1506
- [API Server]
1507
- [Scheduler]
1508
- [Controller]
1509
- }
1510
-
1511
- node "ワーカーノード1" {
1512
- [Pod 1]
1513
- [Pod 2]
1514
- }
1515
-
1516
- node "ワーカーノード2" {
1517
- [Pod 3]
1518
- [Pod 4]
1519
- }
1520
-
1521
- [API Server] --> [Pod 1]
1522
- [API Server] --> [Pod 2]
1523
- [API Server] --> [Pod 3]
1524
- [API Server] --> [Pod 4]
1525
- }
1526
- @enduml
1527
- ```
1528
-
1529
- **メリット**:
1530
-
1531
- - 自動スケーリング
1532
- - 高可用性
1533
- - リソース効率化
1534
-
1535
- **デメリット**:
1536
-
1537
- - 高い学習コスト
1538
- - 複雑な設定
1539
- - 運用の複雑さ
1540
-
1541
- ### 4. サーバーレスアーキテクチャ
1542
-
1543
- #### 適用場面
1544
- - **負荷パターン**: 変動が大きい
1545
- - **実行頻度**: イベント駆動、バースト型
1546
- - **特性**: AWS Lambda、Azure Functions等
1547
-
1548
- #### 構造
1549
- ```plantuml
1550
- @startuml
1551
- cloud "APIゲートウェイ" as api
1552
- rectangle "Lambda関数" as lambda1
1553
- rectangle "Lambda関数" as lambda2
1554
- rectangle "Lambda関数" as lambda3
1555
- database "DynamoDB" as db
1556
- queue "SQS" as queue
1557
-
1558
- api --> lambda1 : HTTP
1559
- queue --> lambda2 : イベント
1560
- lambda1 --> db
1561
- lambda2 --> db
1562
- lambda3 --> db
1563
- @enduml
1564
- ```
1565
-
1566
- **メリット**:
1567
-
1568
- - 完全なサーバー管理不要
1569
- - 自動スケーリング
1570
- - 従量課金
1571
-
1572
- **デメリット**:
1573
-
1574
- - コールドスタート
1575
- - ベンダーロックイン
1576
- - ローカルテストの困難さ
1577
-
1578
- ## ネットワークアーキテクチャ
1579
-
1580
- ### ネットワーク構成パターン
1581
-
1582
- ```plantuml
1583
- @startuml
1584
- package "DMZ(非武装地帯)" {
1585
- [ロードバランサー]
1586
- [リバースプロキシ]
1587
- }
1588
-
1589
- package "プライベートネットワーク" {
1590
- package "アプリケーション層" {
1591
- [Webサーバー]
1592
- [APサーバー]
1593
- }
1594
-
1595
- package "データ層" {
1596
- database "DB(Primary)"
1597
- database "DB(Replica)"
1598
- }
1599
- }
1600
-
1601
- cloud "インターネット" as internet
1602
-
1603
- internet --> [ロードバランサー]
1604
- [ロードバランサー] --> [リバースプロキシ]
1605
- [リバースプロキシ] --> [Webサーバー]
1606
- [Webサーバー] --> [APサーバー]
1607
- [APサーバー] --> "DB(Primary)"
1608
- "DB(Primary)" --> "DB(Replica)" : レプリケーション
1609
- @enduml
1610
- ```
1611
-
1612
- ### ネットワーク設計の要点
1613
-
1614
- | 要素 | 考慮事項 |
1615
- |------|----------|
1616
- | **負荷分散** | ロードバランサーによる複数サーバーへの分散 |
1617
- | **セキュリティ** | ファイアウォール、WAF、DDoS対策 |
1618
- | **可用性** | 冗長化、フェイルオーバー |
1619
- | **パフォーマンス** | CDN、キャッシング、帯域幅 |
1620
-
1621
- ## スケーリング戦略
1622
-
1623
- ### 垂直スケーリング vs 水平スケーリング
1624
-
1625
- ```plantuml
1626
- @startuml
1627
- left to right direction
1628
-
1629
- package "垂直スケーリング" {
1630
- node "サーバー" as v1 {
1631
- [CPU: 2コア\nメモリ: 4GB]
1632
- }
1633
-
1634
- node "サーバー" as v2 {
1635
- [CPU: 8コア\nメモリ: 32GB]
1636
- }
1637
-
1638
- v1 -right-> v2 : スペックアップ
1639
- }
1640
-
1641
- package "水平スケーリング" {
1642
- node "サーバー1" as h1 {
1643
- [CPU: 2コア\nメモリ: 4GB]
1644
- }
1645
-
1646
- node "サーバー2" as h2 {
1647
- [CPU: 2コア\nメモリ: 4GB]
1648
- }
1649
-
1650
- node "サーバー3" as h3 {
1651
- [CPU: 2コア\nメモリ: 4GB]
1652
- }
1653
-
1654
- h1 -right-> h2 : サーバー追加
1655
- h2 -right-> h3 : サーバー追加
1656
- }
1657
- @enduml
1658
- ```
1659
-
1660
- ### スケーリング戦略の選択
1661
-
1662
- | 戦略 | メリット | デメリット | 適用場面 |
1663
- |------|----------|------------|----------|
1664
- | **垂直スケーリング** | シンプル、データ整合性保持 | 物理的上限、ダウンタイム | データベース、レガシーシステム |
1665
- | **水平スケーリング** | 柔軟性、高可用性 | 複雑な設計、データ分散 | Webアプリケーション、マイクロサービス |
1666
-
1667
- ### オートスケーリング
1668
-
1669
- ```plantuml
1670
- @startuml
1671
- start
1672
-
1673
- :負荷監視;
1674
-
1675
- if (CPU使用率 > 80%?) then (yes)
1676
- :インスタンス追加;
1677
- :負荷分散設定更新;
1678
- else if (CPU使用率 < 20%?) then (yes)
1679
- :インスタンス削減;
1680
- :負荷分散設定更新;
1681
- else (no)
1682
- :現状維持;
1683
- endif
1684
-
1685
- :負荷監視;
1686
-
1687
- stop
1688
- @enduml
1689
- ```
1690
-
1691
- ## 監視とログ管理
1692
-
1693
- ### 監視アーキテクチャ
1694
-
1695
- ```plantuml
1696
- @startuml
1697
- package "アプリケーション" {
1698
- [Webサーバー]
1699
- [APサーバー]
1700
- [DBサーバー]
1701
- }
1702
-
1703
- package "監視システム" {
1704
- [メトリクス収集] as metrics
1705
- [ログ収集] as logs
1706
- [アラート管理] as alerts
1707
- }
1708
-
1709
- package "可視化・分析" {
1710
- [ダッシュボード]
1711
- [ログ分析]
1712
- [トレーシング]
1713
- }
1714
-
1715
- [Webサーバー] --> metrics
1716
- [APサーバー] --> metrics
1717
- [DBサーバー] --> metrics
1718
-
1719
- [Webサーバー] --> logs
1720
- [APサーバー] --> logs
1721
- [DBサーバー] --> logs
1722
-
1723
- metrics --> [ダッシュボード]
1724
- logs --> [ログ分析]
1725
- metrics --> alerts
1726
- logs --> alerts
1727
- @enduml
1728
- ```
1729
-
1730
- ### 監視対象と指標
1731
-
1732
- | カテゴリ | 監視項目 | 重要指標 |
1733
- |----------|----------|----------|
1734
- | **インフラ** | CPU、メモリ、ディスク、ネットワーク | 使用率、レスポンス時間 |
1735
- | **アプリケーション** | レスポンスタイム、エラー率、スループット | レイテンシ、成功率 |
1736
- | **ビジネス** | アクティブユーザー数、トランザクション数 | コンバージョン率、利用状況 |
1737
-
1738
- ### ログ管理戦略
1739
-
1740
- #### ログレベルの定義
1741
-
1742
- ```java
1743
- // ✅ 適切なログレベルの使用
1744
- public class ReservationService {
1745
- private static final Logger logger = LoggerFactory.getLogger(ReservationService.class);
1746
-
1747
- public void createReservation(ReservationRequest request) {
1748
- logger.debug("予約作成開始: {}", request);
1749
-
1750
- try {
1751
- var reservation = processReservation(request);
1752
- logger.info("予約作成成功: reservationId={}", reservation.getId());
1753
- } catch (BusinessException e) {
1754
- logger.warn("予約作成失敗(ビジネスエラー): {}", e.getMessage());
1755
- throw e;
1756
- } catch (Exception e) {
1757
- logger.error("予約作成失敗(システムエラー)", e);
1758
- throw new SystemException("予約作成処理でエラーが発生しました", e);
1759
- }
1760
- }
1761
- }
1762
- ```
1763
-
1764
- #### ログの集約と分析
1765
-
1766
- - **集約**: Fluentd、Logstash等でログを集約
1767
- - **保存**: Elasticsearch、S3等で長期保存
1768
- - **分析**: Kibana、CloudWatch Insights等で可視化・分析
1769
-
1770
- ## セキュリティアーキテクチャ
1771
-
1772
- ### 多層防御アーキテクチャ
1773
-
1774
- ```plantuml
1775
- @startuml
1776
- left to right direction
1777
-
1778
- rectangle "インターネット" as internet
1779
-
1780
- package "セキュリティ層" {
1781
- rectangle "WAF/DDoS対策" as waf
1782
- rectangle "ファイアウォール" as fw
1783
- rectangle "IDS/IPS" as ids
1784
- }
1785
-
1786
- package "認証・認可層" {
1787
- rectangle "認証サーバー" as auth
1788
- rectangle "API Gateway" as apigw
1789
- }
1790
-
1791
- package "アプリケーション層" {
1792
- rectangle "暗号化通信" as encrypt
1793
- rectangle "入力検証" as validation
1794
- rectangle "アクセス制御" as access
1795
- }
1796
-
1797
- package "データ層" {
1798
- database "暗号化DB" as db
1799
- rectangle "監査ログ" as audit
1800
- }
1801
-
1802
- internet --> waf
1803
- waf --> fw
1804
- fw --> ids
1805
- ids --> auth
1806
- auth --> apigw
1807
- apigw --> encrypt
1808
- encrypt --> validation
1809
- validation --> access
1810
- access --> db
1811
- db --> audit
1812
- @enduml
1813
- ```
1814
-
1815
- ### セキュリティベストプラクティス
1816
-
1817
- | 領域 | 対策 | 実装例 |
1818
- |------|------|--------|
1819
- | **ネットワーク** | ファイアウォール、WAF、DDoS対策 | AWS WAF, CloudFlare |
1820
- | **認証・認可** | 多要素認証、OAuth2.0、RBAC | Auth0, Keycloak |
1821
- | **データ保護** | 暗号化(保管時・転送時)、マスキング | TLS/SSL, AES-256 |
1822
- | **監査** | アクセスログ、変更履歴、コンプライアンス | CloudTrail, 監査ログ |
1823
-
1824
- ### セキュリティ実装例
1825
-
1826
- ```java
1827
- // ✅ セキュアな実装
1828
- @RestController
1829
- @RequestMapping("/api/reservations")
1830
- public class ReservationController {
1831
-
1832
- @PostMapping
1833
- @PreAuthorize("hasRole('USER')") // 認可チェック
1834
- public ResponseEntity<Reservation> create(
1835
- @Valid @RequestBody CreateReservationRequest request) { // 入力検証
1836
-
1837
- // SQLインジェクション対策(PreparedStatement使用)
1838
- var reservation = reservationService.createReservation(request);
1839
-
1840
- // 監査ログ記録
1841
- auditService.log("RESERVATION_CREATED", reservation.getId());
1842
-
1843
- return ResponseEntity.ok(reservation);
1844
- }
1845
- }
1846
- ```
1847
-
1848
- ## バックアップと災害復旧
1849
-
1850
- ### バックアップ戦略
1851
-
1852
- ```plantuml
1853
- @startuml
1854
- package "本番環境" {
1855
- database "本番DB" as prod
1856
- }
1857
-
1858
- package "バックアップ" {
1859
- database "日次バックアップ" as daily
1860
- database "週次バックアップ" as weekly
1861
- database "月次バックアップ" as monthly
1862
- }
1863
-
1864
- package "災害復旧サイト" {
1865
- database "DR環境" as dr
1866
- }
1867
-
1868
- prod --> daily : 毎日
1869
- prod --> weekly : 毎週
1870
- prod --> monthly : 毎月
1871
- prod --> dr : リアルタイムレプリケーション
1872
- @enduml
1873
- ```
1874
-
1875
- ### RPO/RTO定義
1876
-
1877
- | 指標 | 意味 | 目標値例 |
1878
- |------|------|----------|
1879
- | **RPO (Recovery Point Objective)** | データ損失許容時間 | 1時間以内 |
1880
- | **RTO (Recovery Time Objective)** | サービス復旧目標時間 | 4時間以内 |
1881
-
1882
- ### ディザスタリカバリパターン
1883
-
1884
- #### 1. バックアップ&リストア
1885
- - **RPO**: 数時間〜1日
1886
- - **RTO**: 数時間〜1日
1887
- - **コスト**: 低
1888
- - **用途**: 非重要システム
1889
-
1890
- #### 2. パイロットライト
1891
- - **RPO**: 数分〜数時間
1892
- - **RTO**: 1時間以内
1893
- - **コスト**: 中
1894
- - **用途**: ビジネス継続性が重要
1895
-
1896
- #### 3. ウォームスタンバイ
1897
- - **RPO**: 数秒〜数分
1898
- - **RTO**: 数分
1899
- - **コスト**: 高
1900
- - **用途**: 高可用性要求システム
1901
-
1902
- #### 4. マルチサイトアクティブ/アクティブ
1903
- - **RPO**: ゼロ
1904
- - **RTO**: ゼロ(自動フェイルオーバー)
1905
- - **コスト**: 非常に高
1906
- - **用途**: ミッションクリティカルシステム
1907
-
1908
- ## Infrastructure as Code (IaC)
1909
-
1910
- ### IaCツールの選択
1911
-
1912
- | ツール | 特徴 | 適用場面 |
1913
- |--------|------|----------|
1914
- | **Terraform** | マルチクラウド対応、宣言的 | クラウド横断的なインフラ管理 |
1915
- | **CloudFormation** | AWS特化、AWSサービスとの統合 | AWS専用環境 |
1916
- | **Ansible** | 構成管理、手続き型 | サーバー設定管理 |
1917
- | **Pulumi** | 汎用プログラミング言語使用 | 複雑なロジック要求時 |
1918
-
1919
- ### IaC実装例(Terraform)
1920
-
1921
- ```hcl
1922
- # ✅ VPC定義
1923
- resource "aws_vpc" "main" {
1924
- cidr_block = "10.0.0.0/16"
1925
- enable_dns_hostnames = true
1926
- enable_dns_support = true
1927
-
1928
- tags = {
1929
- Name = "main-vpc"
1930
- Environment = var.environment
1931
- }
1932
- }
1933
-
1934
- # ✅ サブネット定義
1935
- resource "aws_subnet" "public" {
1936
- count = 2
1937
- vpc_id = aws_vpc.main.id
1938
- cidr_block = "10.0.${count.index}.0/24"
1939
- availability_zone = data.aws_availability_zones.available.names[count.index]
1940
- map_public_ip_on_launch = true
1941
-
1942
- tags = {
1943
- Name = "public-subnet-${count.index + 1}"
1944
- }
1945
- }
1946
-
1947
- # ✅ セキュリティグループ
1948
- resource "aws_security_group" "web" {
1949
- name = "web-sg"
1950
- description = "Security group for web servers"
1951
- vpc_id = aws_vpc.main.id
1952
-
1953
- ingress {
1954
- from_port = 443
1955
- to_port = 443
1956
- protocol = "tcp"
1957
- cidr_blocks = ["0.0.0.0/0"]
1958
- }
1959
-
1960
- egress {
1961
- from_port = 0
1962
- to_port = 0
1963
- protocol = "-1"
1964
- cidr_blocks = ["0.0.0.0/0"]
1965
- }
1966
- }
1967
- ```
1968
-
1969
- ## CI/CDパイプライン
1970
-
1971
- ### CI/CDアーキテクチャ
1972
-
1973
- ```plantuml
1974
- @startuml
1975
- start
1976
-
1977
- :コード変更;
1978
- :Git Push;
1979
-
1980
- fork
1981
- :ユニットテスト実行;
1982
- fork again
1983
- :静的解析;
1984
- fork again
1985
- :コードカバレッジ;
1986
- end fork
1987
-
1988
- :ビルド;
1989
-
1990
- if (テスト成功?) then (yes)
1991
- :コンテナイメージ作成;
1992
- :イメージレジストリ登録;
1993
-
1994
- if (本番デプロイ?) then (yes)
1995
- :承認待ち;
1996
- :本番デプロイ;
1997
- else (no)
1998
- :ステージングデプロイ;
1999
- endif
2000
-
2001
- :スモークテスト;
2002
- :監視開始;
2003
- else (no)
2004
- :通知(失敗);
2005
- stop
2006
- endif
2007
-
2008
- :デプロイ完了;
2009
-
2010
- stop
2011
- @enduml
2012
- ```
2013
-
2014
- ### デプロイメント戦略
2015
-
2016
- #### ブルーグリーンデプロイメント
2017
-
2018
- ```plantuml
2019
- @startuml
2020
- left to right direction
2021
-
2022
- cloud "ロードバランサー" as lb
2023
-
2024
- package "Blue環境(現行)" {
2025
- node "App v1.0" as blue1
2026
- node "App v1.0" as blue2
2027
- }
2028
-
2029
- package "Green環境(新規)" {
2030
- node "App v2.0" as green1
2031
- node "App v2.0" as green2
2032
- }
2033
-
2034
- lb --> blue1
2035
- lb --> blue2
2036
- @enduml
2037
- ```
2038
-
2039
- **メリット**:
2040
-
2041
- - 即座にロールバック可能
2042
- - ゼロダウンタイム
2043
- - 本番環境での検証
2044
-
2045
- **デメリット**:
2046
-
2047
- - リソースが2倍必要
2048
- - データベース移行の複雑さ
2049
-
2050
- #### カナリアデプロイメント
2051
-
2052
- ```plantuml
2053
- @startuml
2054
- cloud "ロードバランサー" as lb
2055
-
2056
- package "本番環境" {
2057
- node "App v1.0" as old1
2058
- node "App v1.0" as old2
2059
- node "App v1.0" as old3
2060
- node "App v2.0(カナリア)" as canary
2061
- }
2062
-
2063
- lb --> old1 : 75%
2064
- lb --> old2 : 75%
2065
- lb --> old3 : 75%
2066
- lb --> canary : 25%
2067
- @enduml
2068
- ```
2069
-
2070
- **メリット**:
2071
-
2072
- - リスク最小化
2073
- - 段階的なロールアウト
2074
- - 問題の早期発見
2075
-
2076
- **デメリット**:
2077
-
2078
- - 複雑な管理
2079
- - バージョン混在期間
2080
-
2081
- ## インフラストラクチャ評価基準
2082
-
2083
- ### 品質属性評価マトリックス
2084
-
2085
- | 品質属性 | モノリシック | マイクロサービス | コンテナ | サーバーレス |
2086
- |----------|:---:|:---:|:---:|:---:|
2087
- | **運用複雑性** | ⭐⭐⭐⭐⭐ | ⭐⭐ | ⭐⭐⭐ | ⭐⭐⭐⭐ |
2088
- | **スケーラビリティ** | ⭐⭐ | ⭐⭐⭐⭐⭐ | ⭐⭐⭐⭐ | ⭐⭐⭐⭐⭐ |
2089
- | **コスト効率** | ⭐⭐⭐ | ⭐⭐ | ⭐⭐⭐⭐ | ⭐⭐⭐⭐⭐ |
2090
- | **デプロイ速度** | ⭐⭐⭐ | ⭐⭐⭐⭐ | ⭐⭐⭐⭐⭐ | ⭐⭐⭐⭐⭐ |
2091
- | **可用性** | ⭐⭐ | ⭐⭐⭐⭐⭐ | ⭐⭐⭐⭐⭐ | ⭐⭐⭐⭐ |
2092
- | **監視・デバッグ** | ⭐⭐⭐⭐⭐ | ⭐⭐ | ⭐⭐⭐ | ⭐⭐ |
2093
-
2094
- ### コスト最適化戦略
2095
-
2096
- | 戦略 | 実装方法 | 削減効果 |
2097
- |------|----------|----------|
2098
- | **リソース最適化** | 適切なインスタンスサイズ選択 | 20-40% |
2099
- | **予約インスタンス** | 長期コミットメントで割引 | 40-60% |
2100
- | **スポットインスタンス** | 余剰リソースの活用 | 70-90% |
2101
- | **オートスケーリング** | 需要に応じた自動調整 | 30-50% |
2102
- | **ストレージ最適化** | ライフサイクル管理、圧縮 | 30-60% |
2103
-
2104
- ## インフラストラクチャ移行戦略
2105
-
2106
- ### クラウド移行パターン
2107
-
2108
- ```plantuml
2109
- @startuml
2110
- start
2111
-
2112
- :現状分析;
2113
-
2114
- if (移行戦略) then (リフト&シフト)
2115
- :既存システムをそのままクラウドへ;
2116
- :最小限の変更;
2117
- else if (リプラットフォーム) then
2118
- :軽微な最適化;
2119
- :クラウドサービス活用;
2120
- else if (リアーキテクト) then
2121
- :アプリケーション再設計;
2122
- :クラウドネイティブ化;
2123
- else (リビルド)
2124
- :完全な再構築;
2125
- :最新アーキテクチャ採用;
2126
- endif
2127
-
2128
- :移行実行;
2129
- :検証;
2130
- :最適化;
2131
-
2132
- stop
2133
- @enduml
2134
- ```
2135
-
2136
- ### 移行時の注意点
2137
-
2138
- 1. **段階的移行**: すべてを一度に移行せず、段階的に実施
2139
- 2. **パイロットプロジェクト**: 小規模システムで先行検証
2140
- 3. **データ移行計画**: データの整合性とダウンタイム最小化
2141
- 4. **セキュリティ**: クラウド環境でのセキュリティ要件確認
2142
- 5. **コスト管理**: 移行コストと運用コストの可視化
2143
-
2144
- # まとめ
2145
-
2146
- ## バックエンドアーキテクチャ選択の指針
2147
-
2148
- 1. **業務ドメインの理解**: 中核業務と補完業務の明確な識別
2149
- 2. **データ複雑性の評価**: エンティティ関係とビジネスルールの複雑さ
2150
- 3. **非機能要件の考慮**: パフォーマンス、スケーラビリティ、監査要件
2151
- 4. **チーム能力の評価**: 技術的習熟度と学習意欲
2152
- 5. **長期戦略の整合**: 将来的な拡張性と保守性の確保
2153
-
2154
- ## フロントエンドアーキテクチャ選択の指針
2155
-
2156
- 1. **プロジェクト規模**: 小規模・中規模・大規模に応じた構造設計
2157
- 2. **ユーザー体験要件**: SEO・パフォーマンス・インタラクティビティの優先順位
2158
- 3. **状態管理複雑性**: データフロー・更新頻度・共有範囲の分析
2159
- 4. **チーム構成**: フロントエンド専任・フルスタック・QAエンジニアの有無
2160
- 5. **技術的制約**: ブラウザサポート・既存システム・運用環境
2161
-
2162
- ## インフラストラクチャアーキテクチャ選択の指針
2163
-
2164
- 1. **システム規模とトラフィック**: 予想される負荷・成長率・ピーク時の要件分析
2165
- 2. **可用性要件**: SLA・ダウンタイム許容度・災害復旧要件の定義
2166
- 3. **セキュリティ要件**: コンプライアンス・データ保護・監査要件の評価
2167
- 4. **運用体制**: チームの技術力・運用負荷・自動化レベルの考慮
2168
- 5. **コスト制約**: 初期投資・運用コスト・スケーリングコストのバランス
2169
-
2170
- ## 成功要因
2171
-
2172
- ### バックエンド
2173
- - **適切なパターン選択**: 業務特性に応じた最適なアーキテクチャの採用
2174
- - **段階的な実装**: 小さく始めて継続的に改善
2175
- - **品質の作り込み**: テストファースト・継続的インテグレーション
2176
- - **ドメイン駆動設計**: ビジネスルールの適切な表現と分離
2177
-
2178
- ### フロントエンド
2179
- - **適切な技術選択**: 要件に応じたライブラリ・フレームワークの選定
2180
- - **コンポーネント設計**: 再利用性と保守性を両立した設計
2181
- - **状態管理戦略**: スケールに応じた適切な状態管理手法の採用
2182
- - **パフォーマンス最適化**: ユーザー体験を重視したパフォーマンス設計
2183
-
2184
- ### インフラストラクチャ
2185
- - **自動化の徹底**: IaC によるインフラ管理とデプロイメントの自動化
2186
- - **監視とオブザーバビリティ**: 包括的な監視体制と問題の早期検知
2187
- - **セキュリティの組み込み**: 設計段階からのセキュリティ対策実装
2188
- - **コスト最適化**: リソース利用の継続的な見直しと最適化
2189
-
2190
- ## 統合的成功要因
2191
-
2192
- - **チーム教育**: アーキテクチャ原則の共有と実践
2193
- - **継続的改善**: 定期的な設計見直しとリファクタリング
2194
- - **品質文化**: 自動テスト・コードレビュー・静的解析の徹底
2195
- - **段階的移行**: リスクを最小化した漸進的なアーキテクチャ改善
2196
-
2197
- ## 実践ポイント
2198
-
2199
- ### 開発初期
2200
-
2201
- 1. **要件に基づく技術選択**: 過度な技術より要件適合性を重視
2202
- 2. **プロトタイプ開発**: アーキテクチャ妥当性の早期検証
2203
- 3. **チーム合意形成**: 技術選択の背景と理由の共有
2204
-
2205
- ### 開発中期
2206
-
2207
- 1. **継続的リファクタリング**: 設計負債の早期解消
2208
- 2. **パフォーマンス監視**: 品質メトリクスに基づく改善
2209
- 3. **テストカバレッジ**: アーキテクチャ変更に対する安全性確保
2210
-
2211
- ### 運用期
2212
-
2213
- 1. **監視・メトリクス**: 実装の効果測定と改善指針
2214
- 2. **技術的負債管理**: 計画的なアーキテクチャ改善
2215
- 3. **スケーラビリティ対応**: 成長に応じたアーキテクチャ進化
2216
-
1
+ # アーキテクチャ設計ガイド
2
+
3
+ ## 概要
4
+
5
+ 本ガイドは、システム開発におけるアーキテクチャ設計の指針を提供します。バックエンドでは業務領域の特性とデータ構造の複雑さに基づいたアーキテクチャパターンの選択を、フロントエンドでは現代的なWebアプリケーション開発のベストプラクティスを定義します。
6
+
7
+ ## アーキテクチャ設計の原則
8
+
9
+ ### 基本方針
10
+
11
+ - **モノレポ構成**: 単一リポジトリでフロントエンド・バックエンドを統合管理
12
+ - **関心事の分離**: 明確な責務分離によるメンテナンス性向上
13
+ - **依存関係の方向性**: 外側から内側(ドメイン)への単方向依存
14
+ - **テストしやすい設計**: 各層が独立してテスト可能な構造
15
+
16
+ ## 全体構成
17
+
18
+ ```plantuml
19
+ @startuml
20
+ package "インフラストラクチャ" {
21
+ package "ネットワーク" {
22
+ package "アプリケーション" {
23
+ package "フロントエンド" {
24
+ [Webアプリケーション] as WebApp
25
+ }
26
+
27
+ package "バックエンド" {
28
+ [APIサーバー] as API
29
+ database "データベース" as DB
30
+ }
31
+
32
+ WebApp --> API : HTTP/REST
33
+ API --> DB : SQL/NoSQL
34
+ }
35
+ }
36
+ }
37
+ @endtuml
38
+ ```
39
+
40
+ ### コンポーネント責務
41
+
42
+ #### アプリケーション
43
+
44
+ ##### フロントエンド
45
+
46
+ - **UI/UX**: ユーザーインターフェース・ユーザー体験
47
+ - **状態管理**: アプリケーション状態とサーバー状態の管理
48
+ - **API連携**: バックエンドとのデータ通信
49
+ - **レンダリング**: 効率的な画面描画とユーザーインタラクション
50
+
51
+ ##### バックエンド
52
+
53
+ - **ビジネスロジック**: 業務ルール・制約の実装
54
+ - **データ永続化**: データの保存・取得・更新・削除
55
+ - **セキュリティ**: 認証・認可・データ保護
56
+ - **外部システム連携**: API・メッセージング・ファイル処理
57
+
58
+ #### インフラストラクチャ
59
+
60
+ - **ネットワーク**: 負荷分散・DNS・CDN
61
+ - **アプリケーション**: ホスティング: サーバー・コンテナ管理
62
+
63
+ # バックエンドアーキテクチャ
64
+
65
+ ## バックエンドアーキテクチャパターン選択フロー
66
+
67
+ ```plantuml
68
+ @startuml
69
+ !define DECISION_COLOR #FFE6CC
70
+ !define PROCESS_COLOR #E6F3FF
71
+ !define TERMINAL_COLOR #E6FFE6
72
+
73
+ skinparam roundcorner 10
74
+ skinparam shadowing false
75
+
76
+ start
77
+
78
+ if (業務領域のカテゴリー) then (補完、一般との連携)
79
+ if (データ構造が複雑か?) then (いいえ)
80
+ :トランザクションスクリプト;
81
+ :逆ピラミッド形のテスト;
82
+ if (永続化モデルは複数か?) then (いいえ)
83
+ :レイヤードアーキテクチャ 3層;
84
+ else (はい)
85
+ :レイヤードアーキテクチャ 4層;
86
+ endif
87
+ else (はい)
88
+ :アクティブレコード;
89
+ :ダイヤモンド形のテスト;
90
+ if (永続化モデルは複数か?) then (いいえ)
91
+ :レイヤードアーキテクチャ 3層;
92
+ else (はい)
93
+ :レイヤードアーキテクチャ 4層;
94
+ endif
95
+ endif
96
+ else (中核の業務領域)
97
+ if (金額を扱う/分析/監査記録が必要か?) then (いいえ)
98
+ :ドメインモデル;
99
+ :ピラミッド形のテスト;
100
+ if (永続化モデルは複数か?) then (いいえ)
101
+ :ポートとアダプター;
102
+ else (はい)
103
+ :CQRS;
104
+ endif
105
+ else (はい)
106
+ :イベント履歴式ドメインモデル;
107
+ :ピラミッド形のテスト;
108
+ :CQRS;
109
+ endif
110
+ endif
111
+
112
+ stop
113
+ @enduml
114
+ ```
115
+
116
+ ### 判断基準
117
+
118
+ #### 業務領域カテゴリー
119
+
120
+ | カテゴリー | 特徴 | 例 |
121
+ |-----------|------|-----|
122
+ | **中核の業務領域** | 組織の競争優位性を決定する領域 | 商品管理、顧客管理、受注処理 |
123
+ | **補完、一般との連携** | 中核を支援する補助的な領域 | レポート出力、バッチ処理、外部連携 |
124
+
125
+ #### データ構造の複雑さ
126
+
127
+ | 複雑さ | 判定基準 |
128
+ |--------|----------|
129
+ | **複雑** | エンティティ間の関係が多く、ビジネスルールが複雑 |
130
+ | **シンプル** | 単純なCRUD操作が中心、関係性が少ない |
131
+
132
+ #### 特殊要件
133
+
134
+ - **金額を扱う**: 会計・決済・金融関連の処理
135
+ - **分析**: 大量データの集計・分析処理
136
+ - **監査記録が必要**: コンプライアンス・規制対応
137
+
138
+ ## アーキテクチャパターン詳細
139
+
140
+ ### 1. トランザクションスクリプトパターン
141
+
142
+ #### 適用場面
143
+ - **業務領域**: 補完・一般との連携
144
+ - **データ構造**: シンプル
145
+ - **システム規模**: 小規模
146
+
147
+ #### 特徴
148
+ ```plantuml
149
+ @startuml
150
+ package "トランザクションスクリプト" {
151
+ [スクリプト1] as s1
152
+ [スクリプト2] as s2
153
+ [スクリプト3] as s3
154
+ database "データベース" as db
155
+ }
156
+
157
+ s1 --> db
158
+ s2 --> db
159
+ s3 --> db
160
+ @enduml
161
+ ```
162
+
163
+ **メリット**:
164
+
165
+ - 実装が直感的でわかりやすい
166
+ - 開発速度が早い
167
+ - 小規模チームでも扱いやすい
168
+
169
+ **デメリット**:
170
+
171
+ - コードの重複が発生しやすい
172
+ - 大規模化すると保守が困難
173
+ - ビジネスロジックが散在する
174
+
175
+ #### 実装指針
176
+
177
+ ```java
178
+ // 例:会議室予約処理
179
+ public class ReservationService {
180
+ public void makeReservation(ReservationRequest request) {
181
+ // 1. バリデーション
182
+ validateRequest(request);
183
+
184
+ // 2. 重複チェック
185
+ checkConflicts(request);
186
+
187
+ // 3. 予約作成
188
+ createReservation(request);
189
+
190
+ // 4. 通知送信
191
+ sendNotification(request);
192
+ }
193
+ }
194
+ ```
195
+
196
+ ### 2. アクティブレコードパターン
197
+
198
+ #### 適用場面
199
+ - **業務領域**: 補完・一般との連携
200
+ - **データ構造**: 複雑
201
+ - **システム規模**: 中規模
202
+
203
+ #### 特徴
204
+ ```plantuml
205
+ @startuml
206
+ allow_mixing
207
+
208
+ class User {
209
+ +id: Long
210
+ +name: String
211
+ +email: String
212
+ +save()
213
+ +delete()
214
+ +findById()
215
+ }
216
+
217
+ class Reservation {
218
+ +id: Long
219
+ +userId: Long
220
+ +roomId: Long
221
+ +save()
222
+ +cancel()
223
+ +findByUser()
224
+ }
225
+
226
+ database "データベース" as db
227
+
228
+ User --> db : CRUD操作
229
+ Reservation --> db : CRUD操作
230
+ @enduml
231
+ ```
232
+
233
+ **メリット**:
234
+
235
+ - オブジェクトとデータベースの対応が明確
236
+ - ORMとの相性が良い
237
+ - 理解しやすい構造
238
+
239
+ **デメリット**:
240
+
241
+ - データアクセスとビジネスロジックが密結合
242
+ - テストが困難
243
+ - ドメインロジックが薄くなる傾向
244
+
245
+ #### 実装指針
246
+
247
+ ```java
248
+ // 例:予約エンティティ
249
+ @Entity
250
+ public class Reservation {
251
+ @Id
252
+ private Long id;
253
+ private Long userId;
254
+ private Long roomId;
255
+ private LocalDateTime startTime;
256
+ private LocalDateTime endTime;
257
+
258
+ // ビジネスロジックを含む
259
+ public void cancel() {
260
+ if (canCancel()) {
261
+ this.status = CANCELLED;
262
+ this.save();
263
+ }
264
+ }
265
+
266
+ public boolean canCancel() {
267
+ return startTime.isAfter(LocalDateTime.now().plusHours(2));
268
+ }
269
+ }
270
+ ```
271
+
272
+ ### 3. ドメインモデルパターン
273
+
274
+ #### 適用場面
275
+ - **業務領域**: 中核の業務領域
276
+ - **特殊要件**: 金額を扱わない、監査記録不要
277
+ - **システム規模**: 中規模〜大規模
278
+
279
+ #### 特徴
280
+ ```plantuml
281
+ @startuml
282
+ package "ドメイン層" {
283
+ class User
284
+ class Reservation
285
+ class MeetingRoom
286
+ class ReservationService
287
+ }
288
+
289
+ package "アプリケーション層" {
290
+ class ReservationUseCase
291
+ }
292
+
293
+ package "インフラストラクチャ層" {
294
+ class UserRepository
295
+ class ReservationRepository
296
+ }
297
+
298
+ ReservationUseCase --> ReservationService
299
+ ReservationService --> User
300
+ ReservationService --> Reservation
301
+ ReservationService --> MeetingRoom
302
+ ReservationUseCase --> UserRepository
303
+ ReservationUseCase --> ReservationRepository
304
+ @enduml
305
+ ```
306
+
307
+ **メリット**:
308
+
309
+ - リッチなドメインモデル
310
+ - ビジネスロジックの集約
311
+ - 高い保守性・拡張性
312
+ - テスト容易性
313
+
314
+ **デメリット**:
315
+
316
+ - 初期の学習コストが高い
317
+ - 設計の複雑さ
318
+ - 開発速度が遅い場合がある
319
+
320
+ #### 実装指針
321
+
322
+ ```java
323
+ // ドメインモデル例
324
+ public class Reservation {
325
+ private ReservationId id;
326
+ private UserId userId;
327
+ private MeetingRoomId roomId;
328
+ private TimeSlot timeSlot;
329
+ private ReservationStatus status;
330
+
331
+ // ファクトリーメソッド
332
+ public static Reservation create(UserId userId, MeetingRoomId roomId, TimeSlot timeSlot) {
333
+ validateTimeSlot(timeSlot);
334
+ return new Reservation(ReservationId.generate(), userId, roomId, timeSlot, CONFIRMED);
335
+ }
336
+
337
+ // ビジネスロジック
338
+ public void cancel(CancellationPolicy policy) {
339
+ if (!policy.canCancel(this.timeSlot)) {
340
+ throw new CancellationNotAllowedException();
341
+ }
342
+ this.status = CANCELLED;
343
+ }
344
+ }
345
+ ```
346
+
347
+ ### 4. イベント履歴式ドメインモデルパターン
348
+
349
+ #### 適用場面
350
+ - **業務領域**: 中核の業務領域
351
+ - **特殊要件**: 金額を扱う、分析・監査記録が必要
352
+ - **システム規模**: 大規模
353
+
354
+ #### 特徴
355
+ ```plantuml
356
+ @startuml
357
+ package "コマンド側" {
358
+ class ReservationAggregate
359
+ class DomainEvent
360
+ }
361
+
362
+ package "イベントストア" {
363
+ class EventStream
364
+ }
365
+
366
+ package "クエリ側" {
367
+ class ReservationProjection
368
+ class ReadModel
369
+ }
370
+
371
+ ReservationAggregate --> EventStream : イベント保存
372
+ EventStream --> ReservationProjection : イベント再生
373
+ ReservationProjection --> ReadModel : プロジェクション更新
374
+ @enduml
375
+ ```
376
+
377
+ **メリット**:
378
+
379
+ - 完全な監査証跡
380
+ - 時系列分析が可能
381
+ - 高いスケーラビリティ
382
+ - 複雑なクエリに対応
383
+
384
+ **デメリット**:
385
+
386
+ - 実装の複雑さ
387
+ - 高い学習コスト
388
+ - 結果整合性の考慮が必要
389
+
390
+ #### 実装指針
391
+
392
+ ```java
393
+ // イベント例
394
+ public class ReservationCreatedEvent extends DomainEvent {
395
+ private final ReservationId reservationId;
396
+ private final UserId userId;
397
+ private final MeetingRoomId roomId;
398
+ private final TimeSlot timeSlot;
399
+ private final LocalDateTime occurredAt;
400
+ }
401
+
402
+ // 集約例
403
+ public class ReservationAggregate {
404
+ private ReservationId id;
405
+ private List<DomainEvent> changes = new ArrayList<>();
406
+
407
+ public void create(UserId userId, MeetingRoomId roomId, TimeSlot timeSlot) {
408
+ var event = new ReservationCreatedEvent(id, userId, roomId, timeSlot, LocalDateTime.now());
409
+ apply(event);
410
+ }
411
+
412
+ private void apply(DomainEvent event) {
413
+ changes.add(event);
414
+ // 状態更新ロジック
415
+ }
416
+ }
417
+ ```
418
+
419
+ ## アーキテクチャスタイル詳細
420
+
421
+ ### 1. レイヤードアーキテクチャ(3層)
422
+
423
+ #### 適用場面
424
+ - **永続化モデル**: 単一
425
+ - **システム特性**: 標準的なエンタープライズアプリケーション
426
+
427
+ #### 構造
428
+ ```plantuml
429
+ @startuml
430
+ package "プレゼンテーション層" {
431
+ [コントローラー]
432
+ [UI]
433
+ }
434
+
435
+ package "ビジネスロジック層" {
436
+ [サービス]
437
+ [ドメインモデル]
438
+ }
439
+
440
+ package "データアクセス層" {
441
+ [リポジトリ]
442
+ [DAO]
443
+ }
444
+
445
+ database "データベース"
446
+
447
+ [コントローラー] --> [サービス]
448
+ [UI] --> [コントローラー]
449
+ [サービス] --> [リポジトリ]
450
+ [リポジトリ] --> [データベース]
451
+ @enduml
452
+ ```
453
+
454
+ #### 実装指針
455
+
456
+ ```java
457
+ // プレゼンテーション層
458
+ @RestController
459
+ public class ReservationController {
460
+ private final ReservationService service;
461
+
462
+ @PostMapping("/reservations")
463
+ public ResponseEntity<Reservation> create(@RequestBody CreateReservationRequest request) {
464
+ var reservation = service.createReservation(request);
465
+ return ResponseEntity.ok(reservation);
466
+ }
467
+ }
468
+
469
+ // ビジネスロジック層
470
+ @Service
471
+ public class ReservationService {
472
+ private final ReservationRepository repository;
473
+
474
+ public Reservation createReservation(CreateReservationRequest request) {
475
+ // ビジネスロジック実行
476
+ var reservation = new Reservation(request);
477
+ return repository.save(reservation);
478
+ }
479
+ }
480
+
481
+ // データアクセス層
482
+ @Repository
483
+ public interface ReservationRepository extends JpaRepository<Reservation, Long> {
484
+ List<Reservation> findByUserId(Long userId);
485
+ }
486
+ ```
487
+
488
+ ### 2. レイヤードアーキテクチャ(4層)
489
+
490
+ #### 適用場面
491
+ - **永続化モデル**: 複数
492
+ - **システム特性**: 大規模エンタープライズアプリケーション
493
+
494
+ #### 構造
495
+ ```plantuml
496
+ @startuml
497
+ package "プレゼンテーション層" {
498
+ [コントローラー]
499
+ }
500
+
501
+ package "アプリケーション層" {
502
+ [アプリケーションサービス]
503
+ [ユースケース]
504
+ }
505
+
506
+ package "ドメイン層" {
507
+ [ドメインサービス]
508
+ [エンティティ]
509
+ }
510
+
511
+ package "インフラストラクチャ層" {
512
+ [リポジトリ実装]
513
+ [外部API]
514
+ }
515
+
516
+ [コントローラー] --> [アプリケーションサービス]
517
+ [アプリケーションサービス] --> [ドメインサービス]
518
+ [アプリケーションサービス] --> [リポジトリ実装]
519
+ @enduml
520
+ ```
521
+
522
+ #### レイヤー責務
523
+
524
+ | レイヤー | 責務 |
525
+ |----------|------|
526
+ | **プレゼンテーション** | HTTP要求/応答、入力検証、認証 |
527
+ | **アプリケーション** | ユースケース制御、トランザクション境界 |
528
+ | **ドメイン** | ビジネスルール、不変条件、ドメインサービス |
529
+ | **インフラストラクチャ** | 外部システム連携、永続化、技術的関心事 |
530
+
531
+ ### 3. ポートとアダプターアーキテクチャ(ヘキサゴナル)
532
+
533
+ #### 適用場面
534
+ - **ドメインモデル**: あり
535
+ - **永続化モデル**: 単一
536
+ - **システム特性**: マイクロサービス、高いテスト容易性が要求される
537
+
538
+ #### 構造
539
+ ```plantuml
540
+ @startuml
541
+ hexagon "ドメイン\nモデル" as domain
542
+
543
+ interface "入力ポート" as inport
544
+ interface "出力ポート" as outport
545
+
546
+ [Webアダプター] as web
547
+ [CLIアダプター] as cli
548
+ [データベースアダプター] as db
549
+ [外部APIアダプター] as api
550
+
551
+ web --> inport
552
+ cli --> inport
553
+ inport --> domain
554
+ domain --> outport
555
+ outport <|-- db
556
+ outport <|-- api
557
+ @enduml
558
+ ```
559
+
560
+ #### 実装指針
561
+
562
+ ```java
563
+ // 入力ポート(ユースケース)
564
+ public interface CreateReservationUseCase {
565
+ ReservationId execute(CreateReservationCommand command);
566
+ }
567
+
568
+ // 出力ポート(リポジトリインターフェース)
569
+ public interface ReservationRepository {
570
+ void save(Reservation reservation);
571
+ Optional<Reservation> findById(ReservationId id);
572
+ }
573
+
574
+ // ドメインサービス(実装)
575
+ @Service
576
+ public class ReservationService implements CreateReservationUseCase {
577
+ private final ReservationRepository repository;
578
+
579
+ @Override
580
+ public ReservationId execute(CreateReservationCommand command) {
581
+ var reservation = Reservation.create(command);
582
+ repository.save(reservation);
583
+ return reservation.getId();
584
+ }
585
+ }
586
+
587
+ // アダプター(インフラストラクチャ)
588
+ @Repository
589
+ public class JpaReservationRepository implements ReservationRepository {
590
+ private final SpringDataReservationRepository jpaRepository;
591
+
592
+ @Override
593
+ public void save(Reservation reservation) {
594
+ var entity = toEntity(reservation);
595
+ jpaRepository.save(entity);
596
+ }
597
+ }
598
+ ```
599
+
600
+ ### 4. CQRSアーキテクチャ
601
+
602
+ #### 適用場面
603
+ - **永続化モデル**: 複数
604
+ - **特殊要件**: イベント履歴式、高スケーラビリティ
605
+ - **システム特性**: 複雑なクエリ要件、読み書き分離
606
+
607
+ #### 構造
608
+ ```plantuml
609
+ @startuml
610
+ package "コマンド側" {
611
+ [コマンドハンドラー] as ch
612
+ [書き込みモデル] as wm
613
+ [コマンドストア] as cs
614
+ }
615
+
616
+ package "クエリ側" {
617
+ [クエリハンドラー] as qh
618
+ [読み取りモデル] as rm
619
+ [クエリストア] as qs
620
+ }
621
+
622
+ package "イベント" {
623
+ [イベントバス] as eb
624
+ }
625
+
626
+ [コマンド] --> ch
627
+ ch --> wm
628
+ wm --> cs
629
+ wm --> eb
630
+ eb --> rm
631
+ rm --> qs
632
+ [クエリ] --> qh
633
+ qh --> rm
634
+ @enduml
635
+ ```
636
+
637
+ #### 実装指針
638
+
639
+ ```java
640
+ // コマンド側
641
+ @CommandHandler
642
+ public class CreateReservationHandler {
643
+ private final ReservationWriteRepository writeRepository;
644
+ private final EventBus eventBus;
645
+
646
+ public void handle(CreateReservationCommand command) {
647
+ var reservation = new ReservationAggregate(command);
648
+ writeRepository.save(reservation);
649
+
650
+ var events = reservation.getUncommittedEvents();
651
+ eventBus.publishAll(events);
652
+ }
653
+ }
654
+
655
+ // クエリ側
656
+ @QueryHandler
657
+ public class ReservationQueryHandler {
658
+ private final ReservationReadRepository readRepository;
659
+
660
+ public List<ReservationView> handle(FindReservationsByUserQuery query) {
661
+ return readRepository.findByUserId(query.getUserId());
662
+ }
663
+ }
664
+
665
+ // イベントハンドラー(プロジェクション更新)
666
+ @EventHandler
667
+ public class ReservationProjectionHandler {
668
+ private final ReservationReadRepository readRepository;
669
+
670
+ public void on(ReservationCreatedEvent event) {
671
+ var view = new ReservationView(event);
672
+ readRepository.save(view);
673
+ }
674
+ }
675
+ ```
676
+
677
+ ## テスト戦略とアーキテクチャの関係
678
+
679
+ ### ピラミッド形テスト(ドメインモデル・イベント履歴式)
680
+
681
+ ```plantuml
682
+ @startuml
683
+ rectangle "E2Eテスト\n(少数)" as e2e #lightcoral
684
+ rectangle "統合テスト\n(中程度)" as integration #orange
685
+ rectangle "ユニットテスト\n(多数)" as unit #lightgreen
686
+
687
+ unit -up-> integration
688
+ integration -up-> e2e
689
+ @enduml
690
+ ```
691
+
692
+ **特徴**:
693
+
694
+ - ユニットテスト中心(80%)
695
+ - ドメインロジックの徹底検証
696
+ - 高品質なビジネスルール実装
697
+
698
+ ### ダイヤモンド形テスト(アクティブレコード)
699
+
700
+ ```plantuml
701
+ @startuml
702
+ rectangle "E2Eテスト\n(中程度)" as e2e #orange
703
+ rectangle "統合テスト\n(多数)" as integration #lightgreen
704
+ rectangle "ユニットテスト\n(中程度)" as unit #orange
705
+
706
+ unit -up-> integration
707
+ integration -up-> e2e
708
+ @enduml
709
+ ```
710
+
711
+ **特徴**:
712
+
713
+ - 統合テスト中心(60%)
714
+ - データアクセスロジックの重点検証
715
+ - ORMとの連携確認
716
+
717
+ ### 逆ピラミッド形テスト(トランザクションスクリプト)
718
+
719
+ ```plantuml
720
+ @startuml
721
+ rectangle "E2Eテスト\n(多数)" as e2e #lightgreen
722
+ rectangle "統合テスト\n(中程度)" as integration #orange
723
+ rectangle "ユニットテスト\n(少数)" as unit #lightcoral
724
+
725
+ unit -up-> integration
726
+ integration -up-> e2e
727
+ @enduml
728
+ ```
729
+
730
+ **特徴**:
731
+
732
+ - E2Eテスト中心(70%)
733
+ - エンドツーエンドの動作確認
734
+ - シナリオベースの検証
735
+
736
+ ## アーキテクチャ評価基準
737
+
738
+ ### 品質属性評価マトリックス
739
+
740
+ | 品質属性 | トランザクション<br>スクリプト | アクティブ<br>レコード | ドメイン<br>モデル | イベント履歴式<br>ドメインモデル |
741
+ |----------|:---:|:---:|:---:|:---:|
742
+ | **開発速度** | ⭐⭐⭐⭐⭐ | ⭐⭐⭐⭐ | ⭐⭐ | ⭐ |
743
+ | **保守性** | ⭐⭐ | ⭐⭐⭐ | ⭐⭐⭐⭐⭐ | ⭐⭐⭐⭐ |
744
+ | **テスト容易性** | ⭐⭐ | ⭐⭐ | ⭐⭐⭐⭐⭐ | ⭐⭐⭐⭐ |
745
+ | **スケーラビリティ** | ⭐⭐ | ⭐⭐⭐ | ⭐⭐⭐⭐ | ⭐⭐⭐⭐⭐ |
746
+ | **複雑さ対応** | ⭐ | ⭐⭐ | ⭐⭐⭐⭐⭐ | ⭐⭐⭐⭐⭐ |
747
+ | **監査要件** | ⭐ | ⭐⭐ | ⭐⭐⭐ | ⭐⭐⭐⭐⭐ |
748
+
749
+ ### アーキテクチャスタイル評価マトリックス
750
+
751
+ | 品質属性 | レイヤード<br>3層 | レイヤード<br>4層 | ポートと<br>アダプター | CQRS |
752
+ |----------|:---:|:---:|:---:|:---:|
753
+ | **学習容易性** | ⭐⭐⭐⭐⭐ | ⭐⭐⭐⭐ | ⭐⭐⭐ | ⭐⭐ |
754
+ | **テスト容易性** | ⭐⭐⭐ | ⭐⭐⭐⭐ | ⭐⭐⭐⭐⭐ | ⭐⭐⭐⭐ |
755
+ | **関心事分離** | ⭐⭐⭐ | ⭐⭐⭐⭐ | ⭐⭐⭐⭐⭐ | ⭐⭐⭐⭐⭐ |
756
+ | **パフォーマンス** | ⭐⭐⭐ | ⭐⭐⭐ | ⭐⭐⭐ | ⭐⭐⭐⭐⭐ |
757
+ | **スケーラビリティ** | ⭐⭐ | ⭐⭐⭐ | ⭐⭐⭐⭐ | ⭐⭐⭐⭐⭐ |
758
+ | **進化性** | ⭐⭐ | ⭐⭐⭐ | ⭐⭐⭐⭐⭐ | ⭐⭐⭐⭐ |
759
+
760
+ ## 実装ベストプラクティス
761
+
762
+ ### 1. 依存関係管理
763
+
764
+ ```java
765
+ // ✅ 良い例:インターフェースに依存
766
+ public class ReservationService {
767
+ private final ReservationRepository repository; // インターフェース
768
+ private final NotificationService notificationService; // インターフェース
769
+ }
770
+
771
+ // ❌ 悪い例:具象クラスに依存
772
+ public class ReservationService {
773
+ private final JpaReservationRepository repository; // 具象クラス
774
+ private final EmailService emailService; // 具象クラス
775
+ }
776
+ ```
777
+
778
+ ### 2. レイヤー分離
779
+
780
+ ```java
781
+ // ✅ 良い例:適切なレイヤー分離
782
+ @RestController
783
+ public class ReservationController {
784
+ @PostMapping("/reservations")
785
+ public ResponseEntity<ReservationResponse> create(@RequestBody CreateReservationRequest request) {
786
+ // プレゼンテーション層の責務のみ
787
+ var command = toCommand(request);
788
+ var result = useCase.execute(command);
789
+ return ResponseEntity.ok(toResponse(result));
790
+ }
791
+ }
792
+
793
+ // ❌ 悪い例:レイヤー違反
794
+ @RestController
795
+ public class ReservationController {
796
+ @PostMapping("/reservations")
797
+ public ResponseEntity<ReservationResponse> create(@RequestBody CreateReservationRequest request) {
798
+ // ビジネスロジックをコントローラーに記述(レイヤー違反)
799
+ if (request.getStartTime().isBefore(LocalDateTime.now().plusHours(2))) {
800
+ throw new ValidationException("2時間前までの予約が必要です");
801
+ }
802
+ // ...
803
+ }
804
+ }
805
+ ```
806
+
807
+ ### 3. エラーハンドリング
808
+
809
+ ```java
810
+ // ✅ 良い例:適切なエラー伝播
811
+ public class ReservationService {
812
+ public ReservationId createReservation(CreateReservationCommand command) {
813
+ try {
814
+ var reservation = Reservation.create(command);
815
+ repository.save(reservation);
816
+ return reservation.getId();
817
+ } catch (DomainException e) {
818
+ // ドメイン例外は適切にハンドリング
819
+ throw new ReservationException("予約作成に失敗しました", e);
820
+ }
821
+ }
822
+ }
823
+
824
+ // ❌ 悪い例:例外の隠蔽
825
+ public class ReservationService {
826
+ public ReservationId createReservation(CreateReservationCommand command) {
827
+ try {
828
+ var reservation = Reservation.create(command);
829
+ repository.save(reservation);
830
+ return reservation.getId();
831
+ } catch (Exception e) {
832
+ // すべての例外を隠蔽(問題の特定が困難)
833
+ return null;
834
+ }
835
+ }
836
+ }
837
+ ```
838
+
839
+ # フロントエンドアーキテクチャ
840
+
841
+ ## フロントエンドアーキテクチャ決定フロー
842
+
843
+ ### 主要アーキテクチャ決定ポイント
844
+
845
+ ```plantuml
846
+ @startuml
847
+ start
848
+
849
+ :プロジェクト分析;
850
+
851
+ if (プロジェクト規模) then (大規模)
852
+ :11フォルダ標準構造;
853
+ note right
854
+ components/config/features/layouts/
855
+ lib/pages/providers/stores/
856
+ testing/types/utils/
857
+ end note
858
+ else (中小規模)
859
+ :6フォルダシンプル構造;
860
+ note right
861
+ components/pages/hooks/
862
+ utils/types/config/
863
+ end note
864
+ endif
865
+
866
+ if (レンダリング戦略) then (SEO重要)
867
+ if (更新頻度) then (高頻度)
868
+ :サーバーサイドレンダリング;
869
+ note right: Next.js
870
+ else (低頻度)
871
+ :静的生成;
872
+ note right: Gatsby/Next.js SSG
873
+ endif
874
+ else (内部ツール・ダッシュボード)
875
+ :SPA;
876
+ note right: React SPA
877
+ endif
878
+
879
+ if (状態管理複雑性) then (複雑)
880
+ if (更新頻度) then (高頻度)
881
+ :Atom系(Recoil/Jotai);
882
+ note right: stores/フォルダに集約
883
+ else (共有多い)
884
+ :Redux with RTK;
885
+ note right: stores/フォルダに集約
886
+ endif
887
+ else (シンプル)
888
+ :Context API + hooks / Zustand;
889
+ note right: providers/フォルダに集約
890
+ endif
891
+
892
+ if (パフォーマンス重要度) then (高)
893
+ :CSS/SCSS/Tailwind;
894
+ note right: 頻繁レンダリング対応
895
+ else (開発速度重視)
896
+ :CSS-in-JS (Styled Components);
897
+ note right: components/内で管理
898
+ endif
899
+
900
+ stop
901
+ @enduml
902
+ ```
903
+
904
+ ## フロントエンド設計原則
905
+
906
+ ### 良いアーキテクチャ決定
907
+
908
+ #### 1. **プロジェクト構造**
909
+
910
+ ##### 標準的なフロントエンドプロジェクト構造
911
+ ```
912
+ src/
913
+ ├── components/ # (1) 共通UIコンポーネント
914
+ │ ├── ui/ # 基本UIパーツ(Button, Input, Modal等)
915
+ │ └── layout/ # レイアウトコンポーネント
916
+ ├── config/ # (2) アプリケーション設定
917
+ │ ├── constants.ts # 定数定義
918
+ │ ├── env.ts # 環境変数管理
919
+ │ └── api.ts # API設定
920
+ ├── features/ # (3) フィーチャー単位のコンポーネント
921
+ │ ├── auth/ # 認証機能
922
+ │ ├── reservation/ # 予約機能
923
+ │ └── meeting-room/# 会議室管理機能
924
+ ├── layouts/ # (4) アプリケーションレイアウト
925
+ │ ├── AppLayout.tsx
926
+ │ ├── AuthLayout.tsx
927
+ │ └── DashboardLayout.tsx
928
+ ├── lib/ # (5) 外部ライブラリ設定・ユーティリティ
929
+ │ ├── auth.ts # 認証ライブラリ設定
930
+ │ ├── api-client.ts# API クライアント
931
+ │ └── utils.ts # ヘルパー関数
932
+ ├── pages/ # (6) ページコンポーネント(ルーティング)
933
+ │ ├── LoginPage.tsx
934
+ │ ├── DashboardPage.tsx
935
+ │ └── ReservationPage.tsx
936
+ ├── providers/ # (7) Context Provider
937
+ │ ├── AuthProvider.tsx
938
+ │ ├── ThemeProvider.tsx
939
+ │ └── AppProviders.tsx
940
+ ├── stores/ # (8) 状態管理
941
+ │ ├── authStore.ts
942
+ │ ├── uiStore.ts
943
+ │ └── index.ts
944
+ ├── testing/ # (9) テスト用ユーティリティ
945
+ │ ├── setup.ts # テスト環境設定
946
+ │ ├── mocks/ # モックデータ
947
+ │ └── utils.ts # テストヘルパー
948
+ ├── types/ # (10) TypeScript型定義
949
+ │ ├── api.ts # API型定義
950
+ │ ├── auth.ts # 認証関連型
951
+ │ └── common.ts # 共通型定義
952
+ └── utils/ # (11) 汎用ユーティリティ関数
953
+ ├── format.ts # フォーマット関数
954
+ ├── validation.ts# バリデーション
955
+ └── date.ts # 日付操作
956
+ ```
957
+
958
+ ##### プロジェクト規模による使い分け
959
+
960
+ **小規模プロジェクト (シンプル構造)**:
961
+ ```
962
+ src/
963
+ ├── components/ # UI コンポーネント
964
+ ├── pages/ # ページコンポーネント
965
+ ├── hooks/ # カスタムフック
966
+ ├── utils/ # ユーティリティ
967
+ ├── types/ # 型定義
968
+ └── config/ # 設定
969
+ ```
970
+
971
+ **大規模プロジェクト (フル構造)**:
972
+ 上記の標準11フォルダ構成を使用
973
+
974
+ #### 2. **コンポーネント設計**
975
+ - **小さなコンポーネント**: 単一責任の原則に従った分割
976
+ - **関心事の分離**: UI・ロジック・状態管理の明確な分離
977
+ - **再利用性**: 汎用コンポーネントの適切な抽象化
978
+
979
+ #### 3. **状態管理戦略**
980
+
981
+ ```plantuml
982
+ @startuml
983
+ package "状態管理レイヤー" {
984
+ rectangle "サーバー状態" as server #lightblue
985
+ rectangle "クライアント状態" as client #lightgreen
986
+ rectangle "UI状態" as ui #lightyellow
987
+ }
988
+
989
+ package "管理ツール" {
990
+ rectangle "React Query / SWR" as rq
991
+ rectangle "Redux / Zustand" as global
992
+ rectangle "useState / useReducer" as local
993
+ }
994
+
995
+ server --> rq : キャッシュ・同期
996
+ client --> global : グローバル共有
997
+ ui --> local : ローカル管理
998
+ @enduml
999
+ ```
1000
+
1001
+ #### 4. **レンダリング戦略**
1002
+
1003
+ | 戦略 | 適用場面 | 特徴 | 例 |
1004
+ |------|----------|------|-----|
1005
+ | **SPA** | ダッシュボード・管理画面 | 高いインタラクティビティ | React |
1006
+ | **SSR** | SEO重要・高更新頻度 | 初期表示高速・SEO対応 | Next.js |
1007
+ | **SSG** | SEO重要・低更新頻度 | 最高のパフォーマンス | Gatsby |
1008
+
1009
+ ### 悪いアーキテクチャ決定
1010
+
1011
+ #### ❌ **避けるべき設計**
1012
+
1013
+ 1. **フラットなプロジェクト構造**
1014
+ ```
1015
+ src/
1016
+ ├── LoginPage.tsx # 管理困難
1017
+ ├── Button.tsx # コンポーネント分類なし
1018
+ ├── UserService.ts # ロジック散在
1019
+ ├── constants.ts # 設定管理なし
1020
+ ├── utils.ts # 目的不明
1021
+ ├── types.ts # 型定義混在
1022
+ └── ... # 数十個のファイル(役割不明)
1023
+ ```
1024
+
1025
+ 2. **不適切な責務分散**
1026
+ ```
1027
+ src/
1028
+ ├── components/ # 全コンポーネント混在
1029
+ │ ├── LoginPage.tsx # ページなのにcomponents内
1030
+ │ ├── Button.tsx # UIコンポーネント
1031
+ │ ├── AuthProvider.tsx # Providerなのにcomponents内
1032
+ │ └── authStore.ts # ストアなのにcomponents内
1033
+ └── utils/ # 何でも入れる場所
1034
+ ├── api.ts # API設定
1035
+ ├── constants.ts # 定数
1036
+ ├── types.ts # 型定義
1037
+ └── validation.ts # バリデーション
1038
+ ```
1039
+
1040
+ 2. **巨大で密結合なコンポーネント**
1041
+ ```tsx
1042
+ // ❌ 悪い例
1043
+ function MegaComponent() {
1044
+ // 500行以上のコンポーネント
1045
+ // 複数の責務を持つ
1046
+ // テストが困難
1047
+ }
1048
+ ```
1049
+
1050
+ 3. **不適切な状態管理**
1051
+ ```tsx
1052
+ // ❌ 悪い例:すべてをグローバル状態に
1053
+ const globalState = {
1054
+ user: {},
1055
+ reservations: [],
1056
+ modalOpen: false, // UI状態もグローバル化
1057
+ buttonColor: 'blue' // 一時的な状態もグローバル化
1058
+ }
1059
+ ```
1060
+
1061
+ 4. **セキュリティの軽視**
1062
+ ```tsx
1063
+ // ❌ 悪い例:入力値のサニタイジング不備
1064
+ function UserInput({ input }) {
1065
+ return <div dangerouslySetInnerHTML={{__html: input}} />
1066
+ }
1067
+ ```
1068
+
1069
+ ## フロントエンド実装パターン
1070
+
1071
+ ### 1. **コンポーネント設計パターン**
1072
+
1073
+ #### Container/Presentational パターン
1074
+
1075
+ ```
1076
+ // ファイル配置例
1077
+ src/
1078
+ ├── features/reservation/
1079
+ │ ├── components/
1080
+ │ │ ├── ReservationContainer.tsx # Container
1081
+ │ │ └── ReservationList.tsx # Presentational
1082
+ │ ├── hooks/
1083
+ │ │ └── useReservations.ts # Custom Hook
1084
+ │ └── types/
1085
+ │ └── reservation.ts # 型定義
1086
+ ```
1087
+
1088
+ ```tsx
1089
+ // ✅ Container: ロジック担当 (features/reservation/components/ReservationContainer.tsx)
1090
+ import { useReservations } from '../hooks/useReservations';
1091
+ import { ReservationList } from './ReservationList';
1092
+
1093
+ export function ReservationContainer() {
1094
+ const { reservations, loading, createReservation } = useReservations();
1095
+ const handleCreate = useCallback((data) => {
1096
+ createReservation(data);
1097
+ }, [createReservation]);
1098
+
1099
+ return (
1100
+ <ReservationList
1101
+ reservations={reservations}
1102
+ loading={loading}
1103
+ onCreate={handleCreate}
1104
+ />
1105
+ );
1106
+ }
1107
+
1108
+ // ✅ Presentational: UI担当 (features/reservation/components/ReservationList.tsx)
1109
+ import { LoadingSpinner } from '@/components/ui/LoadingSpinner';
1110
+ import { CreateButton } from '@/components/ui/CreateButton';
1111
+ import type { Reservation } from '../types/reservation';
1112
+
1113
+ interface Props {
1114
+ reservations: Reservation[];
1115
+ loading: boolean;
1116
+ onCreate: (data: CreateReservationData) => void;
1117
+ }
1118
+
1119
+ export function ReservationList({ reservations, loading, onCreate }: Props) {
1120
+ if (loading) return <LoadingSpinner />;
1121
+
1122
+ return (
1123
+ <div>
1124
+ {reservations.map(reservation =>
1125
+ <ReservationItem key={reservation.id} data={reservation} />
1126
+ )}
1127
+ <CreateButton onClick={onCreate} />
1128
+ </div>
1129
+ );
1130
+ }
1131
+ ```
1132
+
1133
+ #### Custom Hooks パターン
1134
+ ```tsx
1135
+ // ✅ ビジネスロジックの分離
1136
+ function useReservation() {
1137
+ const [reservations, setReservations] = useState([]);
1138
+ const [loading, setLoading] = useState(false);
1139
+
1140
+ const createReservation = useCallback(async (data) => {
1141
+ setLoading(true);
1142
+ try {
1143
+ const result = await api.createReservation(data);
1144
+ setReservations(prev => [...prev, result]);
1145
+ } catch (error) {
1146
+ handleError(error);
1147
+ } finally {
1148
+ setLoading(false);
1149
+ }
1150
+ }, []);
1151
+
1152
+ return { reservations, loading, createReservation };
1153
+ }
1154
+ ```
1155
+
1156
+ ### 2. **状態管理パターン**
1157
+
1158
+ #### Context + Reducer パターン
1159
+ ```tsx
1160
+ // ✅ 状態とアクションの型安全な管理
1161
+ interface AppState {
1162
+ user: User | null;
1163
+ theme: 'light' | 'dark';
1164
+ }
1165
+
1166
+ type AppAction =
1167
+ | { type: 'SET_USER'; payload: User }
1168
+ | { type: 'SET_THEME'; payload: 'light' | 'dark' };
1169
+
1170
+ function appReducer(state: AppState, action: AppAction): AppState {
1171
+ switch (action.type) {
1172
+ case 'SET_USER':
1173
+ return { ...state, user: action.payload };
1174
+ case 'SET_THEME':
1175
+ return { ...state, theme: action.payload };
1176
+ default:
1177
+ return state;
1178
+ }
1179
+ }
1180
+
1181
+ const AppContext = createContext<{
1182
+ state: AppState;
1183
+ dispatch: Dispatch<AppAction>;
1184
+ } | null>(null);
1185
+ ```
1186
+
1187
+ ### 3. **パフォーマンス最適化パターン**
1188
+
1189
+ #### 遅延読み込み
1190
+ ```tsx
1191
+ // ✅ コード分割
1192
+ const ReservationPage = lazy(() => import('./pages/ReservationPage'));
1193
+ const UserManagementPage = lazy(() => import('./pages/UserManagementPage'));
1194
+
1195
+ function App() {
1196
+ return (
1197
+ <Router>
1198
+ <Suspense fallback={<LoadingSpinner />}>
1199
+ <Routes>
1200
+ <Route path="/reservations" element={<ReservationPage />} />
1201
+ <Route path="/users" element={<UserManagementPage />} />
1202
+ </Routes>
1203
+ </Suspense>
1204
+ </Router>
1205
+ );
1206
+ }
1207
+ ```
1208
+
1209
+ #### メモ化
1210
+ ```tsx
1211
+ // ✅ 適切なメモ化
1212
+ const ExpensiveList = memo(function ExpensiveList({ items, filter }) {
1213
+ const filteredItems = useMemo(
1214
+ () => items.filter(item => item.type === filter),
1215
+ [items, filter]
1216
+ );
1217
+
1218
+ return (
1219
+ <ul>
1220
+ {filteredItems.map(item =>
1221
+ <ExpensiveListItem key={item.id} item={item} />
1222
+ )}
1223
+ </ul>
1224
+ );
1225
+ });
1226
+ ```
1227
+
1228
+ ## フロントエンド品質保証
1229
+
1230
+ ### 1. **TypeScript活用**
1231
+
1232
+ ```tsx
1233
+ // ✅ 型安全なAPI呼び出し
1234
+ interface CreateReservationRequest {
1235
+ roomId: string;
1236
+ startTime: string;
1237
+ endTime: string;
1238
+ purpose: string;
1239
+ }
1240
+
1241
+ interface ReservationResponse {
1242
+ id: string;
1243
+ status: 'confirmed' | 'pending' | 'cancelled';
1244
+ createdAt: string;
1245
+ }
1246
+
1247
+ async function createReservation(
1248
+ request: CreateReservationRequest
1249
+ ): Promise<ReservationResponse> {
1250
+ const response = await fetch('/api/reservations', {
1251
+ method: 'POST',
1252
+ headers: { 'Content-Type': 'application/json' },
1253
+ body: JSON.stringify(request)
1254
+ });
1255
+
1256
+ if (!response.ok) {
1257
+ throw new Error('予約作成に失敗しました');
1258
+ }
1259
+
1260
+ return response.json();
1261
+ }
1262
+ ```
1263
+
1264
+ ### 2. **テスト戦略**
1265
+
1266
+ #### ユニットテスト
1267
+ ```tsx
1268
+ // ✅ Custom Hooksのテスト
1269
+ import { renderHook, act } from '@testing-library/react';
1270
+ import { useReservation } from './useReservation';
1271
+
1272
+ test('should create reservation successfully', async () => {
1273
+ const { result } = renderHook(() => useReservation());
1274
+
1275
+ await act(async () => {
1276
+ await result.current.createReservation({
1277
+ roomId: '1',
1278
+ startTime: '2024-01-01T10:00:00Z',
1279
+ endTime: '2024-01-01T11:00:00Z',
1280
+ purpose: 'ミーティング'
1281
+ });
1282
+ });
1283
+
1284
+ expect(result.current.reservations).toHaveLength(1);
1285
+ });
1286
+ ```
1287
+
1288
+ #### 統合テスト
1289
+ ```tsx
1290
+ // ✅ コンポーネント統合テスト
1291
+ import { render, screen, fireEvent, waitFor } from '@testing-library/react';
1292
+ import { ReservationForm } from './ReservationForm';
1293
+
1294
+ test('should submit reservation form', async () => {
1295
+ const mockOnSubmit = jest.fn();
1296
+
1297
+ render(<ReservationForm onSubmit={mockOnSubmit} />);
1298
+
1299
+ fireEvent.change(screen.getByLabelText('会議室'), {
1300
+ target: { value: '会議室A' }
1301
+ });
1302
+ fireEvent.click(screen.getByText('予約する'));
1303
+
1304
+ await waitFor(() => {
1305
+ expect(mockOnSubmit).toHaveBeenCalledWith(
1306
+ expect.objectContaining({
1307
+ roomName: '会議室A'
1308
+ })
1309
+ );
1310
+ });
1311
+ });
1312
+ ```
1313
+
1314
+ ## フロントエンド移行戦略
1315
+
1316
+ ### 段階的移行アプローチ
1317
+
1318
+ ```plantuml
1319
+ @startuml
1320
+ start
1321
+
1322
+ :現行フロントエンド分析;
1323
+
1324
+ if (移行戦略) then (段階的)
1325
+ :新機能を新アーキテクチャで実装;
1326
+ :既存機能の段階的リファクタリング;
1327
+ else (リライト)
1328
+ :新システムを並行開発;
1329
+ :フィーチャーフラグによる切り替え;
1330
+ endif
1331
+
1332
+ :共通ライブラリの整備;
1333
+ :コンポーネントライブラリの移行;
1334
+ :状態管理の統合;
1335
+
1336
+ :E2Eテストによる動作確認;
1337
+ :パフォーマンステスト;
1338
+
1339
+ :本番環境移行;
1340
+ :監視・メトリクス設定;
1341
+
1342
+ stop
1343
+ @enduml
1344
+ ```
1345
+
1346
+ ## アーキテクチャ移行戦略
1347
+
1348
+ ### 段階的移行アプローチ
1349
+
1350
+ ```plantuml
1351
+ @startuml
1352
+ start
1353
+
1354
+ :現状アーキテクチャ分析;
1355
+ :移行計画策定;
1356
+
1357
+ fork
1358
+ :既存機能の段階的抽出;
1359
+ fork again
1360
+ :新機能の新アーキテクチャ実装;
1361
+ end fork
1362
+
1363
+ :境界コンテキスト定義;
1364
+ :データ移行計画;
1365
+ :テスト戦略見直し;
1366
+
1367
+ fork
1368
+ :モジュール単位での移行;
1369
+ fork again
1370
+ :継続的統合の維持;
1371
+ end fork
1372
+
1373
+ :移行完了確認;
1374
+ :旧システム廃棄;
1375
+
1376
+ stop
1377
+ @enduml
1378
+ ```
1379
+
1380
+ ### 移行時の注意点
1381
+
1382
+ #### バックエンド移行
1383
+ 1. **段階的移行**: ビッグバン移行は避け、モジュール単位で実施
1384
+ 2. **後方互換性**: 既存のAPIやインターフェースの維持
1385
+ 3. **データ整合性**: 移行期間中のデータ同期戦略
1386
+ 4. **テストカバレッジ**: 移行前後でのテスト品質維持
1387
+ 5. **パフォーマンス監視**: 移行による性能劣化の早期検知
1388
+
1389
+ #### フロントエンド移行
1390
+ 1. **フィーチャーフラグ**: 新旧機能の段階的切り替え
1391
+ 2. **コンポーネント移行**: デザインシステムの統一
1392
+ 3. **状態管理移行**: データフローの一貫性維持
1393
+ 4. **バンドルサイズ監視**: パフォーマンス劣化防止
1394
+ 5. **ブラウザ互換性**: サポート対象ブラウザでの動作確認
1395
+
1396
+ # インフラストラクチャアーキテクチャ
1397
+
1398
+ ## インフラストラクチャ設計の原則
1399
+
1400
+ ### 基本方針
1401
+
1402
+ - **Infrastructure as Code (IaC)**: インフラの設定をコード化し、バージョン管理
1403
+ - **自動化**: デプロイ・スケーリング・復旧の自動化
1404
+ - **モニタリングとオブザーバビリティ**: システム状態の可視化と追跡
1405
+ - **セキュリティファースト**: 設計段階からのセキュリティ考慮
1406
+ - **コスト最適化**: リソース利用の効率化とコスト管理
1407
+
1408
+ ## デプロイメントアーキテクチャパターン
1409
+
1410
+ ### 1. モノリシックデプロイメント
1411
+
1412
+ #### 適用場面
1413
+ - **システム規模**: 小規模〜中規模
1414
+ - **チーム規模**: 小規模チーム
1415
+ - **特性**: 単一アプリケーション、シンプルなデプロイ
1416
+
1417
+ #### 構造
1418
+ ```plantuml
1419
+ @startuml
1420
+ node "Webサーバー" {
1421
+ [アプリケーション]
1422
+ }
1423
+
1424
+ database "データベース" as DB
1425
+
1426
+ cloud "ロードバランサー" as LB
1427
+
1428
+ LB --> [アプリケーション]
1429
+ [アプリケーション] --> DB
1430
+ @enduml
1431
+ ```
1432
+
1433
+ **メリット**:
1434
+
1435
+ - シンプルな構成
1436
+ - 低い運用コスト
1437
+ - デプロイが容易
1438
+
1439
+ **デメリット**:
1440
+
1441
+ - スケーリングの柔軟性が低い
1442
+ - 単一障害点
1443
+ - 大規模化時の制約
1444
+
1445
+ ### 2. マイクロサービスデプロイメント
1446
+
1447
+ #### 適用場面
1448
+ - **システム規模**: 大規模
1449
+ - **チーム規模**: 複数チーム
1450
+ - **特性**: 独立したサービス、高いスケーラビリティ
1451
+
1452
+ #### 構造
1453
+ ```plantuml
1454
+ @startuml
1455
+ cloud "APIゲートウェイ" as gateway
1456
+
1457
+ node "認証サービス" {
1458
+ [Auth Service]
1459
+ }
1460
+
1461
+ node "予約サービス" {
1462
+ [Reservation Service]
1463
+ }
1464
+
1465
+ node "会議室サービス" {
1466
+ [Room Service]
1467
+ }
1468
+
1469
+ database "Auth DB" as authdb
1470
+ database "Reservation DB" as resdb
1471
+ database "Room DB" as roomdb
1472
+
1473
+ gateway --> [Auth Service]
1474
+ gateway --> [Reservation Service]
1475
+ gateway --> [Room Service]
1476
+ [Auth Service] --> authdb
1477
+ [Reservation Service] --> resdb
1478
+ [Room Service] --> roomdb
1479
+ @enduml
1480
+ ```
1481
+
1482
+ **メリット**:
1483
+
1484
+ - 独立したデプロイとスケーリング
1485
+ - 技術スタックの柔軟性
1486
+ - 障害の局所化
1487
+
1488
+ **デメリット**:
1489
+
1490
+ - 複雑な運用
1491
+ - 分散システムの課題
1492
+ - デバッグの困難さ
1493
+
1494
+ ### 3. コンテナオーケストレーション
1495
+
1496
+ #### 適用場面
1497
+ - **デプロイ頻度**: 高頻度
1498
+ - **スケーリング要件**: 動的スケーリング
1499
+ - **特性**: Kubernetes、Docker等のコンテナ技術
1500
+
1501
+ #### 構造
1502
+ ```plantuml
1503
+ @startuml
1504
+ package "Kubernetesクラスター" {
1505
+ node "マスターノード" {
1506
+ [API Server]
1507
+ [Scheduler]
1508
+ [Controller]
1509
+ }
1510
+
1511
+ node "ワーカーノード1" {
1512
+ [Pod 1]
1513
+ [Pod 2]
1514
+ }
1515
+
1516
+ node "ワーカーノード2" {
1517
+ [Pod 3]
1518
+ [Pod 4]
1519
+ }
1520
+
1521
+ [API Server] --> [Pod 1]
1522
+ [API Server] --> [Pod 2]
1523
+ [API Server] --> [Pod 3]
1524
+ [API Server] --> [Pod 4]
1525
+ }
1526
+ @enduml
1527
+ ```
1528
+
1529
+ **メリット**:
1530
+
1531
+ - 自動スケーリング
1532
+ - 高可用性
1533
+ - リソース効率化
1534
+
1535
+ **デメリット**:
1536
+
1537
+ - 高い学習コスト
1538
+ - 複雑な設定
1539
+ - 運用の複雑さ
1540
+
1541
+ ### 4. サーバーレスアーキテクチャ
1542
+
1543
+ #### 適用場面
1544
+ - **負荷パターン**: 変動が大きい
1545
+ - **実行頻度**: イベント駆動、バースト型
1546
+ - **特性**: AWS Lambda、Azure Functions等
1547
+
1548
+ #### 構造
1549
+ ```plantuml
1550
+ @startuml
1551
+ cloud "APIゲートウェイ" as api
1552
+ rectangle "Lambda関数" as lambda1
1553
+ rectangle "Lambda関数" as lambda2
1554
+ rectangle "Lambda関数" as lambda3
1555
+ database "DynamoDB" as db
1556
+ queue "SQS" as queue
1557
+
1558
+ api --> lambda1 : HTTP
1559
+ queue --> lambda2 : イベント
1560
+ lambda1 --> db
1561
+ lambda2 --> db
1562
+ lambda3 --> db
1563
+ @enduml
1564
+ ```
1565
+
1566
+ **メリット**:
1567
+
1568
+ - 完全なサーバー管理不要
1569
+ - 自動スケーリング
1570
+ - 従量課金
1571
+
1572
+ **デメリット**:
1573
+
1574
+ - コールドスタート
1575
+ - ベンダーロックイン
1576
+ - ローカルテストの困難さ
1577
+
1578
+ ## ネットワークアーキテクチャ
1579
+
1580
+ ### ネットワーク構成パターン
1581
+
1582
+ ```plantuml
1583
+ @startuml
1584
+ package "DMZ(非武装地帯)" {
1585
+ [ロードバランサー]
1586
+ [リバースプロキシ]
1587
+ }
1588
+
1589
+ package "プライベートネットワーク" {
1590
+ package "アプリケーション層" {
1591
+ [Webサーバー]
1592
+ [APサーバー]
1593
+ }
1594
+
1595
+ package "データ層" {
1596
+ database "DB(Primary)"
1597
+ database "DB(Replica)"
1598
+ }
1599
+ }
1600
+
1601
+ cloud "インターネット" as internet
1602
+
1603
+ internet --> [ロードバランサー]
1604
+ [ロードバランサー] --> [リバースプロキシ]
1605
+ [リバースプロキシ] --> [Webサーバー]
1606
+ [Webサーバー] --> [APサーバー]
1607
+ [APサーバー] --> "DB(Primary)"
1608
+ "DB(Primary)" --> "DB(Replica)" : レプリケーション
1609
+ @enduml
1610
+ ```
1611
+
1612
+ ### ネットワーク設計の要点
1613
+
1614
+ | 要素 | 考慮事項 |
1615
+ |------|----------|
1616
+ | **負荷分散** | ロードバランサーによる複数サーバーへの分散 |
1617
+ | **セキュリティ** | ファイアウォール、WAF、DDoS対策 |
1618
+ | **可用性** | 冗長化、フェイルオーバー |
1619
+ | **パフォーマンス** | CDN、キャッシング、帯域幅 |
1620
+
1621
+ ## スケーリング戦略
1622
+
1623
+ ### 垂直スケーリング vs 水平スケーリング
1624
+
1625
+ ```plantuml
1626
+ @startuml
1627
+ left to right direction
1628
+
1629
+ package "垂直スケーリング" {
1630
+ node "サーバー" as v1 {
1631
+ [CPU: 2コア\nメモリ: 4GB]
1632
+ }
1633
+
1634
+ node "サーバー" as v2 {
1635
+ [CPU: 8コア\nメモリ: 32GB]
1636
+ }
1637
+
1638
+ v1 -right-> v2 : スペックアップ
1639
+ }
1640
+
1641
+ package "水平スケーリング" {
1642
+ node "サーバー1" as h1 {
1643
+ [CPU: 2コア\nメモリ: 4GB]
1644
+ }
1645
+
1646
+ node "サーバー2" as h2 {
1647
+ [CPU: 2コア\nメモリ: 4GB]
1648
+ }
1649
+
1650
+ node "サーバー3" as h3 {
1651
+ [CPU: 2コア\nメモリ: 4GB]
1652
+ }
1653
+
1654
+ h1 -right-> h2 : サーバー追加
1655
+ h2 -right-> h3 : サーバー追加
1656
+ }
1657
+ @enduml
1658
+ ```
1659
+
1660
+ ### スケーリング戦略の選択
1661
+
1662
+ | 戦略 | メリット | デメリット | 適用場面 |
1663
+ |------|----------|------------|----------|
1664
+ | **垂直スケーリング** | シンプル、データ整合性保持 | 物理的上限、ダウンタイム | データベース、レガシーシステム |
1665
+ | **水平スケーリング** | 柔軟性、高可用性 | 複雑な設計、データ分散 | Webアプリケーション、マイクロサービス |
1666
+
1667
+ ### オートスケーリング
1668
+
1669
+ ```plantuml
1670
+ @startuml
1671
+ start
1672
+
1673
+ :負荷監視;
1674
+
1675
+ if (CPU使用率 > 80%?) then (yes)
1676
+ :インスタンス追加;
1677
+ :負荷分散設定更新;
1678
+ else if (CPU使用率 < 20%?) then (yes)
1679
+ :インスタンス削減;
1680
+ :負荷分散設定更新;
1681
+ else (no)
1682
+ :現状維持;
1683
+ endif
1684
+
1685
+ :負荷監視;
1686
+
1687
+ stop
1688
+ @enduml
1689
+ ```
1690
+
1691
+ ## 監視とログ管理
1692
+
1693
+ ### 監視アーキテクチャ
1694
+
1695
+ ```plantuml
1696
+ @startuml
1697
+ package "アプリケーション" {
1698
+ [Webサーバー]
1699
+ [APサーバー]
1700
+ [DBサーバー]
1701
+ }
1702
+
1703
+ package "監視システム" {
1704
+ [メトリクス収集] as metrics
1705
+ [ログ収集] as logs
1706
+ [アラート管理] as alerts
1707
+ }
1708
+
1709
+ package "可視化・分析" {
1710
+ [ダッシュボード]
1711
+ [ログ分析]
1712
+ [トレーシング]
1713
+ }
1714
+
1715
+ [Webサーバー] --> metrics
1716
+ [APサーバー] --> metrics
1717
+ [DBサーバー] --> metrics
1718
+
1719
+ [Webサーバー] --> logs
1720
+ [APサーバー] --> logs
1721
+ [DBサーバー] --> logs
1722
+
1723
+ metrics --> [ダッシュボード]
1724
+ logs --> [ログ分析]
1725
+ metrics --> alerts
1726
+ logs --> alerts
1727
+ @enduml
1728
+ ```
1729
+
1730
+ ### 監視対象と指標
1731
+
1732
+ | カテゴリ | 監視項目 | 重要指標 |
1733
+ |----------|----------|----------|
1734
+ | **インフラ** | CPU、メモリ、ディスク、ネットワーク | 使用率、レスポンス時間 |
1735
+ | **アプリケーション** | レスポンスタイム、エラー率、スループット | レイテンシ、成功率 |
1736
+ | **ビジネス** | アクティブユーザー数、トランザクション数 | コンバージョン率、利用状況 |
1737
+
1738
+ ### ログ管理戦略
1739
+
1740
+ #### ログレベルの定義
1741
+
1742
+ ```java
1743
+ // ✅ 適切なログレベルの使用
1744
+ public class ReservationService {
1745
+ private static final Logger logger = LoggerFactory.getLogger(ReservationService.class);
1746
+
1747
+ public void createReservation(ReservationRequest request) {
1748
+ logger.debug("予約作成開始: {}", request);
1749
+
1750
+ try {
1751
+ var reservation = processReservation(request);
1752
+ logger.info("予約作成成功: reservationId={}", reservation.getId());
1753
+ } catch (BusinessException e) {
1754
+ logger.warn("予約作成失敗(ビジネスエラー): {}", e.getMessage());
1755
+ throw e;
1756
+ } catch (Exception e) {
1757
+ logger.error("予約作成失敗(システムエラー)", e);
1758
+ throw new SystemException("予約作成処理でエラーが発生しました", e);
1759
+ }
1760
+ }
1761
+ }
1762
+ ```
1763
+
1764
+ #### ログの集約と分析
1765
+
1766
+ - **集約**: Fluentd、Logstash等でログを集約
1767
+ - **保存**: Elasticsearch、S3等で長期保存
1768
+ - **分析**: Kibana、CloudWatch Insights等で可視化・分析
1769
+
1770
+ ## セキュリティアーキテクチャ
1771
+
1772
+ ### 多層防御アーキテクチャ
1773
+
1774
+ ```plantuml
1775
+ @startuml
1776
+ left to right direction
1777
+
1778
+ rectangle "インターネット" as internet
1779
+
1780
+ package "セキュリティ層" {
1781
+ rectangle "WAF/DDoS対策" as waf
1782
+ rectangle "ファイアウォール" as fw
1783
+ rectangle "IDS/IPS" as ids
1784
+ }
1785
+
1786
+ package "認証・認可層" {
1787
+ rectangle "認証サーバー" as auth
1788
+ rectangle "API Gateway" as apigw
1789
+ }
1790
+
1791
+ package "アプリケーション層" {
1792
+ rectangle "暗号化通信" as encrypt
1793
+ rectangle "入力検証" as validation
1794
+ rectangle "アクセス制御" as access
1795
+ }
1796
+
1797
+ package "データ層" {
1798
+ database "暗号化DB" as db
1799
+ rectangle "監査ログ" as audit
1800
+ }
1801
+
1802
+ internet --> waf
1803
+ waf --> fw
1804
+ fw --> ids
1805
+ ids --> auth
1806
+ auth --> apigw
1807
+ apigw --> encrypt
1808
+ encrypt --> validation
1809
+ validation --> access
1810
+ access --> db
1811
+ db --> audit
1812
+ @enduml
1813
+ ```
1814
+
1815
+ ### セキュリティベストプラクティス
1816
+
1817
+ | 領域 | 対策 | 実装例 |
1818
+ |------|------|--------|
1819
+ | **ネットワーク** | ファイアウォール、WAF、DDoS対策 | AWS WAF, CloudFlare |
1820
+ | **認証・認可** | 多要素認証、OAuth2.0、RBAC | Auth0, Keycloak |
1821
+ | **データ保護** | 暗号化(保管時・転送時)、マスキング | TLS/SSL, AES-256 |
1822
+ | **監査** | アクセスログ、変更履歴、コンプライアンス | CloudTrail, 監査ログ |
1823
+
1824
+ ### セキュリティ実装例
1825
+
1826
+ ```java
1827
+ // ✅ セキュアな実装
1828
+ @RestController
1829
+ @RequestMapping("/api/reservations")
1830
+ public class ReservationController {
1831
+
1832
+ @PostMapping
1833
+ @PreAuthorize("hasRole('USER')") // 認可チェック
1834
+ public ResponseEntity<Reservation> create(
1835
+ @Valid @RequestBody CreateReservationRequest request) { // 入力検証
1836
+
1837
+ // SQLインジェクション対策(PreparedStatement使用)
1838
+ var reservation = reservationService.createReservation(request);
1839
+
1840
+ // 監査ログ記録
1841
+ auditService.log("RESERVATION_CREATED", reservation.getId());
1842
+
1843
+ return ResponseEntity.ok(reservation);
1844
+ }
1845
+ }
1846
+ ```
1847
+
1848
+ ## バックアップと災害復旧
1849
+
1850
+ ### バックアップ戦略
1851
+
1852
+ ```plantuml
1853
+ @startuml
1854
+ package "本番環境" {
1855
+ database "本番DB" as prod
1856
+ }
1857
+
1858
+ package "バックアップ" {
1859
+ database "日次バックアップ" as daily
1860
+ database "週次バックアップ" as weekly
1861
+ database "月次バックアップ" as monthly
1862
+ }
1863
+
1864
+ package "災害復旧サイト" {
1865
+ database "DR環境" as dr
1866
+ }
1867
+
1868
+ prod --> daily : 毎日
1869
+ prod --> weekly : 毎週
1870
+ prod --> monthly : 毎月
1871
+ prod --> dr : リアルタイムレプリケーション
1872
+ @enduml
1873
+ ```
1874
+
1875
+ ### RPO/RTO定義
1876
+
1877
+ | 指標 | 意味 | 目標値例 |
1878
+ |------|------|----------|
1879
+ | **RPO (Recovery Point Objective)** | データ損失許容時間 | 1時間以内 |
1880
+ | **RTO (Recovery Time Objective)** | サービス復旧目標時間 | 4時間以内 |
1881
+
1882
+ ### ディザスタリカバリパターン
1883
+
1884
+ #### 1. バックアップ&リストア
1885
+ - **RPO**: 数時間〜1日
1886
+ - **RTO**: 数時間〜1日
1887
+ - **コスト**: 低
1888
+ - **用途**: 非重要システム
1889
+
1890
+ #### 2. パイロットライト
1891
+ - **RPO**: 数分〜数時間
1892
+ - **RTO**: 1時間以内
1893
+ - **コスト**: 中
1894
+ - **用途**: ビジネス継続性が重要
1895
+
1896
+ #### 3. ウォームスタンバイ
1897
+ - **RPO**: 数秒〜数分
1898
+ - **RTO**: 数分
1899
+ - **コスト**: 高
1900
+ - **用途**: 高可用性要求システム
1901
+
1902
+ #### 4. マルチサイトアクティブ/アクティブ
1903
+ - **RPO**: ゼロ
1904
+ - **RTO**: ゼロ(自動フェイルオーバー)
1905
+ - **コスト**: 非常に高
1906
+ - **用途**: ミッションクリティカルシステム
1907
+
1908
+ ## Infrastructure as Code (IaC)
1909
+
1910
+ ### IaCツールの選択
1911
+
1912
+ | ツール | 特徴 | 適用場面 |
1913
+ |--------|------|----------|
1914
+ | **Terraform** | マルチクラウド対応、宣言的 | クラウド横断的なインフラ管理 |
1915
+ | **CloudFormation** | AWS特化、AWSサービスとの統合 | AWS専用環境 |
1916
+ | **Ansible** | 構成管理、手続き型 | サーバー設定管理 |
1917
+ | **Pulumi** | 汎用プログラミング言語使用 | 複雑なロジック要求時 |
1918
+
1919
+ ### IaC実装例(Terraform)
1920
+
1921
+ ```hcl
1922
+ # ✅ VPC定義
1923
+ resource "aws_vpc" "main" {
1924
+ cidr_block = "10.0.0.0/16"
1925
+ enable_dns_hostnames = true
1926
+ enable_dns_support = true
1927
+
1928
+ tags = {
1929
+ Name = "main-vpc"
1930
+ Environment = var.environment
1931
+ }
1932
+ }
1933
+
1934
+ # ✅ サブネット定義
1935
+ resource "aws_subnet" "public" {
1936
+ count = 2
1937
+ vpc_id = aws_vpc.main.id
1938
+ cidr_block = "10.0.${count.index}.0/24"
1939
+ availability_zone = data.aws_availability_zones.available.names[count.index]
1940
+ map_public_ip_on_launch = true
1941
+
1942
+ tags = {
1943
+ Name = "public-subnet-${count.index + 1}"
1944
+ }
1945
+ }
1946
+
1947
+ # ✅ セキュリティグループ
1948
+ resource "aws_security_group" "web" {
1949
+ name = "web-sg"
1950
+ description = "Security group for web servers"
1951
+ vpc_id = aws_vpc.main.id
1952
+
1953
+ ingress {
1954
+ from_port = 443
1955
+ to_port = 443
1956
+ protocol = "tcp"
1957
+ cidr_blocks = ["0.0.0.0/0"]
1958
+ }
1959
+
1960
+ egress {
1961
+ from_port = 0
1962
+ to_port = 0
1963
+ protocol = "-1"
1964
+ cidr_blocks = ["0.0.0.0/0"]
1965
+ }
1966
+ }
1967
+ ```
1968
+
1969
+ ## CI/CDパイプライン
1970
+
1971
+ ### CI/CDアーキテクチャ
1972
+
1973
+ ```plantuml
1974
+ @startuml
1975
+ start
1976
+
1977
+ :コード変更;
1978
+ :Git Push;
1979
+
1980
+ fork
1981
+ :ユニットテスト実行;
1982
+ fork again
1983
+ :静的解析;
1984
+ fork again
1985
+ :コードカバレッジ;
1986
+ end fork
1987
+
1988
+ :ビルド;
1989
+
1990
+ if (テスト成功?) then (yes)
1991
+ :コンテナイメージ作成;
1992
+ :イメージレジストリ登録;
1993
+
1994
+ if (本番デプロイ?) then (yes)
1995
+ :承認待ち;
1996
+ :本番デプロイ;
1997
+ else (no)
1998
+ :ステージングデプロイ;
1999
+ endif
2000
+
2001
+ :スモークテスト;
2002
+ :監視開始;
2003
+ else (no)
2004
+ :通知(失敗);
2005
+ stop
2006
+ endif
2007
+
2008
+ :デプロイ完了;
2009
+
2010
+ stop
2011
+ @enduml
2012
+ ```
2013
+
2014
+ ### デプロイメント戦略
2015
+
2016
+ #### ブルーグリーンデプロイメント
2017
+
2018
+ ```plantuml
2019
+ @startuml
2020
+ left to right direction
2021
+
2022
+ cloud "ロードバランサー" as lb
2023
+
2024
+ package "Blue環境(現行)" {
2025
+ node "App v1.0" as blue1
2026
+ node "App v1.0" as blue2
2027
+ }
2028
+
2029
+ package "Green環境(新規)" {
2030
+ node "App v2.0" as green1
2031
+ node "App v2.0" as green2
2032
+ }
2033
+
2034
+ lb --> blue1
2035
+ lb --> blue2
2036
+ @enduml
2037
+ ```
2038
+
2039
+ **メリット**:
2040
+
2041
+ - 即座にロールバック可能
2042
+ - ゼロダウンタイム
2043
+ - 本番環境での検証
2044
+
2045
+ **デメリット**:
2046
+
2047
+ - リソースが2倍必要
2048
+ - データベース移行の複雑さ
2049
+
2050
+ #### カナリアデプロイメント
2051
+
2052
+ ```plantuml
2053
+ @startuml
2054
+ cloud "ロードバランサー" as lb
2055
+
2056
+ package "本番環境" {
2057
+ node "App v1.0" as old1
2058
+ node "App v1.0" as old2
2059
+ node "App v1.0" as old3
2060
+ node "App v2.0(カナリア)" as canary
2061
+ }
2062
+
2063
+ lb --> old1 : 75%
2064
+ lb --> old2 : 75%
2065
+ lb --> old3 : 75%
2066
+ lb --> canary : 25%
2067
+ @enduml
2068
+ ```
2069
+
2070
+ **メリット**:
2071
+
2072
+ - リスク最小化
2073
+ - 段階的なロールアウト
2074
+ - 問題の早期発見
2075
+
2076
+ **デメリット**:
2077
+
2078
+ - 複雑な管理
2079
+ - バージョン混在期間
2080
+
2081
+ ## インフラストラクチャ評価基準
2082
+
2083
+ ### 品質属性評価マトリックス
2084
+
2085
+ | 品質属性 | モノリシック | マイクロサービス | コンテナ | サーバーレス |
2086
+ |----------|:---:|:---:|:---:|:---:|
2087
+ | **運用複雑性** | ⭐⭐⭐⭐⭐ | ⭐⭐ | ⭐⭐⭐ | ⭐⭐⭐⭐ |
2088
+ | **スケーラビリティ** | ⭐⭐ | ⭐⭐⭐⭐⭐ | ⭐⭐⭐⭐ | ⭐⭐⭐⭐⭐ |
2089
+ | **コスト効率** | ⭐⭐⭐ | ⭐⭐ | ⭐⭐⭐⭐ | ⭐⭐⭐⭐⭐ |
2090
+ | **デプロイ速度** | ⭐⭐⭐ | ⭐⭐⭐⭐ | ⭐⭐⭐⭐⭐ | ⭐⭐⭐⭐⭐ |
2091
+ | **可用性** | ⭐⭐ | ⭐⭐⭐⭐⭐ | ⭐⭐⭐⭐⭐ | ⭐⭐⭐⭐ |
2092
+ | **監視・デバッグ** | ⭐⭐⭐⭐⭐ | ⭐⭐ | ⭐⭐⭐ | ⭐⭐ |
2093
+
2094
+ ### コスト最適化戦略
2095
+
2096
+ | 戦略 | 実装方法 | 削減効果 |
2097
+ |------|----------|----------|
2098
+ | **リソース最適化** | 適切なインスタンスサイズ選択 | 20-40% |
2099
+ | **予約インスタンス** | 長期コミットメントで割引 | 40-60% |
2100
+ | **スポットインスタンス** | 余剰リソースの活用 | 70-90% |
2101
+ | **オートスケーリング** | 需要に応じた自動調整 | 30-50% |
2102
+ | **ストレージ最適化** | ライフサイクル管理、圧縮 | 30-60% |
2103
+
2104
+ ## インフラストラクチャ移行戦略
2105
+
2106
+ ### クラウド移行パターン
2107
+
2108
+ ```plantuml
2109
+ @startuml
2110
+ start
2111
+
2112
+ :現状分析;
2113
+
2114
+ if (移行戦略) then (リフト&シフト)
2115
+ :既存システムをそのままクラウドへ;
2116
+ :最小限の変更;
2117
+ else if (リプラットフォーム) then
2118
+ :軽微な最適化;
2119
+ :クラウドサービス活用;
2120
+ else if (リアーキテクト) then
2121
+ :アプリケーション再設計;
2122
+ :クラウドネイティブ化;
2123
+ else (リビルド)
2124
+ :完全な再構築;
2125
+ :最新アーキテクチャ採用;
2126
+ endif
2127
+
2128
+ :移行実行;
2129
+ :検証;
2130
+ :最適化;
2131
+
2132
+ stop
2133
+ @enduml
2134
+ ```
2135
+
2136
+ ### 移行時の注意点
2137
+
2138
+ 1. **段階的移行**: すべてを一度に移行せず、段階的に実施
2139
+ 2. **パイロットプロジェクト**: 小規模システムで先行検証
2140
+ 3. **データ移行計画**: データの整合性とダウンタイム最小化
2141
+ 4. **セキュリティ**: クラウド環境でのセキュリティ要件確認
2142
+ 5. **コスト管理**: 移行コストと運用コストの可視化
2143
+
2144
+ # まとめ
2145
+
2146
+ ## バックエンドアーキテクチャ選択の指針
2147
+
2148
+ 1. **業務ドメインの理解**: 中核業務と補完業務の明確な識別
2149
+ 2. **データ複雑性の評価**: エンティティ関係とビジネスルールの複雑さ
2150
+ 3. **非機能要件の考慮**: パフォーマンス、スケーラビリティ、監査要件
2151
+ 4. **チーム能力の評価**: 技術的習熟度と学習意欲
2152
+ 5. **長期戦略の整合**: 将来的な拡張性と保守性の確保
2153
+
2154
+ ## フロントエンドアーキテクチャ選択の指針
2155
+
2156
+ 1. **プロジェクト規模**: 小規模・中規模・大規模に応じた構造設計
2157
+ 2. **ユーザー体験要件**: SEO・パフォーマンス・インタラクティビティの優先順位
2158
+ 3. **状態管理複雑性**: データフロー・更新頻度・共有範囲の分析
2159
+ 4. **チーム構成**: フロントエンド専任・フルスタック・QAエンジニアの有無
2160
+ 5. **技術的制約**: ブラウザサポート・既存システム・運用環境
2161
+
2162
+ ## インフラストラクチャアーキテクチャ選択の指針
2163
+
2164
+ 1. **システム規模とトラフィック**: 予想される負荷・成長率・ピーク時の要件分析
2165
+ 2. **可用性要件**: SLA・ダウンタイム許容度・災害復旧要件の定義
2166
+ 3. **セキュリティ要件**: コンプライアンス・データ保護・監査要件の評価
2167
+ 4. **運用体制**: チームの技術力・運用負荷・自動化レベルの考慮
2168
+ 5. **コスト制約**: 初期投資・運用コスト・スケーリングコストのバランス
2169
+
2170
+ ## 成功要因
2171
+
2172
+ ### バックエンド
2173
+ - **適切なパターン選択**: 業務特性に応じた最適なアーキテクチャの採用
2174
+ - **段階的な実装**: 小さく始めて継続的に改善
2175
+ - **品質の作り込み**: テストファースト・継続的インテグレーション
2176
+ - **ドメイン駆動設計**: ビジネスルールの適切な表現と分離
2177
+
2178
+ ### フロントエンド
2179
+ - **適切な技術選択**: 要件に応じたライブラリ・フレームワークの選定
2180
+ - **コンポーネント設計**: 再利用性と保守性を両立した設計
2181
+ - **状態管理戦略**: スケールに応じた適切な状態管理手法の採用
2182
+ - **パフォーマンス最適化**: ユーザー体験を重視したパフォーマンス設計
2183
+
2184
+ ### インフラストラクチャ
2185
+ - **自動化の徹底**: IaC によるインフラ管理とデプロイメントの自動化
2186
+ - **監視とオブザーバビリティ**: 包括的な監視体制と問題の早期検知
2187
+ - **セキュリティの組み込み**: 設計段階からのセキュリティ対策実装
2188
+ - **コスト最適化**: リソース利用の継続的な見直しと最適化
2189
+
2190
+ ## 統合的成功要因
2191
+
2192
+ - **チーム教育**: アーキテクチャ原則の共有と実践
2193
+ - **継続的改善**: 定期的な設計見直しとリファクタリング
2194
+ - **品質文化**: 自動テスト・コードレビュー・静的解析の徹底
2195
+ - **段階的移行**: リスクを最小化した漸進的なアーキテクチャ改善
2196
+
2197
+ ## 実践ポイント
2198
+
2199
+ ### 開発初期
2200
+
2201
+ 1. **要件に基づく技術選択**: 過度な技術より要件適合性を重視
2202
+ 2. **プロトタイプ開発**: アーキテクチャ妥当性の早期検証
2203
+ 3. **チーム合意形成**: 技術選択の背景と理由の共有
2204
+
2205
+ ### 開発中期
2206
+
2207
+ 1. **継続的リファクタリング**: 設計負債の早期解消
2208
+ 2. **パフォーマンス監視**: 品質メトリクスに基づく改善
2209
+ 3. **テストカバレッジ**: アーキテクチャ変更に対する安全性確保
2210
+
2211
+ ### 運用期
2212
+
2213
+ 1. **監視・メトリクス**: 実装の効果測定と改善指針
2214
+ 2. **技術的負債管理**: 計画的なアーキテクチャ改善
2215
+ 3. **スケーラビリティ対応**: 成長に応じたアーキテクチャ進化
2216
+
2217
2217
  良いアーキテクチャは、システムの長期的成功の基盤となります。本ガイドを参考に、アプリケーション・インフラストラクチャそれぞれの特性を理解し、プロジェクトに最適なアーキテクチャを選択・実装してください。