memento-mcp-server 0.1.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 (555) hide show
  1. package/.cursor/rules/cache-management.mdc +171 -0
  2. package/.cursor/rules/database-schema.mdc +344 -0
  3. package/.cursor/rules/deployment.mdc +596 -0
  4. package/.cursor/rules/error-logging.mdc +298 -0
  5. package/.cursor/rules/forgetting-algorithms.mdc +426 -0
  6. package/.cursor/rules/http-server.mdc +432 -0
  7. package/.cursor/rules/hybrid-search.mdc +424 -0
  8. package/.cursor/rules/implementation.mdc +369 -0
  9. package/.cursor/rules/lightweight-embedding.mdc +178 -0
  10. package/.cursor/rules/mcp-client-development.mdc +0 -0
  11. package/.cursor/rules/mcp-server-development.mdc +0 -0
  12. package/.cursor/rules/mcp-tools-architecture.mdc +205 -0
  13. package/.cursor/rules/memento-memory-rule.mdc +8 -0
  14. package/.cursor/rules/memento-project-overview.mdc +0 -0
  15. package/.cursor/rules/memory-algorithms.mdc +502 -0
  16. package/.cursor/rules/monitoring.mdc +622 -0
  17. package/.cursor/rules/performance-alerts.mdc +537 -0
  18. package/.cursor/rules/performance-monitoring.mdc +345 -0
  19. package/.cursor/rules/performance-optimization.mdc +563 -0
  20. package/.cursor/rules/project-structure.mdc +310 -0
  21. package/.cursor/rules/testing.mdc +473 -0
  22. package/.dockerignore +15 -0
  23. package/.eslintrc.json +34 -0
  24. package/.github/ISSUE_TEMPLATE/bug_report.md +51 -0
  25. package/.github/ISSUE_TEMPLATE/feature_request.md +45 -0
  26. package/.github/ISSUE_TEMPLATE/question.md +31 -0
  27. package/.github/PULL_REQUEST_TEMPLATE.md +97 -0
  28. package/AGENTS.md +28 -0
  29. package/CHANGELOG.md +416 -0
  30. package/CODE_OF_CONDUCT.md +62 -0
  31. package/CONTRIBUTING.md +165 -0
  32. package/DOCKER_SETUP_GUIDE.md +84 -0
  33. package/Dockerfile +90 -0
  34. package/INSTALL.en.md +303 -0
  35. package/INSTALL.md +303 -0
  36. package/README.en.md +330 -0
  37. package/README.md +427 -0
  38. package/backup/legacy-removal-20250930-201816/http-server-legacy.ts +1068 -0
  39. package/backup/legacy-removal-20250930-201816/rollback-to-legacy.ps1 +46 -0
  40. package/backup/legacy-removal-20250930-201816/rollback-to-legacy.sh +48 -0
  41. package/dist/algorithms/forgetting-algorithm.d.ts +90 -0
  42. package/dist/algorithms/forgetting-algorithm.d.ts.map +1 -0
  43. package/dist/algorithms/forgetting-algorithm.js +160 -0
  44. package/dist/algorithms/forgetting-algorithm.js.map +1 -0
  45. package/dist/algorithms/hybrid-search-engine.d.ts +108 -0
  46. package/dist/algorithms/hybrid-search-engine.d.ts.map +1 -0
  47. package/dist/algorithms/hybrid-search-engine.js +384 -0
  48. package/dist/algorithms/hybrid-search-engine.js.map +1 -0
  49. package/dist/algorithms/search-engine.d.ts +64 -0
  50. package/dist/algorithms/search-engine.d.ts.map +1 -0
  51. package/dist/algorithms/search-engine.js +304 -0
  52. package/dist/algorithms/search-engine.js.map +1 -0
  53. package/dist/algorithms/search-ranking.d.ts +145 -0
  54. package/dist/algorithms/search-ranking.d.ts.map +1 -0
  55. package/dist/algorithms/search-ranking.js +311 -0
  56. package/dist/algorithms/search-ranking.js.map +1 -0
  57. package/dist/algorithms/spaced-repetition.d.ts +83 -0
  58. package/dist/algorithms/spaced-repetition.d.ts.map +1 -0
  59. package/dist/algorithms/spaced-repetition.js +153 -0
  60. package/dist/algorithms/spaced-repetition.js.map +1 -0
  61. package/dist/algorithms/vector-search-engine.d.ts +96 -0
  62. package/dist/algorithms/vector-search-engine.d.ts.map +1 -0
  63. package/dist/algorithms/vector-search-engine.js +410 -0
  64. package/dist/algorithms/vector-search-engine.js.map +1 -0
  65. package/dist/client/index.d.ts +55 -0
  66. package/dist/client/index.d.ts.map +1 -0
  67. package/dist/client/index.js +179 -0
  68. package/dist/client/index.js.map +1 -0
  69. package/dist/config/index.d.ts +20 -0
  70. package/dist/config/index.d.ts.map +1 -0
  71. package/dist/config/index.js +87 -0
  72. package/dist/config/index.js.map +1 -0
  73. package/dist/database/init.d.ts +7 -0
  74. package/dist/database/init.d.ts.map +1 -0
  75. package/dist/database/init.js +117 -0
  76. package/dist/database/init.js.map +1 -0
  77. package/dist/database/migrate.d.ts +6 -0
  78. package/dist/database/migrate.d.ts.map +1 -0
  79. package/dist/database/migrate.js +84 -0
  80. package/dist/database/migrate.js.map +1 -0
  81. package/dist/database/schema.sql +159 -0
  82. package/dist/npm-client/context-injector.d.ts +106 -0
  83. package/dist/npm-client/context-injector.d.ts.map +1 -0
  84. package/dist/npm-client/context-injector.js +296 -0
  85. package/dist/npm-client/context-injector.js.map +1 -0
  86. package/dist/npm-client/index.d.ts +42 -0
  87. package/dist/npm-client/index.d.ts.map +1 -0
  88. package/dist/npm-client/index.js +43 -0
  89. package/dist/npm-client/index.js.map +1 -0
  90. package/dist/npm-client/memento-client.d.ts +114 -0
  91. package/dist/npm-client/memento-client.d.ts.map +1 -0
  92. package/dist/npm-client/memento-client.js +391 -0
  93. package/dist/npm-client/memento-client.js.map +1 -0
  94. package/dist/npm-client/memory-manager.d.ts +137 -0
  95. package/dist/npm-client/memory-manager.d.ts.map +1 -0
  96. package/dist/npm-client/memory-manager.js +341 -0
  97. package/dist/npm-client/memory-manager.js.map +1 -0
  98. package/dist/npm-client/types.d.ts +216 -0
  99. package/dist/npm-client/types.d.ts.map +1 -0
  100. package/dist/npm-client/types.js +44 -0
  101. package/dist/npm-client/types.js.map +1 -0
  102. package/dist/npm-client/utils.d.ts +91 -0
  103. package/dist/npm-client/utils.d.ts.map +1 -0
  104. package/dist/npm-client/utils.js +351 -0
  105. package/dist/npm-client/utils.js.map +1 -0
  106. package/dist/scripts/copy-assets.d.ts +3 -0
  107. package/dist/scripts/copy-assets.d.ts.map +1 -0
  108. package/dist/scripts/copy-assets.js +31 -0
  109. package/dist/scripts/copy-assets.js.map +1 -0
  110. package/dist/server/http-server.d.ts +28 -0
  111. package/dist/server/http-server.d.ts.map +1 -0
  112. package/dist/server/http-server.js +930 -0
  113. package/dist/server/http-server.js.map +1 -0
  114. package/dist/server/index-backup.d.ts +5 -0
  115. package/dist/server/index-backup.d.ts.map +1 -0
  116. package/dist/server/index-backup.js +793 -0
  117. package/dist/server/index-backup.js.map +1 -0
  118. package/dist/server/index-refactored.d.ts +6 -0
  119. package/dist/server/index-refactored.d.ts.map +1 -0
  120. package/dist/server/index-refactored.js +206 -0
  121. package/dist/server/index-refactored.js.map +1 -0
  122. package/dist/server/index.d.ts +12 -0
  123. package/dist/server/index.d.ts.map +1 -0
  124. package/dist/server/index.js +301 -0
  125. package/dist/server/index.js.map +1 -0
  126. package/dist/server/simple-mcp-server.d.ts +8 -0
  127. package/dist/server/simple-mcp-server.d.ts.map +1 -0
  128. package/dist/server/simple-mcp-server.js +152 -0
  129. package/dist/server/simple-mcp-server.js.map +1 -0
  130. package/dist/services/async-optimizer.d.ts +136 -0
  131. package/dist/services/async-optimizer.d.ts.map +1 -0
  132. package/dist/services/async-optimizer.js +406 -0
  133. package/dist/services/async-optimizer.js.map +1 -0
  134. package/dist/services/batch-scheduler.d.ts +156 -0
  135. package/dist/services/batch-scheduler.d.ts.map +1 -0
  136. package/dist/services/batch-scheduler.js +612 -0
  137. package/dist/services/batch-scheduler.js.map +1 -0
  138. package/dist/services/cache-service.d.ts +168 -0
  139. package/dist/services/cache-service.d.ts.map +1 -0
  140. package/dist/services/cache-service.js +360 -0
  141. package/dist/services/cache-service.js.map +1 -0
  142. package/dist/services/database-optimizer.d.ts +110 -0
  143. package/dist/services/database-optimizer.d.ts.map +1 -0
  144. package/dist/services/database-optimizer.js +369 -0
  145. package/dist/services/database-optimizer.js.map +1 -0
  146. package/dist/services/embedding-provider-factory.d.ts +62 -0
  147. package/dist/services/embedding-provider-factory.d.ts.map +1 -0
  148. package/dist/services/embedding-provider-factory.js +152 -0
  149. package/dist/services/embedding-provider-factory.js.map +1 -0
  150. package/dist/services/embedding-service.d.ts +95 -0
  151. package/dist/services/embedding-service.d.ts.map +1 -0
  152. package/dist/services/embedding-service.js +276 -0
  153. package/dist/services/embedding-service.js.map +1 -0
  154. package/dist/services/error-logging-service.d.ts +134 -0
  155. package/dist/services/error-logging-service.d.ts.map +1 -0
  156. package/dist/services/error-logging-service.js +271 -0
  157. package/dist/services/error-logging-service.js.map +1 -0
  158. package/dist/services/forgetting-policy-service.d.ts +94 -0
  159. package/dist/services/forgetting-policy-service.d.ts.map +1 -0
  160. package/dist/services/forgetting-policy-service.js +233 -0
  161. package/dist/services/forgetting-policy-service.js.map +1 -0
  162. package/dist/services/gemini-embedding-service.d.ts +82 -0
  163. package/dist/services/gemini-embedding-service.d.ts.map +1 -0
  164. package/dist/services/gemini-embedding-service.js +232 -0
  165. package/dist/services/gemini-embedding-service.js.map +1 -0
  166. package/dist/services/lightweight-embedding-service.d.ts +95 -0
  167. package/dist/services/lightweight-embedding-service.d.ts.map +1 -0
  168. package/dist/services/lightweight-embedding-service.js +263 -0
  169. package/dist/services/lightweight-embedding-service.js.map +1 -0
  170. package/dist/services/memory-embedding-service.d.ts +69 -0
  171. package/dist/services/memory-embedding-service.d.ts.map +1 -0
  172. package/dist/services/memory-embedding-service.js +223 -0
  173. package/dist/services/memory-embedding-service.js.map +1 -0
  174. package/dist/services/minilm-embedding-service.d.ts +92 -0
  175. package/dist/services/minilm-embedding-service.d.ts.map +1 -0
  176. package/dist/services/minilm-embedding-service.js +216 -0
  177. package/dist/services/minilm-embedding-service.js.map +1 -0
  178. package/dist/services/performance-alert-service.d.ts +142 -0
  179. package/dist/services/performance-alert-service.d.ts.map +1 -0
  180. package/dist/services/performance-alert-service.js +366 -0
  181. package/dist/services/performance-alert-service.js.map +1 -0
  182. package/dist/services/performance-monitor.d.ts +144 -0
  183. package/dist/services/performance-monitor.d.ts.map +1 -0
  184. package/dist/services/performance-monitor.js +416 -0
  185. package/dist/services/performance-monitor.js.map +1 -0
  186. package/dist/services/performance-monitoring-integration.d.ts +77 -0
  187. package/dist/services/performance-monitoring-integration.d.ts.map +1 -0
  188. package/dist/services/performance-monitoring-integration.js +177 -0
  189. package/dist/services/performance-monitoring-integration.js.map +1 -0
  190. package/dist/services/unified-embedding-service.d.ts +75 -0
  191. package/dist/services/unified-embedding-service.d.ts.map +1 -0
  192. package/dist/services/unified-embedding-service.js +211 -0
  193. package/dist/services/unified-embedding-service.js.map +1 -0
  194. package/dist/test/debug-http-v2.d.ts +5 -0
  195. package/dist/test/debug-http-v2.d.ts.map +1 -0
  196. package/dist/test/debug-http-v2.js +28 -0
  197. package/dist/test/debug-http-v2.js.map +1 -0
  198. package/dist/test/performance-benchmark.d.ts +57 -0
  199. package/dist/test/performance-benchmark.d.ts.map +1 -0
  200. package/dist/test/performance-benchmark.js +427 -0
  201. package/dist/test/performance-benchmark.js.map +1 -0
  202. package/dist/test/test-alerts-direct.d.ts +7 -0
  203. package/dist/test/test-alerts-direct.d.ts.map +1 -0
  204. package/dist/test/test-alerts-direct.js +101 -0
  205. package/dist/test/test-alerts-direct.js.map +1 -0
  206. package/dist/test/test-batch-scheduler.d.ts +2 -0
  207. package/dist/test/test-batch-scheduler.d.ts.map +1 -0
  208. package/dist/test/test-batch-scheduler.js +156 -0
  209. package/dist/test/test-batch-scheduler.js.map +1 -0
  210. package/dist/test/test-client.d.ts +5 -0
  211. package/dist/test/test-client.d.ts.map +1 -0
  212. package/dist/test/test-client.js +86 -0
  213. package/dist/test/test-client.js.map +1 -0
  214. package/dist/test/test-embedding.d.ts +6 -0
  215. package/dist/test/test-embedding.d.ts.map +1 -0
  216. package/dist/test/test-embedding.js +142 -0
  217. package/dist/test/test-embedding.js.map +1 -0
  218. package/dist/test/test-error-logging.d.ts +7 -0
  219. package/dist/test/test-error-logging.d.ts.map +1 -0
  220. package/dist/test/test-error-logging.js +105 -0
  221. package/dist/test/test-error-logging.js.map +1 -0
  222. package/dist/test/test-forgetting.d.ts +6 -0
  223. package/dist/test/test-forgetting.d.ts.map +1 -0
  224. package/dist/test/test-forgetting.js +154 -0
  225. package/dist/test/test-forgetting.js.map +1 -0
  226. package/dist/test/test-gemini-embedding.d.ts +7 -0
  227. package/dist/test/test-gemini-embedding.d.ts.map +1 -0
  228. package/dist/test/test-gemini-embedding.js +134 -0
  229. package/dist/test/test-gemini-embedding.js.map +1 -0
  230. package/dist/test/test-http-server-v2-simple.d.ts +6 -0
  231. package/dist/test/test-http-server-v2-simple.d.ts.map +1 -0
  232. package/dist/test/test-http-server-v2-simple.js +131 -0
  233. package/dist/test/test-http-server-v2-simple.js.map +1 -0
  234. package/dist/test/test-http-server-v2.d.ts +7 -0
  235. package/dist/test/test-http-server-v2.d.ts.map +1 -0
  236. package/dist/test/test-http-server-v2.js +529 -0
  237. package/dist/test/test-http-server-v2.js.map +1 -0
  238. package/dist/test/test-lightweight-embedding.d.ts +6 -0
  239. package/dist/test/test-lightweight-embedding.d.ts.map +1 -0
  240. package/dist/test/test-lightweight-embedding.js +189 -0
  241. package/dist/test/test-lightweight-embedding.js.map +1 -0
  242. package/dist/test/test-m1-completion.d.ts +7 -0
  243. package/dist/test/test-m1-completion.d.ts.map +1 -0
  244. package/dist/test/test-m1-completion.js +124 -0
  245. package/dist/test/test-m1-completion.js.map +1 -0
  246. package/dist/test/test-memory-injection-prompt.d.ts +2 -0
  247. package/dist/test/test-memory-injection-prompt.d.ts.map +1 -0
  248. package/dist/test/test-memory-injection-prompt.js +299 -0
  249. package/dist/test/test-memory-injection-prompt.js.map +1 -0
  250. package/dist/test/test-performance-alerts.d.ts +7 -0
  251. package/dist/test/test-performance-alerts.d.ts.map +1 -0
  252. package/dist/test/test-performance-alerts.js +109 -0
  253. package/dist/test/test-performance-alerts.js.map +1 -0
  254. package/dist/test/test-performance-monitor.d.ts +2 -0
  255. package/dist/test/test-performance-monitor.d.ts.map +1 -0
  256. package/dist/test/test-performance-monitor.js +182 -0
  257. package/dist/test/test-performance-monitor.js.map +1 -0
  258. package/dist/test/test-performance-monitoring.d.ts +6 -0
  259. package/dist/test/test-performance-monitoring.d.ts.map +1 -0
  260. package/dist/test/test-performance-monitoring.js +156 -0
  261. package/dist/test/test-performance-monitoring.js.map +1 -0
  262. package/dist/test/test-search.d.ts +5 -0
  263. package/dist/test/test-search.d.ts.map +1 -0
  264. package/dist/test/test-search.js +141 -0
  265. package/dist/test/test-search.js.map +1 -0
  266. package/dist/test/test-simple-alerts.d.ts +6 -0
  267. package/dist/test/test-simple-alerts.d.ts.map +1 -0
  268. package/dist/test/test-simple-alerts.js +106 -0
  269. package/dist/test/test-simple-alerts.js.map +1 -0
  270. package/dist/test/test-vector-search-engine.d.ts +2 -0
  271. package/dist/test/test-vector-search-engine.d.ts.map +1 -0
  272. package/dist/test/test-vector-search-engine.js +225 -0
  273. package/dist/test/test-vector-search-engine.js.map +1 -0
  274. package/dist/tools/base-tool.d.ts +64 -0
  275. package/dist/tools/base-tool.d.ts.map +1 -0
  276. package/dist/tools/base-tool.js +158 -0
  277. package/dist/tools/base-tool.js.map +1 -0
  278. package/dist/tools/cleanup-memory-tool.d.ts +10 -0
  279. package/dist/tools/cleanup-memory-tool.d.ts.map +1 -0
  280. package/dist/tools/cleanup-memory-tool.js +66 -0
  281. package/dist/tools/cleanup-memory-tool.js.map +1 -0
  282. package/dist/tools/database-optimize-tool.d.ts +10 -0
  283. package/dist/tools/database-optimize-tool.d.ts.map +1 -0
  284. package/dist/tools/database-optimize-tool.js +64 -0
  285. package/dist/tools/database-optimize-tool.js.map +1 -0
  286. package/dist/tools/error-stats.d.ts +93 -0
  287. package/dist/tools/error-stats.d.ts.map +1 -0
  288. package/dist/tools/error-stats.js +115 -0
  289. package/dist/tools/error-stats.js.map +1 -0
  290. package/dist/tools/forget-tool.d.ts +63 -0
  291. package/dist/tools/forget-tool.d.ts.map +1 -0
  292. package/dist/tools/forget-tool.js +340 -0
  293. package/dist/tools/forget-tool.js.map +1 -0
  294. package/dist/tools/forgetting-stats-tool.d.ts +10 -0
  295. package/dist/tools/forgetting-stats-tool.d.ts.map +1 -0
  296. package/dist/tools/forgetting-stats-tool.js +37 -0
  297. package/dist/tools/forgetting-stats-tool.js.map +1 -0
  298. package/dist/tools/index.d.ts +33 -0
  299. package/dist/tools/index.d.ts.map +1 -0
  300. package/dist/tools/index.js +55 -0
  301. package/dist/tools/index.js.map +1 -0
  302. package/dist/tools/memory-injection-prompt.d.ts +31 -0
  303. package/dist/tools/memory-injection-prompt.d.ts.map +1 -0
  304. package/dist/tools/memory-injection-prompt.js +203 -0
  305. package/dist/tools/memory-injection-prompt.js.map +1 -0
  306. package/dist/tools/performance-alerts.d.ts +127 -0
  307. package/dist/tools/performance-alerts.d.ts.map +1 -0
  308. package/dist/tools/performance-alerts.js +208 -0
  309. package/dist/tools/performance-alerts.js.map +1 -0
  310. package/dist/tools/performance-stats-tool.d.ts +10 -0
  311. package/dist/tools/performance-stats-tool.d.ts.map +1 -0
  312. package/dist/tools/performance-stats-tool.js +38 -0
  313. package/dist/tools/performance-stats-tool.js.map +1 -0
  314. package/dist/tools/pin-tool.d.ts +39 -0
  315. package/dist/tools/pin-tool.d.ts.map +1 -0
  316. package/dist/tools/pin-tool.js +211 -0
  317. package/dist/tools/pin-tool.js.map +1 -0
  318. package/dist/tools/recall-tool.d.ts +27 -0
  319. package/dist/tools/recall-tool.d.ts.map +1 -0
  320. package/dist/tools/recall-tool.js +335 -0
  321. package/dist/tools/recall-tool.js.map +1 -0
  322. package/dist/tools/remember-tool.d.ts +10 -0
  323. package/dist/tools/remember-tool.d.ts.map +1 -0
  324. package/dist/tools/remember-tool.js +101 -0
  325. package/dist/tools/remember-tool.js.map +1 -0
  326. package/dist/tools/resolve-error.d.ts +54 -0
  327. package/dist/tools/resolve-error.d.ts.map +1 -0
  328. package/dist/tools/resolve-error.js +63 -0
  329. package/dist/tools/resolve-error.js.map +1 -0
  330. package/dist/tools/tool-registry.d.ts +134 -0
  331. package/dist/tools/tool-registry.d.ts.map +1 -0
  332. package/dist/tools/tool-registry.js +337 -0
  333. package/dist/tools/tool-registry.js.map +1 -0
  334. package/dist/tools/types.d.ts +56 -0
  335. package/dist/tools/types.d.ts.map +1 -0
  336. package/dist/tools/types.js +23 -0
  337. package/dist/tools/types.js.map +1 -0
  338. package/dist/tools/unpin-tool.d.ts +43 -0
  339. package/dist/tools/unpin-tool.d.ts.map +1 -0
  340. package/dist/tools/unpin-tool.js +233 -0
  341. package/dist/tools/unpin-tool.js.map +1 -0
  342. package/dist/types/embedding.types.d.ts +65 -0
  343. package/dist/types/embedding.types.d.ts.map +1 -0
  344. package/dist/types/embedding.types.js +6 -0
  345. package/dist/types/embedding.types.js.map +1 -0
  346. package/dist/types/index.d.ts +103 -0
  347. package/dist/types/index.d.ts.map +1 -0
  348. package/dist/types/index.js +5 -0
  349. package/dist/types/index.js.map +1 -0
  350. package/dist/utils/database.d.ts +62 -0
  351. package/dist/utils/database.d.ts.map +1 -0
  352. package/dist/utils/database.js +399 -0
  353. package/dist/utils/database.js.map +1 -0
  354. package/dist/utils/stopwords.d.ts +18 -0
  355. package/dist/utils/stopwords.d.ts.map +1 -0
  356. package/dist/utils/stopwords.js +117 -0
  357. package/dist/utils/stopwords.js.map +1 -0
  358. package/docker-compose.dev.yml +50 -0
  359. package/docker-compose.prod.yml +77 -0
  360. package/docker-compose.yml +43 -0
  361. package/docs/en/Memento-Goals.md +217 -0
  362. package/docs/en/Memento-M1-DetailSpecs.md +130 -0
  363. package/docs/en/Memento-Milestones.md +135 -0
  364. package/docs/en/Search-Ranking-Memory-Decay-Formulas.md +177 -0
  365. package/docs/en/api-reference.md +658 -0
  366. package/docs/en/architecture.md +1302 -0
  367. package/docs/en/developer-guide.md +1005 -0
  368. package/docs/en/user-manual.md +595 -0
  369. package/docs/ko/Memento-Goals.md +217 -0
  370. package/docs/ko/Memento-M1-DetailSpecs.md +130 -0
  371. package/docs/ko/Memento-Milestones.md +134 -0
  372. package/docs/ko/Search-Ranking-Memory-Decay-Formulas.md +177 -0
  373. package/docs/ko/api-reference.md +658 -0
  374. package/docs/ko/architecture.md +1302 -0
  375. package/docs/ko/developer-guide.md +1006 -0
  376. package/docs/ko/embedding-api-reference.md +122 -0
  377. package/docs/ko/embedding-configuration.md +62 -0
  378. package/docs/ko/embedding-performance-benchmark.md +62 -0
  379. package/docs/ko/embedding-service-guide.md +314 -0
  380. package/docs/ko/user-manual.md +595 -0
  381. package/env.example +49 -0
  382. package/install.sh +191 -0
  383. package/mcp-http-client.js +218 -0
  384. package/mcp.json +0 -0
  385. package/package.json +125 -0
  386. package/packages/mcp-client/docs/API-REFERENCE.md +560 -0
  387. package/packages/mcp-client/docs/BEST-PRACTICES.md +564 -0
  388. package/packages/mcp-client/docs/MIGRATION-GUIDE.md +344 -0
  389. package/packages/mcp-client/docs/PERFORMANCE-GUIDE.md +476 -0
  390. package/packages/mcp-client/docs/TROUBLESHOOTING.md +564 -0
  391. package/packages/mcp-client/package-lock.json +907 -0
  392. package/packages/mcp-client/package.json +58 -0
  393. package/packages/mcp-client/performance-optimizer.js +428 -0
  394. package/packages/mcp-client/test-basic.js +65 -0
  395. package/packages/mcp-client/test-integration.js +366 -0
  396. package/scripts/auto-setup.js +234 -0
  397. package/scripts/backup-daily.bat +28 -0
  398. package/scripts/backup-embeddings.js +108 -0
  399. package/scripts/check-db-integrity.js +93 -0
  400. package/scripts/debug-embeddings.js +184 -0
  401. package/scripts/direct-sql-migration.sql +36 -0
  402. package/scripts/docker-migration.sh +105 -0
  403. package/scripts/fix-migration.js +93 -0
  404. package/scripts/fix-vector-dimensions.js +206 -0
  405. package/scripts/migrate-embedding-data.js +307 -0
  406. package/scripts/regenerate-embeddings.js +144 -0
  407. package/scripts/restore-legacy.ps1 +60 -0
  408. package/scripts/restore-legacy.sh +62 -0
  409. package/scripts/run-migration.js +122 -0
  410. package/scripts/safe-migration.js +150 -0
  411. package/scripts/simple-migrate.js +41 -0
  412. package/scripts/simple-update.js +123 -0
  413. package/scripts/start-container.sh +10 -0
  414. package/src/algorithms/forgetting-algorithm.spec.ts +538 -0
  415. package/src/algorithms/forgetting-algorithm.ts +243 -0
  416. package/src/algorithms/hybrid-search-engine.spec.ts +484 -0
  417. package/src/algorithms/hybrid-search-engine.ts +489 -0
  418. package/src/algorithms/search-engine.spec.ts +429 -0
  419. package/src/algorithms/search-engine.ts +392 -0
  420. package/src/algorithms/search-ranking.spec.ts +293 -0
  421. package/src/algorithms/search-ranking.ts +407 -0
  422. package/src/algorithms/spaced-repetition.spec.ts +510 -0
  423. package/src/algorithms/spaced-repetition.ts +238 -0
  424. package/src/algorithms/vector-search-engine.ts +505 -0
  425. package/src/client/index.spec.ts +427 -0
  426. package/src/client/index.ts +222 -0
  427. package/src/config/index.spec.ts +339 -0
  428. package/src/config/index.ts +106 -0
  429. package/src/database/init.spec.ts +239 -0
  430. package/src/database/init.ts +130 -0
  431. package/src/database/migrate.spec.ts +293 -0
  432. package/src/database/migrate.ts +94 -0
  433. package/src/database/migrations/001_add_embedding_metadata.sql +29 -0
  434. package/src/database/schema.sql +159 -0
  435. package/src/npm-client/context-injector.spec.ts +335 -0
  436. package/src/npm-client/context-injector.ts +412 -0
  437. package/src/npm-client/index.spec.ts +108 -0
  438. package/src/npm-client/index.ts +96 -0
  439. package/src/npm-client/memento-client.spec.ts +549 -0
  440. package/src/npm-client/memento-client.ts +501 -0
  441. package/src/npm-client/memory-manager.spec.ts +374 -0
  442. package/src/npm-client/memory-manager.ts +414 -0
  443. package/src/npm-client/types.spec.ts +427 -0
  444. package/src/npm-client/types.ts +296 -0
  445. package/src/npm-client/utils.spec.ts +355 -0
  446. package/src/npm-client/utils.ts +423 -0
  447. package/src/scripts/copy-assets.js +37 -0
  448. package/src/server/http-server.spec.ts +648 -0
  449. package/src/server/http-server.ts +1030 -0
  450. package/src/server/index-backup.ts +875 -0
  451. package/src/server/index-refactored.ts +237 -0
  452. package/src/server/index.spec.ts +281 -0
  453. package/src/server/index.ts +347 -0
  454. package/src/server/simple-mcp-server.spec.ts +207 -0
  455. package/src/server/simple-mcp-server.ts +173 -0
  456. package/src/services/async-optimizer.spec.ts +569 -0
  457. package/src/services/async-optimizer.ts +484 -0
  458. package/src/services/batch-scheduler.ts +759 -0
  459. package/src/services/cache-service.spec.ts +372 -0
  460. package/src/services/cache-service.ts +434 -0
  461. package/src/services/database-optimizer.spec.ts +344 -0
  462. package/src/services/database-optimizer.ts +450 -0
  463. package/src/services/embedding-provider-factory.ts +173 -0
  464. package/src/services/embedding-service.spec.ts +342 -0
  465. package/src/services/embedding-service.ts +333 -0
  466. package/src/services/error-logging-service.spec.ts +416 -0
  467. package/src/services/error-logging-service.ts +383 -0
  468. package/src/services/forgetting-policy-service.spec.ts +140 -0
  469. package/src/services/forgetting-policy-service.ts +334 -0
  470. package/src/services/gemini-embedding-service.spec.ts +463 -0
  471. package/src/services/gemini-embedding-service.ts +283 -0
  472. package/src/services/lightweight-embedding-service.spec.ts +458 -0
  473. package/src/services/lightweight-embedding-service.ts +324 -0
  474. package/src/services/memory-embedding-service.spec.ts +417 -0
  475. package/src/services/memory-embedding-service.ts +289 -0
  476. package/src/services/minilm-embedding-service.spec.ts +104 -0
  477. package/src/services/minilm-embedding-service.ts +262 -0
  478. package/src/services/performance-alert-service.spec.ts +517 -0
  479. package/src/services/performance-alert-service.ts +477 -0
  480. package/src/services/performance-monitor.spec.ts +401 -0
  481. package/src/services/performance-monitor.ts +532 -0
  482. package/src/services/performance-monitoring-integration.spec.ts +478 -0
  483. package/src/services/performance-monitoring-integration.ts.bak +276 -0
  484. package/src/services/unified-embedding-service.spec.ts +224 -0
  485. package/src/services/unified-embedding-service.ts +255 -0
  486. package/src/test/debug-http-v2.ts +30 -0
  487. package/src/test/embedding-integration-test.spec.ts +295 -0
  488. package/src/test/embedding-integration-test.ts +295 -0
  489. package/src/test/embedding-performance-benchmark.spec.ts +354 -0
  490. package/src/test/embedding-performance-benchmark.ts +312 -0
  491. package/src/test/performance-benchmark.ts +565 -0
  492. package/src/test/test-alerts-direct.ts +136 -0
  493. package/src/test/test-batch-scheduler-simple.spec.ts +122 -0
  494. package/src/test/test-batch-scheduler.spec.ts +453 -0
  495. package/src/test/test-batch-scheduler.ts +182 -0
  496. package/src/test/test-client.ts +97 -0
  497. package/src/test/test-embedding.ts +153 -0
  498. package/src/test/test-error-handling.spec.ts +575 -0
  499. package/src/test/test-error-logging.ts +117 -0
  500. package/src/test/test-forgetting.ts +162 -0
  501. package/src/test/test-gemini-embedding.ts +159 -0
  502. package/src/test/test-http-server-v2-simple.ts +147 -0
  503. package/src/test/test-http-server-v2.ts +586 -0
  504. package/src/test/test-hybrid-search-engine.spec.ts +521 -0
  505. package/src/test/test-integration-fixed.spec.ts +612 -0
  506. package/src/test/test-integration.spec.ts +463 -0
  507. package/src/test/test-lightweight-embedding.ts +208 -0
  508. package/src/test/test-m1-completion.spec.ts +614 -0
  509. package/src/test/test-m1-completion.ts +141 -0
  510. package/src/test/test-m1-integration.spec.ts +514 -0
  511. package/src/test/test-memory-injection-prompt.spec.ts +650 -0
  512. package/src/test/test-memory-injection-prompt.ts +391 -0
  513. package/src/test/test-performance-alerts.ts +125 -0
  514. package/src/test/test-performance-monitor-updates.spec.ts +490 -0
  515. package/src/test/test-performance-monitor.spec.ts +284 -0
  516. package/src/test/test-performance-monitor.ts +228 -0
  517. package/src/test/test-performance-monitoring.ts +171 -0
  518. package/src/test/test-search.ts +151 -0
  519. package/src/test/test-simple-alerts.ts +136 -0
  520. package/src/test/test-vector-search-engine.spec.ts +408 -0
  521. package/src/test/test-vector-search-engine.ts +303 -0
  522. package/src/tools/base-tool.ts +189 -0
  523. package/src/tools/cleanup-memory-tool.ts +77 -0
  524. package/src/tools/database-optimize-tool.ts +79 -0
  525. package/src/tools/error-stats.ts +119 -0
  526. package/src/tools/forget-tool.spec.ts +613 -0
  527. package/src/tools/forget-tool.ts +454 -0
  528. package/src/tools/forgetting-stats-tool.ts +47 -0
  529. package/src/tools/index.ts +71 -0
  530. package/src/tools/memory-injection-prompt.ts +257 -0
  531. package/src/tools/performance-alerts.ts +226 -0
  532. package/src/tools/performance-stats-tool.ts +48 -0
  533. package/src/tools/pin-tool.spec.ts +497 -0
  534. package/src/tools/pin-tool.ts +277 -0
  535. package/src/tools/recall-tool.spec.ts +475 -0
  536. package/src/tools/recall-tool.ts +389 -0
  537. package/src/tools/remember-tool.spec.ts +469 -0
  538. package/src/tools/remember-tool.ts +112 -0
  539. package/src/tools/resolve-error.ts +69 -0
  540. package/src/tools/tool-registry.ts +417 -0
  541. package/src/tools/types.ts +63 -0
  542. package/src/tools/unpin-tool.spec.ts +549 -0
  543. package/src/tools/unpin-tool.ts +306 -0
  544. package/src/types/embedding.types.ts +78 -0
  545. package/src/types/index.spec.ts +420 -0
  546. package/src/types/index.ts +117 -0
  547. package/src/utils/database.spec.ts +77 -0
  548. package/src/utils/database.ts +458 -0
  549. package/src/utils/stopwords.ts +128 -0
  550. package/start-docker-setup.bat +38 -0
  551. package/static/logo.png +0 -0
  552. package/static/memento_logo.svg +2 -0
  553. package/test-docker.js +103 -0
  554. package/tsconfig.json +46 -0
  555. package/vitest.config.ts +23 -0
@@ -0,0 +1,622 @@
1
+ ---
2
+ globs: "src/services/performance-monitor.ts,src/test/performance-benchmark.ts,src/test-performance-monitoring.ts"
3
+ description: 성능 모니터링 및 벤치마크 개발 규칙
4
+ ---
5
+
6
+ # 성능 모니터링 및 벤치마크 개발 규칙
7
+
8
+ ## 📋 성능 모니터링 시스템
9
+
10
+ ### 현재 구현 상태
11
+ - **성능 모니터링**: `src/services/performance-monitor.ts` (367줄)
12
+ - **성능 벤치마크**: `src/test/performance-benchmark.ts` (497줄)
13
+ - **모니터링 테스트**: `src/test-performance-monitoring.ts` (172줄)
14
+
15
+ ### 핵심 인터페이스
16
+
17
+ ```typescript
18
+ interface PerformanceMetrics {
19
+ database: {
20
+ totalMemories: number;
21
+ memoryByType: Record<string, number>;
22
+ averageMemorySize: number;
23
+ databaseSize: number;
24
+ indexUsage: Record<string, number>;
25
+ queryPerformance: {
26
+ averageQueryTime: number;
27
+ slowQueries: Array<{ query: string; time: number; count: number }>;
28
+ };
29
+ };
30
+ search: {
31
+ totalSearches: number;
32
+ averageSearchTime: number;
33
+ searchByType: Record<string, number>;
34
+ cacheHitRate: number;
35
+ embeddingSearchRate: number;
36
+ };
37
+ memory: {
38
+ usage: number;
39
+ heapUsed: number;
40
+ heapTotal: number;
41
+ external: number;
42
+ rss: number;
43
+ };
44
+ system: {
45
+ uptime: number;
46
+ cpuUsage: number;
47
+ loadAverage: number[];
48
+ diskUsage: number;
49
+ };
50
+ }
51
+ ```
52
+
53
+ ## 📊 성능 모니터링 서비스
54
+
55
+ ### 1. 메트릭 수집
56
+
57
+ ```typescript
58
+ export class PerformanceMonitor {
59
+ private metrics: PerformanceMetrics;
60
+ private collectionInterval: number = 5000; // 5초
61
+ private intervalId: NodeJS.Timeout | null = null;
62
+ private db: sqlite3.Database;
63
+
64
+ constructor(db: sqlite3.Database) {
65
+ this.db = db;
66
+ this.metrics = this.initializeMetrics();
67
+ }
68
+
69
+ startMonitoring(): void {
70
+ if (this.intervalId) return;
71
+
72
+ this.intervalId = setInterval(() => {
73
+ this.collectMetrics();
74
+ }, this.collectionInterval);
75
+ }
76
+
77
+ private async collectMetrics(): Promise<void> {
78
+ try {
79
+ // 데이터베이스 메트릭 수집
80
+ this.metrics.database = await this.collectDatabaseMetrics();
81
+
82
+ // 검색 메트릭 수집
83
+ this.metrics.search = await this.collectSearchMetrics();
84
+
85
+ // 메모리 메트릭 수집
86
+ this.metrics.memory = await this.collectMemoryMetrics();
87
+
88
+ // 시스템 메트릭 수집
89
+ this.metrics.system = await this.collectSystemMetrics();
90
+
91
+ // 임계값 확인
92
+ this.checkThresholds();
93
+ } catch (error) {
94
+ console.error('Failed to collect metrics:', error);
95
+ }
96
+ }
97
+ }
98
+ ```
99
+
100
+ ### 2. 데이터베이스 메트릭 수집
101
+
102
+ ```typescript
103
+ private async collectDatabaseMetrics(): Promise<DatabaseMetrics> {
104
+ const totalMemories = await this.getTotalMemories();
105
+ const memoryByType = await this.getMemoryByType();
106
+ const averageMemorySize = await this.getAverageMemorySize();
107
+ const databaseSize = await this.getDatabaseSize();
108
+ const indexUsage = await this.getIndexUsage();
109
+ const queryPerformance = await this.getQueryPerformance();
110
+
111
+ return {
112
+ totalMemories,
113
+ memoryByType,
114
+ averageMemorySize,
115
+ databaseSize,
116
+ indexUsage,
117
+ queryPerformance
118
+ };
119
+ }
120
+
121
+ private async getTotalMemories(): Promise<number> {
122
+ const result = await this.db.get('SELECT COUNT(*) as count FROM memory_item');
123
+ return result.count;
124
+ }
125
+
126
+ private async getMemoryByType(): Promise<Record<string, number>> {
127
+ const result = await this.db.all(`
128
+ SELECT type, COUNT(*) as count
129
+ FROM memory_item
130
+ GROUP BY type
131
+ `);
132
+
133
+ return result.reduce((acc, row) => {
134
+ acc[row.type] = row.count;
135
+ return acc;
136
+ }, {} as Record<string, number>);
137
+ }
138
+ ```
139
+
140
+ ### 3. 검색 메트릭 수집
141
+
142
+ ```typescript
143
+ private async collectSearchMetrics(): Promise<SearchMetrics> {
144
+ const totalSearches = await this.getTotalSearches();
145
+ const averageSearchTime = await this.getAverageSearchTime();
146
+ const searchByType = await this.getSearchByType();
147
+ const cacheHitRate = await this.getCacheHitRate();
148
+ const embeddingSearchRate = await this.getEmbeddingSearchRate();
149
+
150
+ return {
151
+ totalSearches,
152
+ averageSearchTime,
153
+ searchByType,
154
+ cacheHitRate,
155
+ embeddingSearchRate
156
+ };
157
+ }
158
+
159
+ private async getTotalSearches(): Promise<number> {
160
+ const result = await this.db.get(`
161
+ SELECT COUNT(*) as count
162
+ FROM search_log
163
+ WHERE created_at > datetime('now', '-24 hours')
164
+ `);
165
+ return result.count;
166
+ }
167
+ ```
168
+
169
+ ### 4. 메모리 메트릭 수집
170
+
171
+ ```typescript
172
+ private async collectMemoryMetrics(): Promise<MemoryMetrics> {
173
+ const usage = process.memoryUsage();
174
+
175
+ return {
176
+ usage: usage.heapUsed / usage.heapTotal,
177
+ heapUsed: usage.heapUsed,
178
+ heapTotal: usage.heapTotal,
179
+ external: usage.external,
180
+ rss: usage.rss
181
+ };
182
+ }
183
+ ```
184
+
185
+ ### 5. 시스템 메트릭 수집
186
+
187
+ ```typescript
188
+ private async collectSystemMetrics(): Promise<SystemMetrics> {
189
+ const uptime = process.uptime();
190
+ const cpuUsage = await this.getCpuUsage();
191
+ const loadAverage = await this.getLoadAverage();
192
+ const diskUsage = await this.getDiskUsage();
193
+
194
+ return {
195
+ uptime,
196
+ cpuUsage,
197
+ loadAverage,
198
+ diskUsage
199
+ };
200
+ }
201
+
202
+ private async getCpuUsage(): Promise<number> {
203
+ const startUsage = process.cpuUsage();
204
+ await new Promise(resolve => setTimeout(resolve, 100));
205
+ const endUsage = process.cpuUsage(startUsage);
206
+
207
+ const totalUsage = endUsage.user + endUsage.system;
208
+ const totalTime = 100000; // 100ms in microseconds
209
+ return totalUsage / totalTime;
210
+ }
211
+ ```
212
+
213
+ ## 🚨 임계값 모니터링
214
+
215
+ ### 1. 임계값 설정
216
+
217
+ ```typescript
218
+ interface PerformanceThresholds {
219
+ maxResponseTime: number;
220
+ maxMemoryUsage: number;
221
+ minCacheHitRate: number;
222
+ maxErrorRate: number;
223
+ maxCpuUsage: number;
224
+ maxDiskUsage: number;
225
+ }
226
+
227
+ class PerformanceMonitor {
228
+ private thresholds: PerformanceThresholds = {
229
+ maxResponseTime: 1000, // 1초
230
+ maxMemoryUsage: 0.8, // 80%
231
+ minCacheHitRate: 0.7, // 70%
232
+ maxErrorRate: 0.05, // 5%
233
+ maxCpuUsage: 0.8, // 80%
234
+ maxDiskUsage: 0.9 // 90%
235
+ };
236
+
237
+ setThresholds(thresholds: Partial<PerformanceThresholds>): void {
238
+ this.thresholds = { ...this.thresholds, ...thresholds };
239
+ }
240
+ }
241
+ ```
242
+
243
+ ### 2. 임계값 확인 및 알림
244
+
245
+ ```typescript
246
+ private checkThresholds(): void {
247
+ const alerts: Alert[] = [];
248
+
249
+ // 응답 시간 확인
250
+ if (this.metrics.search.averageSearchTime > this.thresholds.maxResponseTime) {
251
+ alerts.push({
252
+ type: 'performance',
253
+ severity: 'warning',
254
+ message: `Search response time exceeded threshold: ${this.metrics.search.averageSearchTime}ms`,
255
+ timestamp: new Date(),
256
+ value: this.metrics.search.averageSearchTime,
257
+ threshold: this.thresholds.maxResponseTime
258
+ });
259
+ }
260
+
261
+ // 메모리 사용량 확인
262
+ if (this.metrics.memory.usage > this.thresholds.maxMemoryUsage) {
263
+ alerts.push({
264
+ type: 'memory',
265
+ severity: 'critical',
266
+ message: `Memory usage exceeded threshold: ${(this.metrics.memory.usage * 100).toFixed(1)}%`,
267
+ timestamp: new Date(),
268
+ value: this.metrics.memory.usage,
269
+ threshold: this.thresholds.maxMemoryUsage
270
+ });
271
+ }
272
+
273
+ // 캐시 히트율 확인
274
+ if (this.metrics.search.cacheHitRate < this.thresholds.minCacheHitRate) {
275
+ alerts.push({
276
+ type: 'cache',
277
+ severity: 'warning',
278
+ message: `Cache hit rate below threshold: ${(this.metrics.search.cacheHitRate * 100).toFixed(1)}%`,
279
+ timestamp: new Date(),
280
+ value: this.metrics.search.cacheHitRate,
281
+ threshold: this.thresholds.minCacheHitRate
282
+ });
283
+ }
284
+
285
+ // 알림 처리
286
+ if (alerts.length > 0) {
287
+ this.handleAlerts(alerts);
288
+ }
289
+ }
290
+ ```
291
+
292
+ ### 3. 알림 처리
293
+
294
+ ```typescript
295
+ private handleAlerts(alerts: Alert[]): void {
296
+ for (const alert of alerts) {
297
+ // 로그 출력
298
+ console.log(`[${alert.severity.toUpperCase()}] ${alert.message}`);
299
+
300
+ // 심각한 알림은 즉시 처리
301
+ if (alert.severity === 'critical') {
302
+ this.handleCriticalAlert(alert);
303
+ }
304
+
305
+ // 알림 히스토리 저장
306
+ this.saveAlert(alert);
307
+ }
308
+ }
309
+
310
+ private handleCriticalAlert(alert: Alert): void {
311
+ // 메모리 사용량이 임계값을 초과하면 가비지 컬렉션 강제 실행
312
+ if (alert.type === 'memory') {
313
+ if (global.gc) {
314
+ global.gc();
315
+ }
316
+ }
317
+
318
+ // 추가적인 복구 작업 수행
319
+ this.performRecoveryActions(alert);
320
+ }
321
+ ```
322
+
323
+ ## 📈 성능 리포트 생성
324
+
325
+ ### 1. 리포트 생성
326
+
327
+ ```typescript
328
+ async generateReport(timeRange: string = '24h'): Promise<PerformanceReport> {
329
+ const startTime = this.getTimeRangeStart(timeRange);
330
+ const endTime = new Date();
331
+
332
+ const report: PerformanceReport = {
333
+ timeRange: { start: startTime, end: endTime },
334
+ summary: {
335
+ totalRequests: this.metrics.search.totalSearches,
336
+ averageResponseTime: this.metrics.search.averageSearchTime,
337
+ cacheHitRate: this.metrics.search.cacheHitRate,
338
+ errorRate: this.calculateErrorRate(),
339
+ memoryUsage: this.metrics.memory.usage,
340
+ uptime: this.metrics.system.uptime
341
+ },
342
+ trends: await this.analyzeTrends(startTime, endTime),
343
+ recommendations: await this.generateRecommendations(),
344
+ alerts: this.getRecentAlerts(startTime, endTime)
345
+ };
346
+
347
+ return report;
348
+ }
349
+ ```
350
+
351
+ ### 2. 트렌드 분석
352
+
353
+ ```typescript
354
+ private async analyzeTrends(startTime: Date, endTime: Date): Promise<TrendAnalysis> {
355
+ const metrics = await this.getHistoricalMetrics(startTime, endTime);
356
+
357
+ return {
358
+ responseTime: this.calculateTrend(metrics, 'averageSearchTime'),
359
+ memoryUsage: this.calculateTrend(metrics, 'memoryUsage'),
360
+ cacheHitRate: this.calculateTrend(metrics, 'cacheHitRate'),
361
+ throughput: this.calculateTrend(metrics, 'totalSearches')
362
+ };
363
+ }
364
+
365
+ private calculateTrend(metrics: any[], field: string): TrendDirection {
366
+ if (metrics.length < 2) return 'stable';
367
+
368
+ const values = metrics.map(m => m[field]);
369
+ const firstHalf = values.slice(0, Math.floor(values.length / 2));
370
+ const secondHalf = values.slice(Math.floor(values.length / 2));
371
+
372
+ const firstAvg = firstHalf.reduce((a, b) => a + b, 0) / firstHalf.length;
373
+ const secondAvg = secondHalf.reduce((a, b) => a + b, 0) / secondHalf.length;
374
+
375
+ const change = (secondAvg - firstAvg) / firstAvg;
376
+
377
+ if (Math.abs(change) < 0.05) return 'stable';
378
+ return change > 0 ? 'increasing' : 'decreasing';
379
+ }
380
+ ```
381
+
382
+ ### 3. 최적화 추천
383
+
384
+ ```typescript
385
+ private async generateRecommendations(): Promise<OptimizationRecommendation[]> {
386
+ const recommendations: OptimizationRecommendation[] = [];
387
+
388
+ // 응답 시간이 느린 경우
389
+ if (this.metrics.search.averageSearchTime > 500) {
390
+ recommendations.push({
391
+ type: 'performance',
392
+ priority: 'high',
393
+ title: 'Optimize search performance',
394
+ description: 'Average search time is above 500ms. Consider optimizing queries or adding indexes.',
395
+ actions: [
396
+ 'Review slow queries in query performance metrics',
397
+ 'Add missing database indexes',
398
+ 'Consider implementing query caching'
399
+ ]
400
+ });
401
+ }
402
+
403
+ // 캐시 히트율이 낮은 경우
404
+ if (this.metrics.search.cacheHitRate < 0.5) {
405
+ recommendations.push({
406
+ type: 'cache',
407
+ priority: 'medium',
408
+ title: 'Improve cache hit rate',
409
+ description: 'Cache hit rate is below 50%. Consider adjusting cache TTL or size.',
410
+ actions: [
411
+ 'Increase cache TTL for frequently accessed data',
412
+ 'Review cache invalidation strategy',
413
+ 'Consider increasing cache size'
414
+ ]
415
+ });
416
+ }
417
+
418
+ // 메모리 사용량이 높은 경우
419
+ if (this.metrics.memory.usage > 0.7) {
420
+ recommendations.push({
421
+ type: 'memory',
422
+ priority: 'high',
423
+ title: 'Optimize memory usage',
424
+ description: 'Memory usage is above 70%. Consider optimizing data structures or implementing cleanup.',
425
+ actions: [
426
+ 'Review memory-intensive operations',
427
+ 'Implement periodic cleanup routines',
428
+ 'Consider data compression or archiving'
429
+ ]
430
+ });
431
+ }
432
+
433
+ return recommendations;
434
+ }
435
+ ```
436
+
437
+ ## 🧪 성능 벤치마크
438
+
439
+ ### 1. 벤치마크 클래스
440
+
441
+ ```typescript
442
+ export class PerformanceBenchmark {
443
+ private client: any;
444
+ private performanceMonitor: PerformanceMonitor | null = null;
445
+ private results: BenchmarkResult[] = [];
446
+
447
+ constructor(client: any) {
448
+ this.client = client;
449
+ }
450
+
451
+ async runComprehensiveBenchmark(): Promise<BenchmarkResult[]> {
452
+ console.log('🚀 Starting comprehensive performance benchmark...');
453
+
454
+ const results: BenchmarkResult[] = [];
455
+
456
+ // 1. 메모리 저장 벤치마크
457
+ results.push(await this.benchmarkMemoryStorage());
458
+
459
+ // 2. 검색 성능 벤치마크
460
+ results.push(await this.benchmarkSearchPerformance());
461
+
462
+ // 3. 캐시 성능 벤치마크
463
+ results.push(await this.benchmarkCachePerformance());
464
+
465
+ // 4. 동시성 벤치마크
466
+ results.push(await this.benchmarkConcurrency());
467
+
468
+ // 5. 메모리 사용량 벤치마크
469
+ results.push(await this.benchmarkMemoryUsage());
470
+
471
+ this.results = results;
472
+ return results;
473
+ }
474
+ }
475
+ ```
476
+
477
+ ### 2. 메모리 저장 벤치마크
478
+
479
+ ```typescript
480
+ private async benchmarkMemoryStorage(): Promise<BenchmarkResult> {
481
+ const testName = 'Memory Storage';
482
+ const iterations = 1000;
483
+ const times: number[] = [];
484
+ const errors: string[] = [];
485
+
486
+ console.log(`📝 Running ${testName} benchmark (${iterations} iterations)...`);
487
+
488
+ const memoryBefore = process.memoryUsage();
489
+
490
+ for (let i = 0; i < iterations; i++) {
491
+ try {
492
+ const startTime = Date.now();
493
+
494
+ await this.client.remember({
495
+ content: `Benchmark memory ${i}: Testing memory storage performance`,
496
+ type: 'episodic',
497
+ tags: ['benchmark', 'storage'],
498
+ importance: 0.5
499
+ });
500
+
501
+ const endTime = Date.now();
502
+ times.push(endTime - startTime);
503
+ } catch (error) {
504
+ errors.push(`Iteration ${i}: ${error.message}`);
505
+ }
506
+ }
507
+
508
+ const memoryAfter = process.memoryUsage();
509
+
510
+ return this.calculateBenchmarkResult(
511
+ testName,
512
+ iterations,
513
+ times,
514
+ errors,
515
+ memoryBefore,
516
+ memoryAfter
517
+ );
518
+ }
519
+ ```
520
+
521
+ ### 3. 검색 성능 벤치마크
522
+
523
+ ```typescript
524
+ private async benchmarkSearchPerformance(): Promise<BenchmarkResult> {
525
+ const testName = 'Search Performance';
526
+ const iterations = 500;
527
+ const times: number[] = [];
528
+ const errors: string[] = [];
529
+
530
+ console.log(`🔍 Running ${testName} benchmark (${iterations} iterations)...`);
531
+
532
+ const memoryBefore = process.memoryUsage();
533
+
534
+ for (let i = 0; i < iterations; i++) {
535
+ try {
536
+ const startTime = Date.now();
537
+
538
+ await this.client.recall({
539
+ query: `benchmark search ${i}`,
540
+ limit: 10
541
+ });
542
+
543
+ const endTime = Date.now();
544
+ times.push(endTime - startTime);
545
+ } catch (error) {
546
+ errors.push(`Iteration ${i}: ${error.message}`);
547
+ }
548
+ }
549
+
550
+ const memoryAfter = process.memoryUsage();
551
+
552
+ return this.calculateBenchmarkResult(
553
+ testName,
554
+ iterations,
555
+ times,
556
+ errors,
557
+ memoryBefore,
558
+ memoryAfter
559
+ );
560
+ }
561
+ ```
562
+
563
+ ### 4. 동시성 벤치마크
564
+
565
+ ```typescript
566
+ private async benchmarkConcurrency(): Promise<BenchmarkResult> {
567
+ const testName = 'Concurrency';
568
+ const concurrentUsers = 10;
569
+ const requestsPerUser = 50;
570
+ const times: number[] = [];
571
+ const errors: string[] = [];
572
+
573
+ console.log(`👥 Running ${testName} benchmark (${concurrentUsers} users, ${requestsPerUser} requests each)...`);
574
+
575
+ const memoryBefore = process.memoryUsage();
576
+ const startTime = Date.now();
577
+
578
+ const userPromises = Array.from({ length: concurrentUsers }, (_, userIndex) =>
579
+ this.simulateUser(userIndex, requestsPerUser, times, errors)
580
+ );
581
+
582
+ await Promise.all(userPromises);
583
+
584
+ const endTime = Date.now();
585
+ const memoryAfter = process.memoryUsage();
586
+
587
+ return this.calculateBenchmarkResult(
588
+ testName,
589
+ concurrentUsers * requestsPerUser,
590
+ times,
591
+ errors,
592
+ memoryBefore,
593
+ memoryAfter
594
+ );
595
+ }
596
+ ```
597
+
598
+ ## 📋 개발 체크리스트
599
+
600
+ ### 성능 모니터링
601
+ - [ ] 메트릭 수집 시스템 구현
602
+ - [ ] 임계값 모니터링 구현
603
+ - [ ] 알림 시스템 구현
604
+ - [ ] 성능 리포트 생성 구현
605
+ - [ ] 트렌드 분석 구현
606
+ - [ ] 최적화 추천 시스템 구현
607
+
608
+ ### 성능 벤치마크
609
+ - [ ] 종합 벤치마크 구현
610
+ - [ ] 메모리 저장 벤치마크 구현
611
+ - [ ] 검색 성능 벤치마크 구현
612
+ - [ ] 캐시 성능 벤치마크 구현
613
+ - [ ] 동시성 벤치마크 구현
614
+ - [ ] 메모리 사용량 벤치마크 구현
615
+
616
+ ### 모니터링 테스트
617
+ - [ ] 모니터링 도구 테스트 구현
618
+ - [ ] 통합 테스트 구현
619
+ - [ ] 실시간 모니터링 테스트 구현
620
+ - [ ] 성능 임계값 테스트 구현
621
+ - [ ] 알림 시스템 테스트 구현
622
+ - [ ] 리포트 생성 테스트 구현