Redis 如何为 IOCP 找到最优值

Redis how to find optimal value for IOCP

目前我们在使用向 Redis 实例发出大量请求的应用程序作为应用程序缓存时遇到问题。

我们收到了不同操作的各种超时。像下面这样:

System.TimeoutException: Timeout performing GET MyKey, inst: 2, mgr: Inactive, 
queue: 6, qu: 0, qs: 6, qc: 0, wr: 0, wq: 0, in: 0, ar: 0, 
IOCP: (Busy=6,Free=994,Min=4,Max=1000), 
WORKER: (Busy=3,Free=997,Min=4,Max=1000)

查阅文档后,我们发现以下文章(https://github.com/StackExchange/StackExchange.Redis/blob/master/Docs/Timeouts.md)建议我们增加 WorkerThreads 的数量(默认值 = 4)

我们如何找到最佳数量的 min/max wokerthreads? Redis 建议从 200-300 开始。但是当我们与默认值 4 比较时,这似乎很高。

如果将数字设置得太高,我们可能会遇到什么问题?为什么这个默认值低至 4?

请注意,当您使用 ThreadPool.SetMinThreads(…) 设置一个值时,这并不意味着那么多线程会立即启动或始终保持。这只是意味着线程池将按需提供新的工作线程或 I/O 完成线程(没有任何限制),直到达到每种线程类型的 "Minimum" 设置。

默认情况下,最小线程数设置为系统上的处理器数。

您不必将其设置为 200-300。您可以将其增加到某个值(比如 100)并根据需要进行相应调整。如果出现突发负载,您将需要更大的数字。