4

我们使用 appfabric 作为 NHibernate asp.net 应用程序的二级缓存,该应用程序包括面向客户的网站和管理网站。它们都连接到同一个缓存,因此当管理员更新某些内容时,面向客户的站点也会更新。

它似乎工作正常 - 我们在单独的服务器上有一个 CacheCLuster,一切都很好,但我们希望启用 localcache 以获得更好的性能,但是,它似乎没有工作。

我们已经像这样启用它...

  bool UseLocalCache = 
  int LocalCacheObjectCount = int.MaxValue;
  TimeSpan LocalCacheDefaultTimeout = TimeSpan.FromMinutes(3);
  DataCacheLocalCacheInvalidationPolicy LocalCacheInvalidationPolicy = DataCacheLocalCacheInvalidationPolicy.TimeoutBased;

        if (UseLocalCache)
        {
            configuration.LocalCacheProperties =
                new DataCacheLocalCacheProperties(
                    LocalCacheObjectCount,
                    LocalCacheDefaultTimeout,
                    LocalCacheInvalidationPolicy
                    );

          //  configuration.NotificationProperties =  new DataCacheNotificationProperties(500, TimeSpan.FromSeconds(300));
        }

最初我们尝试使用超时失效策略(3 分钟),我们的应用感觉运行得更快了。但是,我们注意到,如果我们在管理站点中更改某些内容,它会立即在实时站点中更新。由于我们使用的是超时而不是通知,这表明本地缓存没有被查询(或者是,但总是丢失)。

cache.GetType().Name 返回“LocalCache” - 所以工厂已经做了一个本地缓存。

在我的开发环境中的 PS 中运行“Get-Cache-Statistics MyCache”(从 vs2008 本地运行的 asp.net 应用程序,在单独的 w2k8 机器上运行的缓存集群)显示了一些请求计数。但是,在生产环境中,请求计数会急剧增加。

我们尝试按照此处的方法来设置缓存客户端服务器流量... http://blogs.msdn.com/b/appfabriccat/archive/2010/09/20/appfabric-cache-peeking-into-client-amp -server-wcf-communication.aspx 但日志文件中只有初始标头 - 即也没有登录。

我在 SO 或 Google 中找不到任何东西。

我们做错了什么吗?我们是否安装了 AppFabric - 我们通过 WebPlatform Installer 安装了它 - 我想?(注意:运行 ASp.net 的 IIS 框不在集群中 - 它只是客户端)。

任何见解都非常受欢迎!

4

3 回答 3

1

经过几天和几天的研究为什么我们会收到如此多的本地缓存未命中,我们终于解决了它:

  1. AppFabric v 1.1 中的本地缓存存在一个错误,该错误已在 CU4 中修复,请参阅http://support2.microsoft.com/kb/2800726/en-us
  2. 确保您的应用程序使用的 Microsoft.ApplicationServer.Caching.Client.dll 也已更新。我们在机器上安装了 CU4,但从我们应用程序的 NuGet 包中获得了没有 CU4 的 Client.dll。在我们的例子中,一个简单的 NuGet 包更新使一切正常。

安装 CU4 并确保 Client.dll 也已更新后,由于本地缓存命中增加,我们对 AppFabric 主机的读取减少了很多。耶!

于 2015-02-19T12:12:28.730 回答
1

DataCache您使用哪些方法从缓存中读取?无论是否配置了本地缓存,其中一些DataCache方法总是会对服务器产生影响。您几乎必须确保仅Get在希望利用本地缓存时才使用。

这是我对 AppFabric 缓存最大的缺点之一。他们没有向您解释任何这些,因此当您开始依赖本地缓存时,您开始陷入这些小陷阱,因为您不认为您正在为与服务交谈、通过网络传输数据而付出代价和反序列化对象,但你是。

最糟糕的是,我可以理解必须与服务交谈以确保本地缓存代表最新数据。我什至可以理解将数据传回,这样就不会进行多次调用。但是,我一生无法理解的是,即使本地缓存中的实例被验证仍然是从缓存中返回的当前版本,它们仍然会从线路反序列化对象,而不仅仅是返回实例那已经在记忆中了。如果您的对象很大/很复杂,这可能会造成很大的伤害。

于 2011-02-14T18:27:44.067 回答
0

您是否尝试过使用休眠分析器?http://nhprof.com/

还有这个: http: //mdcadmintool.codeplex.com/

这是管理和查看缓存的好方法。

这两个都可能有助于调试问题。

于 2011-01-10T18:45:08.613 回答