R.B. Boyer
fe2d41ddad
cache: prevent goroutine leak in agent cache ( #14908 )
...
There is a bug in the error handling code for the Agent cache subsystem discovered:
1. NotifyCallback calls notifyBlockingQuery which calls getWithIndex in
a loop (which backs off on-error up to 1 minute)
2. getWithIndex calls fetch if there’s no valid entry in the cache
3. fetch starts a goroutine which calls Fetch on the cache-type, waits
for a while (again with backoff up to 1 minute for errors) and then
calls fetch to trigger a refresh
The end result being that every 1 minute notifyBlockingQuery spawns an
ancestry of goroutines that essentially lives forever.
This PR ensures that the goroutine started by `fetch` cancels any prior
goroutine spawned by the same line for the same key.
In isolated testing where a cache type was tweaked to indefinitely
error, this patch prevented goroutine counts from skyrocketing.
2022-10-17 14:38:10 -05:00
..
2022-02-03 13:42:28 -05:00
2022-04-21 17:34:40 -05:00
2022-10-17 14:38:10 -05:00
2022-10-17 13:24:27 -05:00
2022-09-21 09:27:33 +01:00
2022-10-17 09:26:19 -04:00
2022-10-10 12:40:27 -05:00
2022-10-07 09:05:32 -06:00
2022-10-14 11:04:57 -05:00
2022-01-20 10:46:23 -06:00
2022-05-19 14:00:07 -05:00
2021-11-16 12:04:01 -06:00
2022-10-14 09:44:56 -06:00
2022-10-11 17:00:32 -05:00
2022-10-11 17:00:32 -05:00
2022-10-13 11:31:28 +02:00
2022-08-01 12:31:05 -06:00
2022-08-31 16:38:42 -05:00
2022-07-13 16:33:48 +01:00
2022-10-17 11:31:10 +01:00
2022-10-13 12:45:09 -05:00
2022-10-13 12:04:59 +01:00
2022-02-03 13:42:28 -05:00
2021-12-07 12:48:50 +00:00
2022-10-13 14:57:55 -06:00
2022-07-14 18:22:12 +01:00
2022-10-17 09:26:19 -04:00
2022-08-23 20:17:49 +01:00
2021-12-07 12:12:47 +00:00
2022-07-25 11:50:11 -04:00
2022-10-14 17:05:46 -07:00
2021-10-26 15:20:57 -04:00
2022-07-22 14:42:23 -06:00
2022-06-01 13:17:14 -04:00
2021-12-03 20:36:28 +00:00
2022-07-26 16:54:53 -04:00
2022-04-29 13:42:49 -04:00
2022-05-09 10:07:19 -07:00
2022-04-05 15:11:49 -07:00
2022-10-07 09:05:32 -06:00
2022-09-08 14:53:08 -05:00
2022-06-01 16:18:06 +01:00
2022-10-14 15:52:00 +01:00
2022-10-17 09:26:19 -04:00
2021-11-16 12:04:01 -06:00
2022-07-29 14:36:22 -07:00
2022-06-15 08:30:31 -07:00
2022-04-05 15:11:49 -07:00
2022-04-29 13:42:49 -04:00
2022-06-01 13:17:14 -04:00
2022-04-29 13:42:49 -04:00
2022-04-18 11:41:10 -04:00
2022-04-29 13:42:49 -04:00
2022-04-29 13:42:49 -04:00
2022-06-01 13:17:14 -04:00
2022-06-17 10:24:43 +01:00
2022-08-23 09:13:43 -04:00
2022-06-01 13:17:14 -04:00
2022-07-06 10:30:04 -06:00
2022-09-29 21:44:45 -07:00
2022-09-29 21:44:45 -07:00
2021-11-16 12:04:01 -06:00
2022-04-29 13:42:49 -04:00
2022-06-01 13:17:14 -04:00
2022-06-01 13:17:14 -04:00
2022-07-29 14:36:22 -07:00
2022-06-01 13:17:14 -04:00
2021-12-07 12:48:50 +00:00
2022-04-29 13:42:49 -04:00
2022-09-23 09:43:56 -04:00
2022-08-29 13:43:43 -05:00
2022-09-08 11:02:05 -04:00
2021-11-16 12:04:01 -06:00
2022-06-22 16:25:09 -07:00
2022-06-22 16:25:09 -07:00
2021-12-07 12:48:50 +00:00
2022-02-24 17:24:57 +00:00
2022-06-02 12:26:18 -04:00
2022-09-15 13:04:37 -04:00
2021-10-27 16:26:09 -04:00
2021-11-16 12:04:01 -06:00
2022-04-29 13:42:49 -04:00
2022-05-02 11:49:05 -07:00
2022-10-10 13:20:14 -06:00
2022-09-28 09:56:59 -07:00
2022-07-22 09:14:43 -04:00
2022-06-01 13:17:14 -04:00
2021-12-07 12:48:50 +00:00
2022-09-26 14:58:15 -04:00
2022-09-26 14:58:15 -04:00
2022-10-12 07:49:56 -07:00
2022-05-25 13:20:17 -07:00
2022-10-10 12:40:27 -05:00
2022-06-01 13:17:14 -04:00
2021-11-16 12:04:01 -06:00
2022-10-12 14:17:58 -05:00
2022-09-09 09:47:10 -05:00
2022-09-09 09:47:10 -05:00
2021-11-16 12:04:01 -06:00
2021-11-16 12:04:01 -06:00
2021-11-01 11:40:16 -04:00
2022-10-07 09:05:32 -06:00
2022-09-19 09:07:19 -07:00
2022-10-17 09:26:19 -04:00
2021-11-16 12:04:01 -06:00
2022-10-04 14:46:15 -04:00
2022-09-23 09:43:56 -04:00
2022-07-26 16:54:53 -04:00
2022-02-14 09:45:45 -08:00
2021-11-04 13:07:54 -07:00
2021-11-04 13:07:54 -07:00