0

当我关闭托管用户会话的三节点集群中的一个节点时,我的 Web 应用程序中出现以下异常。

会话缓存也有辅助,没有驱逐。

这是错误消息和堆栈:

Exception information: 
    Exception type: DataCacheException 
    Exception message: ErrorCode<ERRCA0022>:Cache::GetAndLock: There is a temporary failure, please retry after some time. 

Stack trace:    at Microsoft.Data.Caching.DataCache.ExecuteAPI(RequestBody reqMsg, String apiName)
   at Microsoft.Data.Caching.DataCache.InternalGetAndLock(String key, TimeSpan timeout, DataCacheLockHandle& lockHandle, String region)
   at Microsoft.Data.Caching.DataCache.GetAndLock(String key, TimeSpan timeout, DataCacheLockHandle& lockHandle)
   at Microsoft.Data.Caching.DataCacheSessionStoreProvider.GetItemExclusive(HttpContext context, String id, Boolean& locked, TimeSpan& lockAge, Object& lockId, SessionStateActions& actions)
   at System.Web.SessionState.SessionStateModule.GetSessionStateItem()
   at System.Web.SessionState.SessionStateModule.PollLockedSessionCallback(Object state)

如果我稍后重试请求,该消息将消失。为什么我首先收到此消息,并且服务器不应该自行确定主机已关闭并切换到其他客户端之一。我在 web.config 文件中将会话客户端定义为简单,以防万一它是路由问题,但问题仍然存在。

4

1 回答 1

0

请参考以下博客:

http://blogs.msdn.com/velocity/archive/2009/04/30/the-dreaded-error-cache-get-the-request-timed-out.aspx

http://blogs.msdn.com/velocity/archive/2009/06/17/troubleshooting-velocity-series.aspx

回答您关于服务器自行解决的问题;它实际上可以做到这一点,但是由于我们无法从应用程序开发人员的角度做出选择(重试或故障快速),我们将其留给应用程序为自己采用正确的行为(重试、故障返回到数据库等)。因此,我们默认重试,但如果某些应用程序需要,我们也同意内置一些重试逻辑。希望这能回答您的问题。

于 2009-12-28T12:59:31.393 回答