Evgeni Obuchowski
16ea3f272f
fix(plugins): stop derived metadata snapshot rescan storm in /models (regression shipped since v2026.5.18) ( #92127 )
...
Since 5734193fdf ("fix(plugins): keep metadata snapshot memo fresh",
first shipped in v2026.5.18), the in-process plugin metadata snapshot
memo stores derived-registry results under a key recomputed from the
freshly built snapshot.index, while lookups key off the persisted-index
registry state. On installs where the registry resolves as "derived"
(persisted index absent or not covering the running checkout), the two
keys never match. Worse, the lookup-side adoption loop returns the most
recently stored registryState for the context, so two alternating call
shapes (e.g. the model-catalog build mixing workspace-scoped and global
lookups) each adopt the other shape's state, compute a key that was
never stored, and re-run the full plugin manifest scan - on every call,
forever. Chat /models (and each subsequent provider/model pick) pays
multiple full manifest scans plus all downstream snapshot-identity cache
invalidation per step, pinning a CPU core for seconds on every
interaction, in every chat channel.
Fix: store the memo under the exact memoKey/registryState the call
looked up by, instead of re-deriving a second key from snapshot.index.
Freshness is unchanged - the lookup context hash and the plugin metadata
lifecycle clears (install/reload/doctor) still own invalidation. The
now-unused index parameter of resolvePersistedRegistryMemoState is
removed.
Measured on the author's VPS (real plugin discovery, identical catalog
output of 263 entries on both sides): the full-discovery model catalog
build behind chat /models dropped from ~6.3s to ~0.3s (~21x), with
repeat snapshot lookups going from full rescans to memo hits.
Regression test: alternating derived call shapes must not re-scan
(red on main: 4 scans; green with this fix: 2).
2026-06-11 20:35:59 +09:00
..
2026-06-04 19:48:26 -04:00
2026-06-04 19:48:26 -04:00
2026-06-11 11:11:23 +09:00
2026-06-09 01:22:29 +01:00
2026-06-04 19:54:07 -04:00
2026-06-04 04:21:07 -04:00
2026-06-04 04:19:03 -04:00
2026-06-04 04:54:37 -04:00
2026-06-04 04:41:47 -04:00
2026-06-04 04:44:12 -04:00
2026-06-04 04:29:53 -04:00
2026-06-04 04:34:19 -04:00
2026-06-04 04:27:23 -04:00
2026-06-04 04:14:06 -04:00
2026-06-10 16:18:23 +10:00
2026-06-04 04:15:33 -04:00
2026-06-04 04:12:38 -04:00
2026-06-04 04:19:03 -04:00
2026-06-04 04:31:52 -04:00
2026-06-04 04:27:23 -04:00
2026-06-04 04:44:12 -04:00
2026-06-04 04:15:33 -04:00
2026-06-04 04:25:18 -04:00
2026-06-04 04:41:47 -04:00
2026-06-04 04:29:53 -04:00
2026-06-04 04:14:06 -04:00
2026-06-04 04:38:31 -04:00
2026-06-04 04:57:48 -04:00
2026-06-04 04:46:27 -04:00
2026-06-04 04:34:19 -04:00
2026-06-04 04:29:53 -04:00
2026-06-04 04:36:44 -04:00
2026-06-04 04:29:53 -04:00
2026-06-04 04:21:07 -04:00
2026-06-04 04:48:42 -04:00
2026-06-04 04:46:27 -04:00
2026-06-04 04:46:27 -04:00
2026-06-04 04:48:42 -04:00
2026-06-04 04:41:47 -04:00
2026-06-04 04:54:37 -04:00
2026-06-04 04:27:23 -04:00
2026-06-04 04:46:27 -04:00
2026-06-04 04:38:31 -04:00
2026-06-04 04:41:47 -04:00
2026-06-04 04:22:45 -04:00
2026-06-04 04:12:38 -04:00
2026-06-04 04:14:06 -04:00
2026-06-04 04:19:03 -04:00
2026-06-04 04:31:52 -04:00
2026-06-04 04:41:47 -04:00
2026-06-04 04:25:18 -04:00
2026-06-04 04:46:27 -04:00
2026-06-04 04:34:19 -04:00
2026-06-04 04:41:47 -04:00
2026-06-04 04:48:42 -04:00
2026-06-04 04:17:40 -04:00
2026-06-04 04:31:52 -04:00
2026-06-04 04:31:52 -04:00
2026-06-04 04:31:52 -04:00
2026-06-10 16:18:23 +10:00
2026-06-07 00:44:06 +08:00
2026-06-04 04:15:33 -04:00
2026-06-03 20:30:38 -04:00
2026-06-04 04:14:06 -04:00
2026-06-04 04:15:33 -04:00
2026-06-03 21:03:43 -04:00
2026-06-04 04:27:23 -04:00
2026-06-06 12:26:32 -07:00
2026-06-04 04:27:23 -04:00
2026-06-04 04:54:37 -04:00
2026-06-04 04:22:45 -04:00
2026-06-04 04:54:37 -04:00
2026-06-04 04:46:27 -04:00
2026-06-04 04:44:12 -04:00
2026-06-04 04:38:31 -04:00
2026-06-04 04:54:37 -04:00
2026-06-04 04:29:53 -04:00
2026-06-04 04:17:40 -04:00
2026-06-04 04:14:06 -04:00
2026-06-04 04:48:42 -04:00
2026-06-04 04:31:52 -04:00
2026-06-04 04:36:44 -04:00
2026-06-04 04:22:45 -04:00
2026-06-04 04:46:27 -04:00
2026-06-04 04:34:19 -04:00
2026-06-04 04:38:31 -04:00
2026-06-04 04:31:52 -04:00
2026-06-04 04:48:42 -04:00
2026-06-04 04:21:07 -04:00
2026-06-04 04:27:23 -04:00
2026-06-04 04:15:33 -04:00
2026-06-04 04:29:53 -04:00
2026-06-04 04:38:31 -04:00
2026-06-04 04:29:53 -04:00
2026-06-04 04:54:37 -04:00
2026-06-04 04:36:44 -04:00
2026-06-04 04:15:33 -04:00
2026-06-04 04:51:24 -04:00
2026-06-04 04:27:23 -04:00
2026-06-04 04:21:07 -04:00
2026-06-04 04:48:42 -04:00
2026-06-04 04:21:07 -04:00
2026-06-03 20:19:17 -04:00
2026-06-04 04:19:03 -04:00
2026-06-04 04:51:24 -04:00
2026-06-04 04:25:18 -04:00
2026-06-04 04:17:40 -04:00
2026-06-04 04:34:19 -04:00
2026-06-04 04:46:27 -04:00
2026-06-04 04:29:53 -04:00
2026-06-04 04:15:33 -04:00
2026-06-04 04:14:06 -04:00
2026-06-04 04:25:18 -04:00
2026-06-04 04:21:07 -04:00
2026-06-04 04:38:31 -04:00
2026-06-03 21:03:43 -04:00
2026-06-04 04:22:45 -04:00
2026-06-04 04:44:12 -04:00
2026-06-04 04:41:47 -04:00
2026-06-04 04:54:37 -04:00
2026-06-07 00:44:06 +08:00
2026-06-07 00:44:06 +08:00
2026-06-04 04:36:44 -04:00
2026-06-07 00:44:06 +08:00
2026-06-04 04:44:12 -04:00
2026-06-06 00:30:48 -07:00
2026-06-06 00:30:48 -07:00
2026-06-10 21:47:20 -07:00
2026-06-10 21:47:20 -07:00
2026-06-04 04:21:07 -04:00
2026-06-10 16:18:23 +10:00
2026-06-04 04:22:45 -04:00
2026-06-04 04:34:19 -04:00
2026-06-04 04:36:44 -04:00
2026-06-04 04:44:12 -04:00
2026-06-04 04:25:18 -04:00
2026-06-04 04:44:12 -04:00
2026-06-11 19:33:00 +09:00
2026-06-11 19:33:00 +09:00
2026-06-07 19:03:38 +09:00
2026-06-04 04:44:12 -04:00
2026-06-04 04:51:24 -04:00
2026-06-10 14:54:32 +05:30
2026-06-04 04:25:18 -04:00
2026-06-04 04:29:53 -04:00
2026-06-04 04:48:42 -04:00
2026-06-03 14:17:29 -07:00
2026-06-11 19:33:00 +09:00
2026-06-04 04:29:53 -04:00
2026-06-04 04:29:53 -04:00
2026-05-31 18:59:02 +01:00
2026-06-04 04:22:45 -04:00
2026-06-04 04:41:47 -04:00
2026-06-04 04:38:31 -04:00
2026-05-31 23:06:13 +01:00
2026-06-04 04:57:48 -04:00
2026-06-04 04:27:23 -04:00
2026-06-04 04:25:18 -04:00
2026-06-04 04:21:07 -04:00
2026-06-02 08:00:42 -04:00
2026-06-04 04:36:44 -04:00
2026-06-04 04:46:27 -04:00
2026-06-03 21:03:43 -04:00
2026-06-04 04:36:44 -04:00
2026-06-04 04:25:18 -04:00
2026-06-10 16:34:06 +09:00
2026-06-03 20:01:47 -04:00
2026-06-04 17:24:03 +00:00
2026-06-04 04:22:45 -04:00
2026-06-04 04:22:45 -04:00
2026-06-04 04:36:44 -04:00
2026-06-04 04:51:24 -04:00
2026-06-04 04:57:48 -04:00
2026-06-04 04:27:23 -04:00
2026-06-04 04:15:33 -04:00
2026-06-04 04:41:47 -04:00
2026-06-04 04:34:19 -04:00
2026-06-04 04:41:47 -04:00
2026-06-04 04:14:06 -04:00
2026-06-03 21:03:43 -04:00
2026-06-04 04:21:07 -04:00
2026-06-04 04:21:07 -04:00
2026-06-04 04:15:33 -04:00
2026-06-04 04:36:44 -04:00
2026-06-04 04:29:53 -04:00
2026-06-04 04:17:40 -04:00
2026-06-04 04:34:19 -04:00
2026-06-04 04:14:06 -04:00
2026-06-04 04:17:40 -04:00
2026-06-04 04:27:23 -04:00
2026-06-04 04:46:27 -04:00
2026-06-04 04:27:23 -04:00
2026-06-04 04:15:33 -04:00
2026-06-04 04:27:23 -04:00
2026-06-04 04:44:12 -04:00
2026-06-04 04:22:45 -04:00
2026-06-04 04:21:07 -04:00
2026-06-04 04:14:06 -04:00
2026-06-04 04:25:18 -04:00
2026-06-04 04:44:12 -04:00
2026-06-04 04:27:23 -04:00
2026-06-04 04:17:40 -04:00
2026-06-04 04:14:06 -04:00
2026-06-04 04:46:27 -04:00
2026-06-04 04:38:31 -04:00
2026-06-04 04:48:42 -04:00
2026-06-04 04:19:03 -04:00
2026-06-04 04:48:42 -04:00
2026-06-04 04:27:23 -04:00
2026-06-04 04:17:40 -04:00
2026-06-04 04:14:06 -04:00
2026-06-04 04:21:07 -04:00
2026-06-04 04:46:27 -04:00
2026-06-04 04:44:12 -04:00
2026-06-04 04:14:06 -04:00
2026-06-04 04:57:48 -04:00
2026-06-04 04:36:44 -04:00
2026-06-04 04:34:19 -04:00
2026-06-04 04:44:12 -04:00
2026-06-04 04:51:24 -04:00
2026-06-04 04:17:40 -04:00
2026-06-04 04:19:03 -04:00
2026-06-04 04:31:52 -04:00
2026-06-04 04:31:52 -04:00
2026-06-04 04:25:18 -04:00
2026-06-04 04:36:44 -04:00
2026-06-04 04:12:38 -04:00
2026-06-04 04:51:24 -04:00
2026-06-04 04:48:42 -04:00
2026-06-04 04:51:24 -04:00
2026-06-04 04:34:19 -04:00
2026-06-04 04:36:44 -04:00
2026-06-04 04:41:47 -04:00
2026-06-04 04:51:24 -04:00
2026-06-04 04:27:23 -04:00
2026-06-04 04:44:12 -04:00
2026-06-04 04:14:06 -04:00
2026-06-04 04:17:40 -04:00
2026-06-04 04:44:12 -04:00
2026-06-04 04:19:03 -04:00
2026-06-04 04:21:07 -04:00
2026-06-04 04:41:47 -04:00
2026-06-10 16:18:23 +10:00
2026-06-10 16:18:23 +10:00
2026-06-04 04:57:48 -04:00
2026-06-04 04:36:44 -04:00
2026-06-04 04:57:48 -04:00
2026-06-04 04:34:19 -04:00
2026-06-04 04:51:24 -04:00
2026-06-04 04:19:03 -04:00
2026-06-04 04:17:40 -04:00
2026-06-04 04:54:37 -04:00
2026-06-04 04:22:45 -04:00
2026-06-04 04:46:27 -04:00
2026-06-04 04:36:44 -04:00
2026-06-04 04:34:19 -04:00
2026-06-04 04:34:19 -04:00
2026-06-04 04:38:31 -04:00
2026-06-04 04:48:42 -04:00
2026-06-04 04:31:52 -04:00
2026-06-04 04:25:18 -04:00
2026-06-04 04:57:48 -04:00
2026-06-04 04:54:37 -04:00
2026-06-04 04:21:07 -04:00
2026-06-04 04:48:42 -04:00
2026-06-10 16:18:23 +10:00
2026-06-10 16:18:23 +10:00
2026-06-04 04:25:18 -04:00
2026-06-03 20:54:08 -04:00
2026-06-04 04:17:40 -04:00
2026-06-10 16:18:23 +10:00
2026-06-04 04:36:44 -04:00
2026-06-04 04:22:45 -04:00
2026-06-04 04:34:19 -04:00
2026-06-07 00:44:06 +08:00
2026-06-04 04:15:33 -04:00
2026-06-09 06:38:30 -04:00
2026-06-04 04:41:47 -04:00
2026-06-04 04:22:45 -04:00
2026-06-04 04:19:03 -04:00
2026-06-04 04:54:37 -04:00
2026-06-04 04:19:03 -04:00
2026-06-04 04:22:45 -04:00
2026-06-04 04:15:33 -04:00
2026-06-04 04:38:31 -04:00
2026-06-04 04:27:23 -04:00
2026-06-03 20:13:51 -04:00
2026-06-04 04:57:48 -04:00
2026-06-04 04:21:07 -04:00
2026-06-04 04:54:37 -04:00
2026-06-04 04:22:45 -04:00
2026-06-04 04:21:07 -04:00
2026-06-09 14:30:35 +08:00
2026-06-04 04:51:24 -04:00
2026-06-04 04:38:31 -04:00
2026-06-04 04:41:47 -04:00
2026-06-04 23:06:33 +01:00
2026-06-04 04:25:18 -04:00
2026-06-04 04:29:53 -04:00
2026-06-04 04:34:19 -04:00
2026-06-04 04:21:07 -04:00
2026-06-03 21:01:33 -04:00
2026-06-04 04:44:12 -04:00
2026-06-04 04:17:40 -04:00
2026-06-04 04:41:47 -04:00
2026-06-04 04:27:23 -04:00
2026-06-04 04:48:42 -04:00
2026-06-04 04:22:45 -04:00
2026-06-03 20:30:38 -04:00
2026-06-04 04:36:44 -04:00
2026-06-04 04:17:40 -04:00
2026-06-04 04:54:37 -04:00
2026-06-04 04:48:42 -04:00
2026-06-04 04:57:48 -04:00
2026-06-11 20:35:59 +09:00
2026-06-11 20:35:59 +09:00
2026-06-04 04:14:06 -04:00
2026-06-04 04:46:27 -04:00
2026-06-04 04:57:48 -04:00
2026-06-03 20:28:45 -04:00
2026-06-04 04:38:31 -04:00
2026-06-04 04:29:53 -04:00
2026-06-04 04:17:40 -04:00
2026-06-04 04:44:12 -04:00
2026-06-04 04:34:19 -04:00
2026-06-04 04:31:52 -04:00
2026-06-05 21:23:55 -07:00
2026-06-03 20:15:37 -04:00
2026-06-04 04:15:33 -04:00
2026-06-03 21:03:43 -04:00
2026-06-04 04:19:03 -04:00
2026-06-04 04:31:52 -04:00
2026-06-04 04:15:33 -04:00
2026-06-04 04:17:40 -04:00
2026-06-04 04:41:47 -04:00
2026-06-04 04:48:42 -04:00
2026-06-04 04:19:03 -04:00
2026-06-04 04:19:03 -04:00
2026-06-04 04:54:37 -04:00
2026-06-11 11:11:21 +09:00
2026-06-11 11:11:21 +09:00
2026-06-04 04:48:42 -04:00
2026-06-04 04:19:03 -04:00
2026-06-04 04:27:23 -04:00
2026-06-04 04:15:33 -04:00
2026-06-04 04:29:53 -04:00
2026-06-04 04:22:45 -04:00
2026-06-04 04:38:31 -04:00
2026-06-04 04:31:52 -04:00
2026-06-04 04:19:03 -04:00
2026-06-04 04:48:42 -04:00
2026-06-04 04:17:40 -04:00
2026-06-04 04:57:48 -04:00
2026-06-04 04:25:18 -04:00
2026-06-03 21:01:33 -04:00
2026-06-04 04:34:19 -04:00
2026-06-04 04:57:48 -04:00
2026-06-04 04:21:07 -04:00
2026-06-04 04:14:06 -04:00
2026-06-11 19:24:46 +09:00
2026-06-04 04:27:23 -04:00
2026-06-04 04:15:33 -04:00
2026-06-04 04:22:45 -04:00
2026-06-04 04:46:27 -04:00
2026-06-04 04:34:19 -04:00
2026-06-04 04:51:24 -04:00
2026-06-04 04:41:47 -04:00
2026-06-04 04:21:07 -04:00
2026-06-04 04:17:40 -04:00
2026-06-04 04:31:52 -04:00
2026-06-04 04:25:18 -04:00
2026-06-04 04:38:31 -04:00
2026-06-04 04:27:23 -04:00
2026-06-04 04:29:53 -04:00
2026-06-04 04:46:27 -04:00
2026-06-04 04:25:18 -04:00
2026-06-04 04:48:42 -04:00
2026-06-04 04:44:12 -04:00
2026-06-04 04:41:47 -04:00
2026-06-04 04:12:38 -04:00
2026-06-06 22:56:17 -07:00
2026-06-04 04:36:44 -04:00
2026-06-04 04:36:44 -04:00
2026-06-04 04:36:44 -04:00
2026-06-11 01:30:59 +09:00
2026-06-11 01:30:59 +09:00
2026-06-04 04:25:18 -04:00
2026-06-04 04:48:42 -04:00
2026-06-04 04:51:24 -04:00
2026-06-04 04:19:03 -04:00
2026-06-04 04:41:47 -04:00
2026-06-04 04:31:52 -04:00
2026-06-04 05:00:21 -04:00
2026-06-04 04:29:53 -04:00
2026-06-10 08:08:35 -07:00
2026-06-10 08:08:35 -07:00
2026-06-04 04:41:47 -04:00
2026-06-04 04:51:24 -04:00
2026-06-04 04:38:31 -04:00
2026-06-04 04:57:48 -04:00
2026-06-04 04:29:53 -04:00
2026-06-04 04:14:06 -04:00
2026-06-04 04:25:18 -04:00
2026-06-07 14:00:09 -07:00
2026-06-04 04:31:52 -04:00
2026-06-04 04:41:47 -04:00
2026-06-04 04:25:18 -04:00
2026-06-04 04:22:45 -04:00
2026-06-04 04:48:42 -04:00
2026-06-04 04:15:33 -04:00
2026-06-04 04:29:53 -04:00
2026-06-04 04:38:31 -04:00
2026-06-04 04:51:24 -04:00
2026-06-10 16:18:23 +10:00
2026-06-04 04:31:52 -04:00
2026-06-09 01:02:22 +02:00
2026-06-04 04:41:47 -04:00
2026-06-04 04:54:37 -04:00
2026-06-04 04:22:45 -04:00
2026-06-10 16:18:23 +10:00
2026-06-04 04:15:33 -04:00
2026-06-04 04:21:07 -04:00
2026-06-04 04:17:40 -04:00
2026-06-04 04:12:38 -04:00
2026-06-03 20:19:17 -04:00
2026-06-04 04:44:12 -04:00
2026-06-04 04:38:31 -04:00
2026-06-04 04:14:06 -04:00
2026-06-04 04:17:40 -04:00
2026-06-04 04:17:40 -04:00
2026-06-04 04:14:06 -04:00
2026-06-04 04:48:42 -04:00
2026-06-04 04:36:44 -04:00
2026-06-04 04:48:42 -04:00
2026-06-04 04:17:40 -04:00
2026-06-04 04:15:33 -04:00
2026-06-04 04:31:52 -04:00
2026-06-04 04:21:07 -04:00
2026-06-04 04:51:24 -04:00
2026-06-04 04:48:42 -04:00
2026-06-03 21:03:43 -04:00
2026-06-03 20:28:45 -04:00
2026-06-04 04:31:52 -04:00
2026-06-04 04:29:53 -04:00
2026-06-04 04:19:03 -04:00
2026-06-04 04:54:37 -04:00
2026-06-04 04:12:38 -04:00
2026-06-04 04:14:06 -04:00
2026-06-04 04:57:48 -04:00
2026-06-04 04:46:27 -04:00
2026-06-04 04:57:48 -04:00
2026-06-04 04:29:53 -04:00
2026-06-04 04:44:12 -04:00
2026-06-04 04:38:31 -04:00
2026-06-04 04:17:40 -04:00
2026-06-04 04:31:52 -04:00
2026-06-04 04:31:52 -04:00
2026-06-04 04:22:45 -04:00
2026-06-04 04:38:31 -04:00
2026-06-03 20:19:17 -04:00
2026-06-04 04:46:27 -04:00
2026-06-10 16:18:23 +10:00
2026-06-04 04:46:27 -04:00
2026-06-10 16:18:23 +10:00
2026-06-04 04:48:42 -04:00
2026-06-04 04:25:18 -04:00
2026-06-04 04:15:33 -04:00
2026-06-04 04:44:12 -04:00
2026-06-04 04:41:47 -04:00
2026-06-04 04:36:44 -04:00
2026-06-04 04:22:45 -04:00
2026-06-04 04:14:06 -04:00
2026-06-04 04:22:45 -04:00
2026-06-04 04:57:48 -04:00
2026-06-04 04:15:33 -04:00
2026-06-04 04:19:03 -04:00
2026-06-04 04:41:47 -04:00
2026-06-04 04:14:06 -04:00
2026-06-10 16:18:23 +10:00
2026-06-04 04:25:18 -04:00
2026-06-04 04:25:18 -04:00
2026-06-04 04:38:31 -04:00
2026-06-04 04:57:48 -04:00
2026-06-04 04:27:23 -04:00
2026-06-04 04:21:07 -04:00
2026-06-03 20:34:17 -04:00
2026-06-04 05:00:21 -04:00
2026-06-04 04:38:31 -04:00
2026-06-04 04:22:45 -04:00
2026-06-04 04:44:12 -04:00
2026-06-04 04:19:03 -04:00
2026-06-04 04:21:07 -04:00
2026-06-04 04:15:33 -04:00
2026-06-04 04:51:24 -04:00
2026-06-04 04:27:23 -04:00
2026-06-04 04:29:53 -04:00
2026-06-04 04:38:31 -04:00
2026-06-04 04:14:06 -04:00
2026-06-04 04:29:53 -04:00
2026-06-04 04:34:19 -04:00
2026-06-04 04:29:53 -04:00
2026-06-04 04:19:03 -04:00
2026-06-04 04:21:07 -04:00
2026-06-04 04:34:19 -04:00
2026-06-05 12:01:58 -07:00
2026-06-04 04:25:18 -04:00
2026-06-04 04:31:52 -04:00
2026-06-04 04:27:23 -04:00
2026-06-04 04:19:03 -04:00
2026-06-04 04:38:31 -04:00
2026-06-04 04:31:52 -04:00
2026-06-04 04:57:48 -04:00