0

我正在研究缓存一些可以重用的数据库值的要求。但我希望同一服务器中的所有处理器都可以访问缓存。

概述:

所以基本上,会有多个处理器从一个 API 获取工作并将记录处理到数据库。其中一些数据库值将被缓存。

处理器将是多个 Windows 服务,我希望它们共享相同的缓存。 如何使用 Ncache 来实现这一点。我对使用它很陌生。因此,非常感谢任何链接或方向。

4

1 回答 1

2

NCache最大的价值在于可以作为OutProc分布式内存缓存,缓存驻留在NCache进程本身;这与InProc将访问限制为单个进程的缓存不同。

您需要配置OutProc在单独的专用缓存服务器(或集群)或与您的服务相同的服务器上运行的缓存。

有关缓存的更多信息,请参阅http://www.alachisoft.com/resources/docs/ncache/admin-guide/local-cache.html 。OutProcInProc

安装 NCache 服务器后,您可以通过修改config.ncconf默认位于C:\Program Files\NCache\config.

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<configuration>
    <cache-config cache-name="MyOutProcCacheName">
    <cache-settings inproc="False">
      <logging enable-logs="True" trace-errors="True" trace-debug="False" log-path=""/>
      <performance-counters enable-counters="True" snmp-port="0"/>
      <cache-notifications item-remove="False" item-add="False" item-update="False"/>
      <cleanup interval="15sec"/>
      <storage type="heap" cache-size="2024mb"/>
      <eviction-policy default-priority="normal" eviction-ratio="5%"/>
      <cache-topology topology="local-cache"/>
      <client-death-detection enable="False" grace-interval="60sec"/>
    </cache-settings>
  </cache-config>
 </configuration>

上述配置将OutProc在本地服务器上创建一个缓存(请参阅 参考资料cache-topology)。如果需要,可以将其配置为集群环境中的各种镜像、分区或复制缓存(请参阅http://www.alachisoft.com/resources/docs/ncache/admin-guide/cache-topologies.html)。

然后,您可以启动该NCache服务,并从您的应用程序中连接到该服务,并在上述配置中初始化与命名缓存实例的连接。

Cache outProcCache = NCache.InitializeCache("MyOutProcCacheName");

您还可以通过将配置参数发送到上述方法,NCache完全在代码而不是文件中配置与服务器/服务的连接。client.ncconfInitializeCache

CacheInitParams connectionParams = new CacheInitParams();
connectionParams.ServerList = new CacheServerInfo[]{ new CacheServerInfo("ncacheIp", ncachePort) };

Cache outProcCache = NCache.InitializeCache("MyOutProcCacheName", connectionParams);
于 2019-01-25T13:53:41.687 回答