我将ASP.NET MVC工作流配置为由负载平衡器管理的两个网站。网站使用sql Server作为会话状态提供者,并关闭身份验证(不需要)。
现在,偶尔我似乎正在失去会话状态,我相信这是因为该请求是由替代服务器处理的,所以本质上用户是从服务器跳到服务器,这取决于负载平衡器如何看待。我并不总是在工作流程的同一阶段“丢失会话状态”,所以我相信它是与web farm配置sql server会话状态有关的。
两个应用程序使用相同的机器密钥来加密和解密存储在sql server中的会话状态。
两台服务器上的配置如下:
<authentication mode="None" /> <sessionState mode="sqlServer" sqlConnectionString="{connection-string}" /> <machineKey decryptionKey="777CB456774AF02F7F1AC8570FAF31545B156354D9E2DAAD" validationKey="89B5B536D5D17B8FE6A53CBB3CA8B8695289BA3DF0B1370BC47D362D375CF91525DDB5307D8A288230DCD4B3931D23AED4E223955C45CFF2AF66BCC422EC7ECD" />
我已经确认这在两台服务器上都是一样的,有没有我失踪的东西?
当我使用单个服务器时,这不会在我的开发环境中发生。
我害怕我受到周五蓝调的痛苦,毫无疑问,下周将会找出答案,可悲的是我不想等待!
有任何想法吗?