memento-mcp-server 1.6.0 → 1.7.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (560) hide show
  1. package/INSTALL.en.md +303 -303
  2. package/INSTALL.md +303 -303
  3. package/README.en.md +331 -330
  4. package/README.md +432 -432
  5. package/dist/algorithms/hybrid-search-engine.d.ts +114 -44
  6. package/dist/algorithms/hybrid-search-engine.d.ts.map +1 -1
  7. package/dist/algorithms/hybrid-search-engine.js +261 -235
  8. package/dist/algorithms/hybrid-search-engine.js.map +1 -1
  9. package/dist/algorithms/search-engine.d.ts +2 -14
  10. package/dist/algorithms/search-engine.d.ts.map +1 -1
  11. package/dist/algorithms/search-engine.js +43 -35
  12. package/dist/algorithms/search-engine.js.map +1 -1
  13. package/dist/algorithms/vector-search-engine-migration.d.ts +67 -0
  14. package/dist/algorithms/vector-search-engine-migration.d.ts.map +1 -0
  15. package/dist/algorithms/vector-search-engine-migration.js +196 -0
  16. package/dist/algorithms/vector-search-engine-migration.js.map +1 -0
  17. package/dist/algorithms/vector-search-engine-refactored.d.ts +56 -0
  18. package/dist/algorithms/vector-search-engine-refactored.d.ts.map +1 -0
  19. package/dist/algorithms/vector-search-engine-refactored.js +101 -0
  20. package/dist/algorithms/vector-search-engine-refactored.js.map +1 -0
  21. package/dist/algorithms/vector-search-engine.d.ts +9 -2
  22. package/dist/algorithms/vector-search-engine.d.ts.map +1 -1
  23. package/dist/algorithms/vector-search-engine.js +245 -121
  24. package/dist/algorithms/vector-search-engine.js.map +1 -1
  25. package/dist/client/index.d.ts.map +1 -1
  26. package/dist/client/index.js +34 -11
  27. package/dist/client/index.js.map +1 -1
  28. package/dist/config/environment.d.ts +26 -0
  29. package/dist/config/environment.d.ts.map +1 -0
  30. package/dist/config/environment.js +103 -0
  31. package/dist/config/environment.js.map +1 -0
  32. package/dist/config/index.d.ts.map +1 -1
  33. package/dist/config/index.js +29 -50
  34. package/dist/config/index.js.map +1 -1
  35. package/dist/config/vector-search.config.d.ts +25 -0
  36. package/dist/config/vector-search.config.d.ts.map +1 -0
  37. package/dist/config/vector-search.config.js +40 -0
  38. package/dist/config/vector-search.config.js.map +1 -0
  39. package/dist/database/init.d.ts.map +1 -1
  40. package/dist/database/init.js +154 -17
  41. package/dist/database/init.js.map +1 -1
  42. package/dist/database/migrate.d.ts +2 -1
  43. package/dist/database/migrate.d.ts.map +1 -1
  44. package/dist/database/migrate.js +191 -18
  45. package/dist/database/migrate.js.map +1 -1
  46. package/dist/database/schema.sql +234 -159
  47. package/dist/factories/hybrid-search.factory.d.ts +20 -0
  48. package/dist/factories/hybrid-search.factory.d.ts.map +1 -0
  49. package/dist/factories/hybrid-search.factory.js +57 -0
  50. package/dist/factories/hybrid-search.factory.js.map +1 -0
  51. package/dist/factories/spaced-repetition.factory.d.ts +48 -0
  52. package/dist/factories/spaced-repetition.factory.d.ts.map +1 -0
  53. package/dist/factories/spaced-repetition.factory.js +187 -0
  54. package/dist/factories/spaced-repetition.factory.js.map +1 -0
  55. package/dist/factories/vector-search.factory.d.ts +25 -0
  56. package/dist/factories/vector-search.factory.d.ts.map +1 -0
  57. package/dist/factories/vector-search.factory.js +47 -0
  58. package/dist/factories/vector-search.factory.js.map +1 -0
  59. package/dist/interfaces/database.interface.d.ts +36 -0
  60. package/dist/interfaces/database.interface.d.ts.map +1 -0
  61. package/dist/interfaces/database.interface.js +6 -0
  62. package/dist/interfaces/database.interface.js.map +1 -0
  63. package/dist/interfaces/spaced-repetition.interface.d.ts +63 -0
  64. package/dist/interfaces/spaced-repetition.interface.d.ts.map +1 -0
  65. package/dist/interfaces/spaced-repetition.interface.js +6 -0
  66. package/dist/interfaces/spaced-repetition.interface.js.map +1 -0
  67. package/dist/repositories/vector-performance.repository.d.ts +25 -0
  68. package/dist/repositories/vector-performance.repository.d.ts.map +1 -0
  69. package/dist/repositories/vector-performance.repository.js +134 -0
  70. package/dist/repositories/vector-performance.repository.js.map +1 -0
  71. package/dist/repositories/vector-search.repository.d.ts +43 -0
  72. package/dist/repositories/vector-search.repository.d.ts.map +1 -0
  73. package/dist/repositories/vector-search.repository.js +377 -0
  74. package/dist/repositories/vector-search.repository.js.map +1 -0
  75. package/dist/server/http-server.d.ts.map +1 -1
  76. package/dist/server/http-server.js +25 -24
  77. package/dist/server/http-server.js.map +1 -1
  78. package/dist/server/index.d.ts +1 -0
  79. package/dist/server/index.d.ts.map +1 -1
  80. package/dist/server/index.js +3 -1
  81. package/dist/server/index.js.map +1 -1
  82. package/dist/services/alert-notification-service.d.ts +16 -0
  83. package/dist/services/alert-notification-service.d.ts.map +1 -0
  84. package/dist/services/alert-notification-service.js +44 -0
  85. package/dist/services/alert-notification-service.js.map +1 -0
  86. package/dist/services/async-optimizer.d.ts +62 -8
  87. package/dist/services/async-optimizer.d.ts.map +1 -1
  88. package/dist/services/async-optimizer.js +137 -8
  89. package/dist/services/async-optimizer.js.map +1 -1
  90. package/dist/services/batch-scheduler.d.ts +6 -0
  91. package/dist/services/batch-scheduler.d.ts.map +1 -1
  92. package/dist/services/batch-scheduler.js +59 -19
  93. package/dist/services/batch-scheduler.js.map +1 -1
  94. package/dist/services/cache-service.d.ts +32 -0
  95. package/dist/services/cache-service.d.ts.map +1 -1
  96. package/dist/services/cache-service.js +81 -6
  97. package/dist/services/cache-service.js.map +1 -1
  98. package/dist/services/database-optimizer.js +63 -63
  99. package/dist/services/database-optimizer.js.map +1 -1
  100. package/dist/services/embedding-migration-service.d.ts +24 -0
  101. package/dist/services/embedding-migration-service.d.ts.map +1 -0
  102. package/dist/services/embedding-migration-service.js +360 -0
  103. package/dist/services/embedding-migration-service.js.map +1 -0
  104. package/dist/services/embedding-provider-factory.d.ts +12 -5
  105. package/dist/services/embedding-provider-factory.d.ts.map +1 -1
  106. package/dist/services/embedding-provider-factory.js +107 -26
  107. package/dist/services/embedding-provider-factory.js.map +1 -1
  108. package/dist/services/forgetting-policy-service.js +17 -17
  109. package/dist/services/gemini-embedding-service.d.ts +1 -1
  110. package/dist/services/gemini-embedding-service.d.ts.map +1 -1
  111. package/dist/services/gemini-embedding-service.js +25 -18
  112. package/dist/services/gemini-embedding-service.js.map +1 -1
  113. package/dist/services/memory-embedding-service.d.ts +8 -0
  114. package/dist/services/memory-embedding-service.d.ts.map +1 -1
  115. package/dist/services/memory-embedding-service.js +180 -71
  116. package/dist/services/memory-embedding-service.js.map +1 -1
  117. package/dist/services/migration-history-service.d.ts +14 -0
  118. package/dist/services/migration-history-service.d.ts.map +1 -0
  119. package/dist/services/migration-history-service.js +270 -0
  120. package/dist/services/migration-history-service.js.map +1 -0
  121. package/dist/services/migration-monitor-service.d.ts +24 -0
  122. package/dist/services/migration-monitor-service.d.ts.map +1 -0
  123. package/dist/services/migration-monitor-service.js +93 -0
  124. package/dist/services/migration-monitor-service.js.map +1 -0
  125. package/dist/services/model-availability-service.d.ts +22 -0
  126. package/dist/services/model-availability-service.d.ts.map +1 -0
  127. package/dist/services/model-availability-service.js +140 -0
  128. package/dist/services/model-availability-service.js.map +1 -0
  129. package/dist/services/openai-embedding-service.d.ts +36 -0
  130. package/dist/services/openai-embedding-service.d.ts.map +1 -0
  131. package/dist/services/openai-embedding-service.js +192 -0
  132. package/dist/services/openai-embedding-service.js.map +1 -0
  133. package/dist/services/performance-monitor.d.ts +154 -10
  134. package/dist/services/performance-monitor.d.ts.map +1 -1
  135. package/dist/services/performance-monitor.js +446 -60
  136. package/dist/services/performance-monitor.js.map +1 -1
  137. package/dist/services/spaced-repetition/interval-calculation.service.d.ts +38 -0
  138. package/dist/services/spaced-repetition/interval-calculation.service.d.ts.map +1 -0
  139. package/dist/services/spaced-repetition/interval-calculation.service.js +105 -0
  140. package/dist/services/spaced-repetition/interval-calculation.service.js.map +1 -0
  141. package/dist/services/spaced-repetition/optimal-interval.service.d.ts +56 -0
  142. package/dist/services/spaced-repetition/optimal-interval.service.d.ts.map +1 -0
  143. package/dist/services/spaced-repetition/optimal-interval.service.js +163 -0
  144. package/dist/services/spaced-repetition/optimal-interval.service.js.map +1 -0
  145. package/dist/services/spaced-repetition/performance-analysis.service.d.ts +48 -0
  146. package/dist/services/spaced-repetition/performance-analysis.service.d.ts.map +1 -0
  147. package/dist/services/spaced-repetition/performance-analysis.service.js +174 -0
  148. package/dist/services/spaced-repetition/performance-analysis.service.js.map +1 -0
  149. package/dist/services/spaced-repetition/priority-calculation.service.d.ts +53 -0
  150. package/dist/services/spaced-repetition/priority-calculation.service.d.ts.map +1 -0
  151. package/dist/services/spaced-repetition/priority-calculation.service.js +161 -0
  152. package/dist/services/spaced-repetition/priority-calculation.service.js.map +1 -0
  153. package/dist/services/spaced-repetition/recall-probability.service.d.ts +36 -0
  154. package/dist/services/spaced-repetition/recall-probability.service.d.ts.map +1 -0
  155. package/dist/services/spaced-repetition/recall-probability.service.js +88 -0
  156. package/dist/services/spaced-repetition/recall-probability.service.js.map +1 -0
  157. package/dist/services/spaced-repetition/review-scheduling.service.d.ts +43 -0
  158. package/dist/services/spaced-repetition/review-scheduling.service.d.ts.map +1 -0
  159. package/dist/services/spaced-repetition/review-scheduling.service.js +130 -0
  160. package/dist/services/spaced-repetition/review-scheduling.service.js.map +1 -0
  161. package/dist/services/spaced-repetition/spaced-repetition-container.d.ts +69 -0
  162. package/dist/services/spaced-repetition/spaced-repetition-container.d.ts.map +1 -0
  163. package/dist/services/spaced-repetition/spaced-repetition-container.js +136 -0
  164. package/dist/services/spaced-repetition/spaced-repetition-container.js.map +1 -0
  165. package/dist/services/unified-embedding-service.d.ts +3 -0
  166. package/dist/services/unified-embedding-service.d.ts.map +1 -1
  167. package/dist/services/unified-embedding-service.js +58 -62
  168. package/dist/services/unified-embedding-service.js.map +1 -1
  169. package/dist/services/vector-compatibility-service.d.ts +68 -0
  170. package/dist/services/vector-compatibility-service.d.ts.map +1 -0
  171. package/dist/services/vector-compatibility-service.js +373 -0
  172. package/dist/services/vector-compatibility-service.js.map +1 -0
  173. package/dist/services/vector-search/vector-index-manager.d.ts +27 -0
  174. package/dist/services/vector-search/vector-index-manager.d.ts.map +1 -0
  175. package/dist/services/vector-search/vector-index-manager.js +66 -0
  176. package/dist/services/vector-search/vector-index-manager.js.map +1 -0
  177. package/dist/services/vector-search/vector-performance-tester.d.ts +30 -0
  178. package/dist/services/vector-search/vector-performance-tester.d.ts.map +1 -0
  179. package/dist/services/vector-search/vector-performance-tester.js +87 -0
  180. package/dist/services/vector-search/vector-performance-tester.js.map +1 -0
  181. package/dist/services/vector-search/vector-search-container.d.ts +41 -0
  182. package/dist/services/vector-search/vector-search-container.d.ts.map +1 -0
  183. package/dist/services/vector-search/vector-search-container.js +74 -0
  184. package/dist/services/vector-search/vector-search-container.js.map +1 -0
  185. package/dist/services/vector-search/vector-search-facade.d.ts +63 -0
  186. package/dist/services/vector-search/vector-search-facade.d.ts.map +1 -0
  187. package/dist/services/vector-search/vector-search-facade.js +91 -0
  188. package/dist/services/vector-search/vector-search-facade.js.map +1 -0
  189. package/dist/services/vector-search/vector-search-result-normalizer.d.ts +6 -0
  190. package/dist/services/vector-search/vector-search-result-normalizer.d.ts.map +1 -0
  191. package/dist/services/vector-search/vector-search-result-normalizer.js +65 -0
  192. package/dist/services/vector-search/vector-search-result-normalizer.js.map +1 -0
  193. package/dist/services/vector-search/vector-search.service.d.ts +33 -0
  194. package/dist/services/vector-search/vector-search.service.d.ts.map +1 -0
  195. package/dist/services/vector-search/vector-search.service.js +149 -0
  196. package/dist/services/vector-search/vector-search.service.js.map +1 -0
  197. package/dist/tools/forget-tool.js +14 -14
  198. package/dist/tools/pin-tool.js +14 -14
  199. package/dist/tools/unpin-tool.js +21 -21
  200. package/dist/types/alerts.types.d.ts +26 -0
  201. package/dist/types/alerts.types.d.ts.map +1 -0
  202. package/dist/types/alerts.types.js +2 -0
  203. package/dist/types/alerts.types.js.map +1 -0
  204. package/dist/types/embedding-provider-monitoring.types.d.ts +24 -0
  205. package/dist/types/embedding-provider-monitoring.types.d.ts.map +1 -0
  206. package/dist/types/embedding-provider-monitoring.types.js +2 -0
  207. package/dist/types/embedding-provider-monitoring.types.js.map +1 -0
  208. package/dist/types/embedding.types.d.ts +36 -1
  209. package/dist/types/embedding.types.d.ts.map +1 -1
  210. package/dist/types/migration.types.d.ts +131 -0
  211. package/dist/types/migration.types.d.ts.map +1 -0
  212. package/dist/types/migration.types.js +6 -0
  213. package/dist/types/migration.types.js.map +1 -0
  214. package/dist/types/spaced-repetition.types.d.ts +61 -0
  215. package/dist/types/spaced-repetition.types.d.ts.map +1 -0
  216. package/dist/types/spaced-repetition.types.js +6 -0
  217. package/dist/types/spaced-repetition.types.js.map +1 -0
  218. package/dist/types/vector-search.types.d.ts +96 -0
  219. package/dist/types/vector-search.types.d.ts.map +1 -0
  220. package/dist/types/vector-search.types.js +2 -0
  221. package/dist/types/vector-search.types.js.map +1 -0
  222. package/dist/utils/configuration-validator.d.ts +23 -0
  223. package/dist/utils/configuration-validator.d.ts.map +1 -0
  224. package/dist/utils/configuration-validator.js +102 -0
  225. package/dist/utils/configuration-validator.js.map +1 -0
  226. package/dist/utils/database.d.ts.map +1 -1
  227. package/dist/utils/database.js +101 -95
  228. package/dist/utils/database.js.map +1 -1
  229. package/dist/utils/environment-check.d.ts +8 -0
  230. package/dist/utils/environment-check.d.ts.map +1 -0
  231. package/dist/utils/environment-check.js +25 -0
  232. package/dist/utils/environment-check.js.map +1 -0
  233. package/dist/utils/logger.d.ts +8 -0
  234. package/dist/utils/logger.d.ts.map +1 -0
  235. package/dist/utils/logger.js +33 -0
  236. package/dist/utils/logger.js.map +1 -0
  237. package/package.json +139 -125
  238. package/scripts/auto-setup.js +233 -233
  239. package/scripts/backup-daily.bat +28 -28
  240. package/scripts/backup-embeddings.js +108 -108
  241. package/scripts/check-db-integrity.js +93 -93
  242. package/scripts/debug-embeddings.js +184 -184
  243. package/scripts/direct-sql-migration.sql +36 -36
  244. package/scripts/docker-migration.sh +105 -105
  245. package/scripts/fix-migration.js +93 -93
  246. package/scripts/fix-vector-dimensions.js +206 -206
  247. package/scripts/migrate-embedding-data.js +307 -307
  248. package/scripts/regenerate-embeddings.js +144 -144
  249. package/scripts/restore-legacy.ps1 +60 -60
  250. package/scripts/run-migration.js +122 -122
  251. package/scripts/safe-migration.js +150 -150
  252. package/scripts/simple-migrate.js +41 -41
  253. package/scripts/simple-update.js +123 -123
  254. package/src/database/schema.sql +234 -159
  255. package/.cursor/rules/cache-management.mdc +0 -171
  256. package/.cursor/rules/database-schema.mdc +0 -344
  257. package/.cursor/rules/deployment.mdc +0 -596
  258. package/.cursor/rules/error-logging.mdc +0 -298
  259. package/.cursor/rules/forgetting-algorithms.mdc +0 -426
  260. package/.cursor/rules/http-server.mdc +0 -432
  261. package/.cursor/rules/hybrid-search.mdc +0 -424
  262. package/.cursor/rules/implementation.mdc +0 -369
  263. package/.cursor/rules/lightweight-embedding.mdc +0 -178
  264. package/.cursor/rules/mcp-client-development.mdc +0 -0
  265. package/.cursor/rules/mcp-server-development.mdc +0 -0
  266. package/.cursor/rules/mcp-tools-architecture.mdc +0 -205
  267. package/.cursor/rules/memento-memory-rule.mdc +0 -8
  268. package/.cursor/rules/memento-project-overview.mdc +0 -0
  269. package/.cursor/rules/memory-algorithms.mdc +0 -502
  270. package/.cursor/rules/monitoring.mdc +0 -622
  271. package/.cursor/rules/performance-alerts.mdc +0 -537
  272. package/.cursor/rules/performance-monitoring.mdc +0 -345
  273. package/.cursor/rules/performance-optimization.mdc +0 -563
  274. package/.cursor/rules/project-structure.mdc +0 -310
  275. package/.cursor/rules/testing.mdc +0 -473
  276. package/.dockerignore +0 -15
  277. package/.eslintrc.json +0 -34
  278. package/.github/ISSUE_TEMPLATE/bug_report.md +0 -51
  279. package/.github/ISSUE_TEMPLATE/feature_request.md +0 -45
  280. package/.github/ISSUE_TEMPLATE/question.md +0 -31
  281. package/.github/PULL_REQUEST_TEMPLATE.md +0 -97
  282. package/AGENTS.md +0 -28
  283. package/CHANGELOG.md +0 -416
  284. package/CODE_OF_CONDUCT.md +0 -62
  285. package/CONTRIBUTING.md +0 -165
  286. package/DOCKER_SETUP_GUIDE.md +0 -84
  287. package/Dockerfile +0 -90
  288. package/backup/legacy-removal-20250930-201816/http-server-legacy.ts +0 -1068
  289. package/backup/legacy-removal-20250930-201816/rollback-to-legacy.ps1 +0 -46
  290. package/backup/legacy-removal-20250930-201816/rollback-to-legacy.sh +0 -48
  291. package/dist/server/index-backup.d.ts +0 -5
  292. package/dist/server/index-backup.d.ts.map +0 -1
  293. package/dist/server/index-backup.js +0 -793
  294. package/dist/server/index-backup.js.map +0 -1
  295. package/dist/server/index-refactored.d.ts +0 -6
  296. package/dist/server/index-refactored.d.ts.map +0 -1
  297. package/dist/server/index-refactored.js +0 -206
  298. package/dist/server/index-refactored.js.map +0 -1
  299. package/dist/services/performance-monitoring-integration.d.ts +0 -77
  300. package/dist/services/performance-monitoring-integration.d.ts.map +0 -1
  301. package/dist/services/performance-monitoring-integration.js +0 -177
  302. package/dist/services/performance-monitoring-integration.js.map +0 -1
  303. package/dist/test/debug-http-v2.d.ts +0 -5
  304. package/dist/test/debug-http-v2.d.ts.map +0 -1
  305. package/dist/test/debug-http-v2.js +0 -28
  306. package/dist/test/debug-http-v2.js.map +0 -1
  307. package/dist/test/performance-benchmark.d.ts +0 -57
  308. package/dist/test/performance-benchmark.d.ts.map +0 -1
  309. package/dist/test/performance-benchmark.js +0 -427
  310. package/dist/test/performance-benchmark.js.map +0 -1
  311. package/dist/test/test-alerts-direct.d.ts +0 -7
  312. package/dist/test/test-alerts-direct.d.ts.map +0 -1
  313. package/dist/test/test-alerts-direct.js +0 -101
  314. package/dist/test/test-alerts-direct.js.map +0 -1
  315. package/dist/test/test-batch-scheduler.d.ts +0 -2
  316. package/dist/test/test-batch-scheduler.d.ts.map +0 -1
  317. package/dist/test/test-batch-scheduler.js +0 -156
  318. package/dist/test/test-batch-scheduler.js.map +0 -1
  319. package/dist/test/test-client.d.ts +0 -5
  320. package/dist/test/test-client.d.ts.map +0 -1
  321. package/dist/test/test-client.js +0 -86
  322. package/dist/test/test-client.js.map +0 -1
  323. package/dist/test/test-embedding.d.ts +0 -6
  324. package/dist/test/test-embedding.d.ts.map +0 -1
  325. package/dist/test/test-embedding.js +0 -142
  326. package/dist/test/test-embedding.js.map +0 -1
  327. package/dist/test/test-error-logging.d.ts +0 -7
  328. package/dist/test/test-error-logging.d.ts.map +0 -1
  329. package/dist/test/test-error-logging.js +0 -105
  330. package/dist/test/test-error-logging.js.map +0 -1
  331. package/dist/test/test-forgetting.d.ts +0 -6
  332. package/dist/test/test-forgetting.d.ts.map +0 -1
  333. package/dist/test/test-forgetting.js +0 -154
  334. package/dist/test/test-forgetting.js.map +0 -1
  335. package/dist/test/test-gemini-embedding.d.ts +0 -7
  336. package/dist/test/test-gemini-embedding.d.ts.map +0 -1
  337. package/dist/test/test-gemini-embedding.js +0 -134
  338. package/dist/test/test-gemini-embedding.js.map +0 -1
  339. package/dist/test/test-http-server-v2-simple.d.ts +0 -6
  340. package/dist/test/test-http-server-v2-simple.d.ts.map +0 -1
  341. package/dist/test/test-http-server-v2-simple.js +0 -131
  342. package/dist/test/test-http-server-v2-simple.js.map +0 -1
  343. package/dist/test/test-http-server-v2.d.ts +0 -7
  344. package/dist/test/test-http-server-v2.d.ts.map +0 -1
  345. package/dist/test/test-http-server-v2.js +0 -529
  346. package/dist/test/test-http-server-v2.js.map +0 -1
  347. package/dist/test/test-lightweight-embedding.d.ts +0 -6
  348. package/dist/test/test-lightweight-embedding.d.ts.map +0 -1
  349. package/dist/test/test-lightweight-embedding.js +0 -189
  350. package/dist/test/test-lightweight-embedding.js.map +0 -1
  351. package/dist/test/test-m1-completion.d.ts +0 -7
  352. package/dist/test/test-m1-completion.d.ts.map +0 -1
  353. package/dist/test/test-m1-completion.js +0 -124
  354. package/dist/test/test-m1-completion.js.map +0 -1
  355. package/dist/test/test-memory-injection-prompt.d.ts +0 -2
  356. package/dist/test/test-memory-injection-prompt.d.ts.map +0 -1
  357. package/dist/test/test-memory-injection-prompt.js +0 -299
  358. package/dist/test/test-memory-injection-prompt.js.map +0 -1
  359. package/dist/test/test-performance-alerts.d.ts +0 -7
  360. package/dist/test/test-performance-alerts.d.ts.map +0 -1
  361. package/dist/test/test-performance-alerts.js +0 -109
  362. package/dist/test/test-performance-alerts.js.map +0 -1
  363. package/dist/test/test-performance-monitor.d.ts +0 -2
  364. package/dist/test/test-performance-monitor.d.ts.map +0 -1
  365. package/dist/test/test-performance-monitor.js +0 -182
  366. package/dist/test/test-performance-monitor.js.map +0 -1
  367. package/dist/test/test-performance-monitoring.d.ts +0 -6
  368. package/dist/test/test-performance-monitoring.d.ts.map +0 -1
  369. package/dist/test/test-performance-monitoring.js +0 -156
  370. package/dist/test/test-performance-monitoring.js.map +0 -1
  371. package/dist/test/test-search.d.ts +0 -5
  372. package/dist/test/test-search.d.ts.map +0 -1
  373. package/dist/test/test-search.js +0 -141
  374. package/dist/test/test-search.js.map +0 -1
  375. package/dist/test/test-simple-alerts.d.ts +0 -6
  376. package/dist/test/test-simple-alerts.d.ts.map +0 -1
  377. package/dist/test/test-simple-alerts.js +0 -106
  378. package/dist/test/test-simple-alerts.js.map +0 -1
  379. package/dist/test/test-vector-search-engine.d.ts +0 -2
  380. package/dist/test/test-vector-search-engine.d.ts.map +0 -1
  381. package/dist/test/test-vector-search-engine.js +0 -225
  382. package/dist/test/test-vector-search-engine.js.map +0 -1
  383. package/docker-compose.dev.yml +0 -50
  384. package/docker-compose.prod.yml +0 -77
  385. package/docker-compose.yml +0 -43
  386. package/docs/en/Memento-Goals.md +0 -217
  387. package/docs/en/Memento-M1-DetailSpecs.md +0 -130
  388. package/docs/en/Memento-Milestones.md +0 -135
  389. package/docs/en/Search-Ranking-Memory-Decay-Formulas.md +0 -177
  390. package/docs/en/api-reference.md +0 -658
  391. package/docs/en/architecture.md +0 -1302
  392. package/docs/en/developer-guide.md +0 -1005
  393. package/docs/en/user-manual.md +0 -595
  394. package/docs/ko/Memento-Goals.md +0 -217
  395. package/docs/ko/Memento-M1-DetailSpecs.md +0 -130
  396. package/docs/ko/Memento-Milestones.md +0 -134
  397. package/docs/ko/Search-Ranking-Memory-Decay-Formulas.md +0 -177
  398. package/docs/ko/api-reference.md +0 -658
  399. package/docs/ko/architecture.md +0 -1302
  400. package/docs/ko/developer-guide.md +0 -1006
  401. package/docs/ko/embedding-api-reference.md +0 -122
  402. package/docs/ko/embedding-configuration.md +0 -62
  403. package/docs/ko/embedding-performance-benchmark.md +0 -62
  404. package/docs/ko/embedding-service-guide.md +0 -314
  405. package/docs/ko/user-manual.md +0 -595
  406. package/env.example +0 -49
  407. package/install.sh +0 -191
  408. package/mcp-http-client.js +0 -218
  409. package/mcp.json +0 -0
  410. package/packages/mcp-client/docs/API-REFERENCE.md +0 -560
  411. package/packages/mcp-client/docs/BEST-PRACTICES.md +0 -564
  412. package/packages/mcp-client/docs/MIGRATION-GUIDE.md +0 -344
  413. package/packages/mcp-client/docs/PERFORMANCE-GUIDE.md +0 -476
  414. package/packages/mcp-client/docs/TROUBLESHOOTING.md +0 -564
  415. package/packages/mcp-client/package-lock.json +0 -907
  416. package/packages/mcp-client/package.json +0 -58
  417. package/packages/mcp-client/performance-optimizer.js +0 -428
  418. package/packages/mcp-client/test-basic.js +0 -65
  419. package/packages/mcp-client/test-integration.js +0 -366
  420. package/src/algorithms/forgetting-algorithm.spec.ts +0 -538
  421. package/src/algorithms/forgetting-algorithm.ts +0 -243
  422. package/src/algorithms/hybrid-search-engine.spec.ts +0 -484
  423. package/src/algorithms/hybrid-search-engine.ts +0 -489
  424. package/src/algorithms/search-engine.spec.ts +0 -429
  425. package/src/algorithms/search-engine.ts +0 -392
  426. package/src/algorithms/search-ranking.spec.ts +0 -293
  427. package/src/algorithms/search-ranking.ts +0 -407
  428. package/src/algorithms/spaced-repetition.spec.ts +0 -510
  429. package/src/algorithms/spaced-repetition.ts +0 -238
  430. package/src/algorithms/vector-search-engine.ts +0 -505
  431. package/src/client/index.spec.ts +0 -427
  432. package/src/client/index.ts +0 -222
  433. package/src/config/index.spec.ts +0 -339
  434. package/src/config/index.ts +0 -106
  435. package/src/database/init.spec.ts +0 -239
  436. package/src/database/init.ts +0 -130
  437. package/src/database/migrate.spec.ts +0 -293
  438. package/src/database/migrate.ts +0 -94
  439. package/src/database/migrations/001_add_embedding_metadata.sql +0 -29
  440. package/src/npm-client/context-injector.spec.ts +0 -335
  441. package/src/npm-client/context-injector.ts +0 -412
  442. package/src/npm-client/index.spec.ts +0 -108
  443. package/src/npm-client/index.ts +0 -96
  444. package/src/npm-client/memento-client.spec.ts +0 -549
  445. package/src/npm-client/memento-client.ts +0 -501
  446. package/src/npm-client/memory-manager.spec.ts +0 -374
  447. package/src/npm-client/memory-manager.ts +0 -414
  448. package/src/npm-client/types.spec.ts +0 -427
  449. package/src/npm-client/types.ts +0 -296
  450. package/src/npm-client/utils.spec.ts +0 -355
  451. package/src/npm-client/utils.ts +0 -423
  452. package/src/scripts/copy-assets.js +0 -37
  453. package/src/server/http-server.spec.ts +0 -648
  454. package/src/server/http-server.ts +0 -1030
  455. package/src/server/index-backup.ts +0 -875
  456. package/src/server/index-refactored.ts +0 -237
  457. package/src/server/index.spec.ts +0 -281
  458. package/src/server/index.ts +0 -347
  459. package/src/server/simple-mcp-server.spec.ts +0 -207
  460. package/src/server/simple-mcp-server.ts +0 -173
  461. package/src/services/async-optimizer.spec.ts +0 -569
  462. package/src/services/async-optimizer.ts +0 -484
  463. package/src/services/batch-scheduler.ts +0 -759
  464. package/src/services/cache-service.spec.ts +0 -372
  465. package/src/services/cache-service.ts +0 -434
  466. package/src/services/database-optimizer.spec.ts +0 -344
  467. package/src/services/database-optimizer.ts +0 -450
  468. package/src/services/embedding-provider-factory.ts +0 -173
  469. package/src/services/embedding-service.spec.ts +0 -342
  470. package/src/services/embedding-service.ts +0 -333
  471. package/src/services/error-logging-service.spec.ts +0 -416
  472. package/src/services/error-logging-service.ts +0 -383
  473. package/src/services/forgetting-policy-service.spec.ts +0 -140
  474. package/src/services/forgetting-policy-service.ts +0 -334
  475. package/src/services/gemini-embedding-service.spec.ts +0 -463
  476. package/src/services/gemini-embedding-service.ts +0 -283
  477. package/src/services/lightweight-embedding-service.spec.ts +0 -458
  478. package/src/services/lightweight-embedding-service.ts +0 -324
  479. package/src/services/memory-embedding-service.spec.ts +0 -417
  480. package/src/services/memory-embedding-service.ts +0 -289
  481. package/src/services/minilm-embedding-service.spec.ts +0 -104
  482. package/src/services/minilm-embedding-service.ts +0 -262
  483. package/src/services/performance-alert-service.spec.ts +0 -517
  484. package/src/services/performance-alert-service.ts +0 -477
  485. package/src/services/performance-monitor.spec.ts +0 -401
  486. package/src/services/performance-monitor.ts +0 -532
  487. package/src/services/performance-monitoring-integration.spec.ts +0 -478
  488. package/src/services/performance-monitoring-integration.ts.bak +0 -276
  489. package/src/services/unified-embedding-service.spec.ts +0 -224
  490. package/src/services/unified-embedding-service.ts +0 -255
  491. package/src/test/debug-http-v2.ts +0 -30
  492. package/src/test/embedding-integration-test.spec.ts +0 -295
  493. package/src/test/embedding-integration-test.ts +0 -295
  494. package/src/test/embedding-performance-benchmark.spec.ts +0 -354
  495. package/src/test/embedding-performance-benchmark.ts +0 -312
  496. package/src/test/performance-benchmark.ts +0 -565
  497. package/src/test/test-alerts-direct.ts +0 -136
  498. package/src/test/test-batch-scheduler-simple.spec.ts +0 -122
  499. package/src/test/test-batch-scheduler.spec.ts +0 -453
  500. package/src/test/test-batch-scheduler.ts +0 -182
  501. package/src/test/test-client.ts +0 -97
  502. package/src/test/test-embedding.ts +0 -153
  503. package/src/test/test-error-handling.spec.ts +0 -575
  504. package/src/test/test-error-logging.ts +0 -117
  505. package/src/test/test-forgetting.ts +0 -162
  506. package/src/test/test-gemini-embedding.ts +0 -159
  507. package/src/test/test-http-server-v2-simple.ts +0 -147
  508. package/src/test/test-http-server-v2.ts +0 -586
  509. package/src/test/test-hybrid-search-engine.spec.ts +0 -521
  510. package/src/test/test-integration-fixed.spec.ts +0 -612
  511. package/src/test/test-integration.spec.ts +0 -463
  512. package/src/test/test-lightweight-embedding.ts +0 -208
  513. package/src/test/test-m1-completion.spec.ts +0 -614
  514. package/src/test/test-m1-completion.ts +0 -141
  515. package/src/test/test-m1-integration.spec.ts +0 -514
  516. package/src/test/test-memory-injection-prompt.spec.ts +0 -650
  517. package/src/test/test-memory-injection-prompt.ts +0 -391
  518. package/src/test/test-performance-alerts.ts +0 -125
  519. package/src/test/test-performance-monitor-updates.spec.ts +0 -490
  520. package/src/test/test-performance-monitor.spec.ts +0 -284
  521. package/src/test/test-performance-monitor.ts +0 -228
  522. package/src/test/test-performance-monitoring.ts +0 -171
  523. package/src/test/test-search.ts +0 -151
  524. package/src/test/test-simple-alerts.ts +0 -136
  525. package/src/test/test-vector-search-engine.spec.ts +0 -408
  526. package/src/test/test-vector-search-engine.ts +0 -303
  527. package/src/tools/base-tool.ts +0 -189
  528. package/src/tools/cleanup-memory-tool.ts +0 -77
  529. package/src/tools/database-optimize-tool.ts +0 -79
  530. package/src/tools/error-stats.ts +0 -119
  531. package/src/tools/forget-tool.spec.ts +0 -613
  532. package/src/tools/forget-tool.ts +0 -454
  533. package/src/tools/forgetting-stats-tool.ts +0 -47
  534. package/src/tools/index.ts +0 -71
  535. package/src/tools/memory-injection-prompt.ts +0 -257
  536. package/src/tools/performance-alerts.ts +0 -226
  537. package/src/tools/performance-stats-tool.ts +0 -48
  538. package/src/tools/pin-tool.spec.ts +0 -497
  539. package/src/tools/pin-tool.ts +0 -277
  540. package/src/tools/recall-tool.spec.ts +0 -475
  541. package/src/tools/recall-tool.ts +0 -389
  542. package/src/tools/remember-tool.spec.ts +0 -469
  543. package/src/tools/remember-tool.ts +0 -112
  544. package/src/tools/resolve-error.ts +0 -69
  545. package/src/tools/tool-registry.ts +0 -417
  546. package/src/tools/types.ts +0 -63
  547. package/src/tools/unpin-tool.spec.ts +0 -549
  548. package/src/tools/unpin-tool.ts +0 -306
  549. package/src/types/embedding.types.ts +0 -78
  550. package/src/types/index.spec.ts +0 -420
  551. package/src/types/index.ts +0 -117
  552. package/src/utils/database.spec.ts +0 -77
  553. package/src/utils/database.ts +0 -458
  554. package/src/utils/stopwords.ts +0 -128
  555. package/start-docker-setup.bat +0 -38
  556. package/static/logo.png +0 -0
  557. package/static/memento_logo.svg +0 -2
  558. package/test-docker.js +0 -103
  559. package/tsconfig.json +0 -46
  560. package/vitest.config.ts +0 -23
@@ -3,12 +3,16 @@
3
3
  * 시스템 성능 지표 수집, 분석, 알림 기능 제공
4
4
  */
5
5
  import Database from 'better-sqlite3';
6
+ import os from 'os';
7
+ import { logger } from '../utils/logger.js';
8
+ import { alertNotificationService } from './alert-notification-service.js';
6
9
  export class PerformanceMonitor {
7
10
  db = null;
8
11
  thresholds;
9
12
  alerts = new Map();
10
13
  metricsHistory = [];
11
14
  maxHistorySize = 1000;
15
+ monitoringInterval = null;
12
16
  constructor(thresholds) {
13
17
  this.thresholds = {
14
18
  memoryUsagePercent: 80,
@@ -23,7 +27,13 @@ export class PerformanceMonitor {
23
27
  */
24
28
  initialize(db) {
25
29
  this.db = db;
26
- this.log('PerformanceMonitor initialized');
30
+ logger.info('PerformanceMonitor initialized');
31
+ }
32
+ /**
33
+ * 데이터베이스 설정
34
+ */
35
+ setDatabase(db) {
36
+ this.db = db;
27
37
  }
28
38
  /**
29
39
  * 성능 지표 수집
@@ -36,56 +46,49 @@ export class PerformanceMonitor {
36
46
  const cpuUsage = process.cpuUsage();
37
47
  // 데이터베이스 지표
38
48
  const dbMetrics = await this.getDatabaseMetrics();
49
+ const dbMetricsForPerformance = {
50
+ size: dbMetrics.databaseSize,
51
+ memoryCount: dbMetrics.totalMemories,
52
+ queryTime: 0 // 실제 쿼리 시간은 별도로 측정
53
+ };
54
+ // 검색 지표
55
+ const searchMetrics = this.getSearchMetrics();
56
+ // 시스템 지표
57
+ const systemMetrics = this.getSystemMetrics();
58
+ const memoryUsagePercent = memUsage.heapTotal > 0 ? (memUsage.heapUsed / memUsage.heapTotal) * 100 : 0;
59
+ const cpuUsagePercent = this.calculateCpuUsage(cpuUsage);
39
60
  const metrics = {
40
61
  timestamp: new Date(),
62
+ database: dbMetricsForPerformance,
41
63
  memory: {
42
64
  rss: memUsage.rss,
43
65
  heapTotal: memUsage.heapTotal,
44
66
  heapUsed: memUsage.heapUsed,
45
- external: memUsage.external
67
+ external: memUsage.external,
68
+ usagePercent: memoryUsagePercent
46
69
  },
47
70
  cpu: {
48
71
  user: cpuUsage.user,
49
- system: cpuUsage.system
72
+ system: cpuUsage.system,
73
+ percent: cpuUsagePercent
50
74
  },
51
- database: dbMetrics,
52
- uptime: process.uptime()
75
+ uptime: process.uptime(),
76
+ search: {
77
+ total: searchMetrics.totalSearches,
78
+ averageTime: searchMetrics.averageSearchTime,
79
+ byType: searchMetrics.searchByType,
80
+ cacheHitRate: searchMetrics.cacheHitRate,
81
+ embeddingSearchRate: searchMetrics.embeddingSearchRate
82
+ }
53
83
  };
54
84
  // 지표 히스토리에 추가
55
85
  this.addToHistory(metrics);
56
86
  // 알림 검사
57
87
  await this.checkAlerts(metrics);
58
88
  const collectionTime = Date.now() - startTime;
59
- this.log(`Metrics collected in ${collectionTime}ms`);
89
+ logger.debug('Performance metrics collected', { collectionTimeMs: collectionTime });
60
90
  return metrics;
61
91
  }
62
- /**
63
- * 데이터베이스 지표 수집
64
- */
65
- async getDatabaseMetrics() {
66
- if (!this.db) {
67
- return { size: 0, memoryCount: 0, queryTime: 0 };
68
- }
69
- const startTime = Date.now();
70
- try {
71
- // DB 크기
72
- const pageCount = this.db.prepare('PRAGMA page_count').get();
73
- const pageSize = this.db.prepare('PRAGMA page_size').get();
74
- const size = pageCount.page_count * pageSize.page_size;
75
- // 메모리 개수
76
- const memoryCount = this.db.prepare('SELECT COUNT(*) as count FROM memory_item').get();
77
- const queryTime = Date.now() - startTime;
78
- return {
79
- size,
80
- memoryCount: memoryCount.count,
81
- queryTime
82
- };
83
- }
84
- catch (error) {
85
- this.log('Database metrics collection failed:', error);
86
- return { size: 0, memoryCount: 0, queryTime: 0 };
87
- }
88
- }
89
92
  /**
90
93
  * 알림 검사
91
94
  */
@@ -175,11 +178,23 @@ export class PerformanceMonitor {
175
178
  // 알림 저장 및 로깅
176
179
  for (const alert of alerts) {
177
180
  this.alerts.set(alert.id, alert);
178
- this.log(`Alert generated: ${alert.type} - ${alert.message}`, {
181
+ logger.warn('Performance alert generated', {
182
+ type: alert.type,
179
183
  severity: alert.severity,
180
184
  value: alert.value,
181
185
  threshold: alert.threshold
182
186
  });
187
+ alertNotificationService.emitAlert({
188
+ id: alert.id,
189
+ source: 'performance',
190
+ severity: alert.severity,
191
+ message: alert.message,
192
+ metadata: {
193
+ type: alert.type,
194
+ value: alert.value,
195
+ threshold: alert.threshold
196
+ }
197
+ });
183
198
  // 심각한 알림의 경우 추가 처리
184
199
  if (alert.severity === 'critical') {
185
200
  await this.handleCriticalAlert(alert, metrics);
@@ -196,18 +211,6 @@ export class PerformanceMonitor {
196
211
  this.metricsHistory = this.metricsHistory.slice(-this.maxHistorySize);
197
212
  }
198
213
  }
199
- /**
200
- * 활성 알림 조회
201
- */
202
- getActiveAlerts() {
203
- return Array.from(this.alerts.values()).filter(alert => !alert.resolved);
204
- }
205
- /**
206
- * 모든 알림 조회
207
- */
208
- getAllAlerts() {
209
- return Array.from(this.alerts.values());
210
- }
211
214
  /**
212
215
  * 알림 해결
213
216
  */
@@ -215,11 +218,18 @@ export class PerformanceMonitor {
215
218
  const alert = this.alerts.get(alertId);
216
219
  if (alert) {
217
220
  alert.resolved = true;
218
- this.log(`Alert resolved: ${alertId}`);
221
+ logger.info('Performance alert resolved', { alertId });
222
+ alertNotificationService.acknowledgeAlert(alertId);
219
223
  return true;
220
224
  }
221
225
  return false;
222
226
  }
227
+ /**
228
+ * 현재 성능 지표 조회
229
+ */
230
+ async getMetrics() {
231
+ return await this.collectMetrics();
232
+ }
223
233
  /**
224
234
  * 성능 지표 히스토리 조회
225
235
  */
@@ -229,12 +239,316 @@ export class PerformanceMonitor {
229
239
  }
230
240
  return [...this.metricsHistory];
231
241
  }
242
+ /**
243
+ * 활성 알림 조회
244
+ */
245
+ getAlerts() {
246
+ return Array.from(this.alerts.values());
247
+ }
248
+ getActiveAlerts() {
249
+ return Array.from(this.alerts.values()).filter(alert => !alert.resolved);
250
+ }
251
+ getAllAlerts() {
252
+ return Array.from(this.alerts.values());
253
+ }
254
+ /**
255
+ * 알림 초기화
256
+ */
257
+ clearAlerts() {
258
+ this.alerts.clear();
259
+ }
260
+ /**
261
+ * 성능 리포트 생성
262
+ */
263
+ async getPerformanceReport() {
264
+ const summary = this.getPerformanceSummary();
265
+ const metrics = this.getMetricsHistory();
266
+ const alerts = this.getAlerts();
267
+ const recommendations = this.generateRecommendations(alerts);
268
+ const analytics = this.getMetricsAnalytics();
269
+ return {
270
+ summary,
271
+ metrics,
272
+ alerts,
273
+ recommendations,
274
+ analytics,
275
+ timestamp: new Date()
276
+ };
277
+ }
278
+ /**
279
+ * 권장사항 생성
280
+ */
281
+ generateRecommendations(alerts) {
282
+ const recommendations = [];
283
+ const memoryAlerts = alerts.filter(alert => alert.type === 'memory' && !alert.resolved);
284
+ const cpuAlerts = alerts.filter(alert => alert.type === 'cpu' && !alert.resolved);
285
+ const dbAlerts = alerts.filter(alert => alert.type === 'database' && !alert.resolved);
286
+ if (memoryAlerts.length > 0) {
287
+ recommendations.push('메모리 사용량이 높습니다. 캐시 크기를 줄이거나 메모리 정리를 고려하세요.');
288
+ }
289
+ if (cpuAlerts.length > 0) {
290
+ recommendations.push('CPU 사용량이 높습니다. 쿼리 최적화나 인덱스 추가를 고려하세요.');
291
+ }
292
+ if (dbAlerts.length > 0) {
293
+ recommendations.push('데이터베이스 크기가 큽니다. 오래된 데이터 정리나 아카이빙을 고려하세요.');
294
+ }
295
+ if (recommendations.length === 0) {
296
+ recommendations.push('시스템이 정상적으로 작동하고 있습니다.');
297
+ }
298
+ return recommendations;
299
+ }
300
+ /**
301
+ * 모니터링 시작
302
+ */
303
+ startMonitoring(intervalMs = 60000) {
304
+ if (this.monitoringInterval) {
305
+ clearInterval(this.monitoringInterval);
306
+ }
307
+ this.monitoringInterval = setInterval(async () => {
308
+ try {
309
+ await this.collectMetrics();
310
+ }
311
+ catch (error) {
312
+ logger.error('성능 모니터링 중 오류', { error: error instanceof Error ? error.message : String(error) });
313
+ }
314
+ }, intervalMs);
315
+ }
316
+ /**
317
+ * 모니터링 중지
318
+ */
319
+ stopMonitoring() {
320
+ if (this.monitoringInterval) {
321
+ clearInterval(this.monitoringInterval);
322
+ this.monitoringInterval = null;
323
+ }
324
+ }
325
+ /**
326
+ * 모니터링 상태 확인
327
+ */
328
+ isMonitoring() {
329
+ return this.monitoringInterval !== null;
330
+ }
331
+ /**
332
+ * 검색 통계 기록
333
+ */
334
+ recordSearch(type, duration, cacheHit = false) {
335
+ if (!this.searchStats) {
336
+ this.searchStats = {
337
+ totalSearches: 0,
338
+ totalDuration: 0,
339
+ totalSearchTime: 0,
340
+ searchesByType: { text: 0, vector: 0, hybrid: 0 },
341
+ cacheHits: 0,
342
+ cacheMisses: 0,
343
+ embeddingSearches: 0
344
+ };
345
+ }
346
+ const stats = this.searchStats;
347
+ stats.totalSearches++;
348
+ stats.totalDuration += duration;
349
+ stats.totalSearchTime += duration;
350
+ stats.searchesByType[type]++;
351
+ if (type === 'vector') {
352
+ stats.embeddingSearches++;
353
+ }
354
+ if (cacheHit) {
355
+ stats.cacheHits++;
356
+ }
357
+ else {
358
+ stats.cacheMisses++;
359
+ }
360
+ }
361
+ /**
362
+ * 검색 메트릭 조회
363
+ */
364
+ getSearchMetrics() {
365
+ const stats = this.searchStats || {
366
+ totalSearches: 0,
367
+ totalDuration: 0,
368
+ searchesByType: { text: 0, vector: 0, hybrid: 0 },
369
+ cacheHits: 0,
370
+ cacheMisses: 0,
371
+ embeddingSearches: 0
372
+ };
373
+ const averageSearchTime = stats.totalSearches > 0 ? stats.totalDuration / stats.totalSearches : 0;
374
+ const totalCacheRequests = stats.cacheHits + stats.cacheMisses;
375
+ const cacheHitRate = totalCacheRequests > 0 ? stats.cacheHits / totalCacheRequests : 0;
376
+ const embeddingSearchRate = stats.totalSearches > 0 ? stats.embeddingSearches / stats.totalSearches : 0;
377
+ return {
378
+ totalSearches: stats.totalSearches,
379
+ averageSearchTime,
380
+ searchByType: stats.searchesByType,
381
+ cacheHitRate,
382
+ embeddingSearchRate
383
+ };
384
+ }
385
+ /**
386
+ * 메모리 메트릭 조회
387
+ */
388
+ getMemoryMetrics() {
389
+ const memUsage = process.memoryUsage();
390
+ const totalMemory = 1024 * 1024 * 1024; // 1GB 가정
391
+ const usagePercent = (memUsage.heapUsed / totalMemory) * 100;
392
+ return {
393
+ heapUsed: memUsage.heapUsed,
394
+ heapTotal: memUsage.heapTotal,
395
+ rss: memUsage.rss,
396
+ external: memUsage.external,
397
+ usagePercent
398
+ };
399
+ }
400
+ /**
401
+ * 시스템 메트릭 조회
402
+ */
403
+ getSystemMetrics() {
404
+ const uptime = process.uptime();
405
+ const cpuUsage = process.cpuUsage();
406
+ const loadAverage = os.loadavg();
407
+ return {
408
+ uptime,
409
+ cpuUsage: (cpuUsage.user + cpuUsage.system) / 1000000, // 마이크로초를 초로 변환
410
+ loadAverage
411
+ };
412
+ }
413
+ /**
414
+ * 데이터베이스 메트릭 조회
415
+ */
416
+ async getDatabaseMetrics() {
417
+ if (!this.db) {
418
+ return {
419
+ totalMemories: 0,
420
+ memoryByType: {},
421
+ averageMemorySize: 0,
422
+ databaseSize: 0
423
+ };
424
+ }
425
+ try {
426
+ const totalMemories = this.db.prepare('SELECT COUNT(*) as count FROM memory_item').get();
427
+ const memoryByType = this.db.prepare(`
428
+ SELECT type, COUNT(*) as count
429
+ FROM memory_item
430
+ GROUP BY type
431
+ `).all();
432
+ const typeMap = {};
433
+ memoryByType.forEach(row => {
434
+ typeMap[row.type] = row.count;
435
+ });
436
+ const averageSize = this.db.prepare(`
437
+ SELECT AVG(LENGTH(content)) as avgSize
438
+ FROM memory_item
439
+ `).get();
440
+ const dbSize = this.db.prepare('PRAGMA page_count').get();
441
+ const pageSize = this.db.prepare('PRAGMA page_size').get();
442
+ const databaseSize = dbSize.page_count * pageSize.page_size;
443
+ return {
444
+ totalMemories: totalMemories.count,
445
+ memoryByType: typeMap,
446
+ averageMemorySize: averageSize.avgSize || 0,
447
+ databaseSize
448
+ };
449
+ }
450
+ catch (error) {
451
+ return {
452
+ totalMemories: 0,
453
+ memoryByType: {},
454
+ averageMemorySize: 0,
455
+ databaseSize: 0
456
+ };
457
+ }
458
+ }
459
+ /**
460
+ * 통계 초기화
461
+ */
462
+ resetStats() {
463
+ this.searchStats = {
464
+ totalSearches: 0,
465
+ totalDuration: 0,
466
+ totalSearchTime: 0,
467
+ searchesByType: { text: 0, vector: 0, hybrid: 0 },
468
+ cacheHits: 0,
469
+ cacheMisses: 0,
470
+ embeddingSearches: 0
471
+ };
472
+ }
473
+ /**
474
+ * 시스템 건강 상태 확인
475
+ */
476
+ async isHealthy() {
477
+ const metrics = await this.collectMetrics();
478
+ const alerts = this.getActiveAlerts();
479
+ // 심각한 알림이 있으면 비정상
480
+ const criticalAlerts = alerts.filter((alert) => alert.severity === 'critical');
481
+ return criticalAlerts.length === 0;
482
+ }
483
+ /**
484
+ * 메트릭 내보내기
485
+ */
486
+ async exportMetrics() {
487
+ const metrics = this.getMetricsHistory();
488
+ const alerts = this.getAlerts();
489
+ const currentMetrics = await this.collectMetrics();
490
+ return JSON.stringify({
491
+ database: currentMetrics.database,
492
+ search: currentMetrics.search,
493
+ memory: currentMetrics.memory,
494
+ system: currentMetrics.system,
495
+ metrics,
496
+ alerts,
497
+ exportedAt: new Date().toISOString()
498
+ });
499
+ }
500
+ /**
501
+ * 메트릭 가져오기
502
+ */
503
+ async importMetrics(json) {
504
+ const data = JSON.parse(json);
505
+ if (data.metrics) {
506
+ this.metricsHistory = data.metrics;
507
+ }
508
+ if (data.alerts) {
509
+ this.alerts.clear();
510
+ data.alerts.forEach((alert) => {
511
+ this.alerts.set(alert.id, alert);
512
+ });
513
+ }
514
+ // 검색 통계 복원
515
+ if (data.search) {
516
+ this.searchStats = {
517
+ totalSearches: data.search.totalSearches || 0,
518
+ totalDuration: data.search.averageSearchTime * data.search.totalSearches || 0,
519
+ totalSearchTime: data.search.averageSearchTime * data.search.totalSearches || 0,
520
+ searchesByType: data.search.searchByType || { text: 0, vector: 0, hybrid: 0 },
521
+ cacheHits: Math.round((data.search.cacheHitRate || 0) * data.search.totalSearches),
522
+ cacheMisses: Math.round((1 - (data.search.cacheHitRate || 0)) * data.search.totalSearches),
523
+ embeddingSearches: Math.round((data.search.embeddingSearchRate || 0) * data.search.totalSearches)
524
+ };
525
+ }
526
+ // 메트릭 히스토리 복원
527
+ if (data.metrics && Array.isArray(data.metrics)) {
528
+ this.metricsHistory = data.metrics;
529
+ }
530
+ // 데이터베이스 메트릭 복원 (테스트용)
531
+ if (data.database) {
532
+ // 현재 메트릭 수집
533
+ const currentMetrics = await this.collectMetrics();
534
+ if (currentMetrics) {
535
+ // 데이터베이스 메트릭을 직접 설정
536
+ currentMetrics.database = {
537
+ totalMemories: data.database.totalMemories || 0,
538
+ memoryByType: data.database.memoryByType || {},
539
+ averageMemorySize: data.database.averageMemorySize || 0,
540
+ databaseSize: data.database.databaseSize || 0
541
+ };
542
+ this.addToHistory(currentMetrics);
543
+ }
544
+ }
545
+ }
232
546
  /**
233
547
  * 성능 통계 요약
234
548
  */
235
549
  getPerformanceSummary() {
236
550
  const current = this.metricsHistory[this.metricsHistory.length - 1] || null;
237
- const activeAlerts = this.getActiveAlerts();
551
+ const activeAlerts = this.getAlerts();
238
552
  const allAlerts = this.getAllAlerts();
239
553
  // 트렌드 분석 (최근 10개 지표 기준)
240
554
  const recentMetrics = this.metricsHistory.slice(-10);
@@ -252,6 +566,78 @@ export class PerformanceMonitor {
252
566
  }
253
567
  };
254
568
  }
569
+ getMetricsAnalytics(limit = 50) {
570
+ const history = this.metricsHistory.slice(-limit);
571
+ if (!history.length) {
572
+ return {
573
+ memory: {
574
+ averageHeapUsedMB: 0,
575
+ peakHeapUsedMB: 0,
576
+ averageUsagePercent: 0,
577
+ history: []
578
+ },
579
+ cpu: {
580
+ averagePercent: 0,
581
+ peakPercent: 0,
582
+ history: []
583
+ },
584
+ database: {
585
+ averageSizeMB: 0,
586
+ lastSizeMB: 0,
587
+ growthRate: 0
588
+ },
589
+ search: {
590
+ totalSearches: 0,
591
+ averageSearchTime: 0,
592
+ cacheHitRate: 0,
593
+ textShare: 0,
594
+ vectorShare: 0,
595
+ hybridShare: 0
596
+ }
597
+ };
598
+ }
599
+ const toMb = (bytes) => bytes / (1024 * 1024);
600
+ const average = (values) => values.length ? values.reduce((sum, value) => sum + value, 0) / values.length : 0;
601
+ const memoryUsed = history.map(m => m.memory.heapUsed);
602
+ const memoryPercentHistory = history.map(m => m.memory.usagePercent ?? (m.memory.heapTotal ? (m.memory.heapUsed / m.memory.heapTotal) * 100 : 0));
603
+ const cpuPercentHistory = history.map(m => m.cpu.percent ?? this.calculateCpuUsage(m.cpu));
604
+ const dbSizesMB = history.map(m => toMb(m.database.size));
605
+ const latestEntry = history[history.length - 1];
606
+ const latestSearch = latestEntry?.search;
607
+ const totalSearches = latestSearch?.total ?? 0;
608
+ const totalByType = latestSearch?.byType ?? { text: 0, vector: 0, hybrid: 0 };
609
+ const totalByTypeSum = totalByType.text + totalByType.vector + totalByType.hybrid;
610
+ const lastDbSize = dbSizesMB[dbSizesMB.length - 1] ?? 0;
611
+ const firstDbSize = dbSizesMB[0] ?? 0;
612
+ return {
613
+ memory: {
614
+ averageHeapUsedMB: toMb(average(memoryUsed)),
615
+ peakHeapUsedMB: toMb(Math.max(...memoryUsed)),
616
+ averageUsagePercent: average(memoryPercentHistory),
617
+ history: memoryPercentHistory
618
+ },
619
+ cpu: {
620
+ averagePercent: average(cpuPercentHistory),
621
+ peakPercent: Math.max(...cpuPercentHistory),
622
+ history: cpuPercentHistory
623
+ },
624
+ database: {
625
+ averageSizeMB: average(dbSizesMB),
626
+ lastSizeMB: lastDbSize,
627
+ growthRate: dbSizesMB.length > 1 && firstDbSize > 0
628
+ ? (lastDbSize - firstDbSize) / firstDbSize
629
+ : 0
630
+ },
631
+ search: {
632
+ totalSearches,
633
+ averageSearchTime: latestSearch?.averageTime ?? 0,
634
+ cacheHitRate: latestSearch?.cacheHitRate ?? 0,
635
+ textShare: totalByTypeSum > 0 ? totalByType.text / totalByTypeSum : 0,
636
+ vectorShare: totalByTypeSum > 0 ? totalByType.vector / totalByTypeSum : 0,
637
+ hybridShare: totalByTypeSum > 0 ? totalByType.hybrid / totalByTypeSum : 0
638
+ }
639
+ };
640
+ }
255
641
  /**
256
642
  * 트렌드 분석
257
643
  */
@@ -274,7 +660,7 @@ export class PerformanceMonitor {
274
660
  */
275
661
  updateThresholds(newThresholds) {
276
662
  this.thresholds = { ...this.thresholds, ...newThresholds };
277
- this.log('Thresholds updated', this.thresholds);
663
+ logger.info('Performance thresholds updated', { ...this.thresholds });
278
664
  }
279
665
  /**
280
666
  * 바이트를 읽기 쉬운 형식으로 변환
@@ -300,8 +686,8 @@ export class PerformanceMonitor {
300
686
  * 심각한 알림 처리
301
687
  */
302
688
  async handleCriticalAlert(alert, metrics) {
303
- this.log(`Critical alert handling: ${alert.type}`, {
304
- alert: alert,
689
+ logger.error('Critical performance alert handling', {
690
+ alert,
305
691
  metrics: {
306
692
  memoryUsage: (metrics.memory.heapUsed / metrics.memory.heapTotal) * 100,
307
693
  dbSize: metrics.database.size / (1024 * 1024),
@@ -310,22 +696,22 @@ export class PerformanceMonitor {
310
696
  });
311
697
  // 메모리 정리 시도
312
698
  if (alert.type === 'memory' && global.gc) {
313
- this.log('Triggering garbage collection due to high memory usage');
699
+ logger.warn('Triggering garbage collection due to high memory usage');
314
700
  global.gc();
315
701
  }
316
702
  // 데이터베이스 최적화 시도
317
703
  if (alert.type === 'database' && this.db) {
318
704
  try {
319
- this.log('Running database optimization due to large size');
705
+ logger.warn('Running database optimization due to large database size');
320
706
  await this.optimizeDatabase();
321
707
  }
322
708
  catch (error) {
323
- this.log('Database optimization failed:', error);
709
+ logger.error('Database optimization failed', { error: error instanceof Error ? error.message : String(error) });
324
710
  }
325
711
  }
326
712
  // 쿼리 최적화 시도
327
713
  if (alert.type === 'query') {
328
- this.log('Query optimization recommended due to slow queries');
714
+ logger.warn('Query optimization recommended due to slow queries');
329
715
  // 여기에 쿼리 최적화 로직 추가 가능
330
716
  }
331
717
  }
@@ -338,16 +724,16 @@ export class PerformanceMonitor {
338
724
  try {
339
725
  // VACUUM 실행
340
726
  this.db.exec('VACUUM');
341
- this.log('Database VACUUM completed');
727
+ logger.info('Database VACUUM completed');
342
728
  // ANALYZE 실행
343
729
  this.db.exec('ANALYZE');
344
- this.log('Database ANALYZE completed');
730
+ logger.info('Database ANALYZE completed');
345
731
  // WAL 체크포인트
346
732
  this.db.exec('PRAGMA wal_checkpoint(TRUNCATE)');
347
- this.log('WAL checkpoint completed');
733
+ logger.info('WAL checkpoint completed');
348
734
  }
349
735
  catch (error) {
350
- this.log('Database optimization failed:', error);
736
+ logger.error('Database optimization failed', { error: error instanceof Error ? error.message : String(error) });
351
737
  throw error;
352
738
  }
353
739
  }
@@ -391,7 +777,7 @@ export class PerformanceMonitor {
391
777
  }
392
778
  }
393
779
  if (removedCount > 0) {
394
- this.log(`Cleaned up ${removedCount} old alerts`);
780
+ logger.info('Old alerts cleaned', { removedCount });
395
781
  }
396
782
  }
397
783
  /**