【问题标题】:Redis how to find optimal value for IOCPRedis如何找到IOCP的最佳值
【发布时间】:2017-08-12 19:38:50
【问题描述】:

目前,我们在使用向 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)

我们怎样才能找到最小/最大wokerthreads的最佳数量? Redis 建议从 200-300 开始。但是当我们与默认值 4 相比时,这似乎很高。

将数字设置得太高时可能会遇到什么问题?为什么这个默认值低到 4?

【问题讨论】:

    标签: multithreading redis timeout


    【解决方案1】:

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

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

    您不必将其设置为 200-300。您可以将其增加到某个值(例如 100)并根据需要进行相应调整。在突发负载的情况下,您将需要更高的数量。

    【讨论】:

      猜你喜欢
      • 2018-03-17
      • 1970-01-01
      • 2012-06-11
      • 1970-01-01
      • 2022-06-14
      • 1970-01-01
      • 2021-06-29
      • 1970-01-01
      • 2019-09-08
      相关资源
      最近更新 更多