从上一篇博客《使用Azure Redis Cache》我们已经可以创建并使用Redis Cache为我们服务了。
作为Web开发者,我们都知道Session状态默认是保存在内存中的,它的优点是可以快速读取,但是缺点也是很明显的,只能应用在单台服务器系统上,无法应用在集群系统中,而且一旦服务器宕机或内存泄漏,Session都是可能丢失的。
为了解决在分布式应用中Session的读取问题,我们可以将Session持久化到数据库中,但这又带来了新的问题,增加了IO,降低了应用程序的性能。
1、Redis Cache来了
但是现在我们有了Redis Cache,它完美的解决了进程内Session的一些缺点,既使得应用程序可以快速读取Session,也能分布式系统应用中如鱼得水。
- 快读读取,Redis Cache是一种高级的键值存储
- 提供主从复制,保证了数据的可用性
- 支持大多数编程语言
- 提供身份验证,保证数据的安全性
2、Redis Cache作为会话状态提供程序
创建一个Web Application,右键"引用",点击管理NuGet程序包,在搜索框中输入RedisSessionStateProvider,然后安装。
由于Session状态提供程序包依赖StackExchange.Redis.StrongName程序集,我们会看到StackExchange.Redis.StrongName也被安装引用到Web应用程序中。这里有一个细节需要注意下:StackExchange.Redis.StrongName是strong-named version,而StackExchange.Redis是non-strong-named version。所以如果Web应用程序如果在之前引用了StackExchange.Redis程序集,那么我们需要删除对StackExchange.Redis程序集的引用。
完成程序集的引用后,我们可以在web.config文件中看到下面这段xml内容:
<sessionStatemode="Custom" customProvider="MySessionStateStore"> <providers> <!-- <add name="MySessionStateStore" type="Microsoft.Web.Redis.RedisSessionStateProvider" host = "127.0.0.1" [String] port = "" [number]//如果RedisCache开启了SSL,那么此处需填写为SslPort,否则报错 accessKey = "" [String] ssl = "false" [true|false]//如果RedisCache开启了SSL,此处填true throwOnError = "true" [true|false] retryTimeoutInMilliseconds = "0" [number] databaseId = "0" [number] applicationName = "" [String] connectionTimeoutInMilliseconds = "5000" [number] operationTimeoutInMilliseconds = "5000" [number] /> --> </providers> </sessionState>
- host – Redis Cache的host name/endpoint
- port – 使用你的Redis Cache的SSL port或者非SSL port,这取决你的ssl设置的值
- accessKey – Redis Cache的Keys
- ssl – true (Cache/Client之间安全的通信); 否则设为 false
- 默认禁用 non-SSL port,有关启用 non-SSL port,参阅 Access Ports
- throwOnError – true (在事件出错时抛出异常),否则设为 false. 你可以在静态属性 Microsoft.Web.Redis.RedisSessionStateProvider.LastException检查异常信息, 默认为true。
- retryTimeoutInMilliseconds – 在此时间间隔内重试操作(单位:毫秒)
- databaseId – 指定一个数据库用来存储缓存输入数据。如果未指定,默认值为0。
- applicationName – 缓存key存储在Redis中命名规则为:
{<Application Name>_<Session ID>}_Data
,如果多个应用程序共享相同的key,则这个参数是可选的。 如果不设置该参数将使用默认值。 - connectionTimeoutInMilliseconds – 这个设置会覆盖connectTimeout参数设置。如果未设置,那么会使用默认的connectTimeout值5000,详情请参考 StackExchange.Redis configuration model.
- operationTimeoutInMilliseconds – 这个设置会覆盖syncTimeout参数设置。如果未设置,那么会使用默认的syncTimeout值1000,详情请参考 StackExchange.Redis configuration model.
3、注释ASP.NET默认的Session状态提供程序
最后一步也是非常重要的,我们打开web.config文件将一下xml内容注释
<!-- <sessionState mode="InProc" customProvider="DefaultSessionProvider"> <providers> <add name="DefaultSessionProvider" type="System.Web.Providers.DefaultSessionStateProvider, System.Web.Providers, Version=1.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35" connectionStringName="DefaultConnection" /> </providers> </sessionState> -->
更多关于Session State提供的更佳实现,参考Web Development Best Practices (Building Real-World Cloud Apps with Azure)