在微软 Azure 中用 Redis 为 ASP.NET 应用加速

阅读数:1652 2015 年 11 月 19 日

话题:微软云计算Azure语言 & 开发架构

Azure Redis Cache是微软 Azure 提供的一项托管服务。该服务基于开源 Redis 缓存构建,能够利用 Redis 引擎低延迟、高吞吐量的特性提高应用程序的响应速度。

目前,Azure Redis Cache 包含以下三个服务等级:

  • 基本服务:仅有一个缓存节点,适合开发 / 测试和非关键工作负载,无 SLA。
  • 标准服务:有两个节点(主节点 / 备用节点),具备自动故障转移和自动复制功能,提供高可用 SLA。
  • 高级服务(预览):包含标准服务的所有特性,性能更好,安全性更高,支持更大的工作负载及灾难恢复。要了解更多特性,请查看这里

其中,基本 / 标准服务缓存上限为 53GB,而高级服务的缓存上限为 530GB。价格信息可以查看这里

Scott Hanselman是微软 Web 平台 & 工具部门的一名项目经理。去年,他曾撰文介绍Azure Redis Cache的基本用法。近日,他又介绍了一种新的 Azure Redis Cache 应用场景,即将其作为 ASP.NET 应用的缓存。

重要通知:接下来 InfoQ 将会选择性地将部分优秀内容首发在微信公众号中,欢迎关注 InfoQ 微信公众号第一时间阅读精品内容。

据 Scott 介绍,ASP.NET 现在提供了很好的 Redis 支持,可以从 NuGet 上下载 Microsoft.Web.RedisSessionStateProvider 库:

Install-Package Microsoft.Web.RedisSessionStateProvider

该库底层使用了StackExchange,但允许 ASP.NET 使用 Session 对象,并在 Redis 中保存结果,而不是在 Web 服务器的内存中。使用下面的代码在 web.config 中添加该库:

<sessionState mode="Custom" customProvider="FooFoo">
      <providers>               <add name="MySessionStateStore" 
            type="Microsoft.Web.Redis.RedisSessionStateProvider" 
            host="hanselcache.redis.cache.windows.net"
            accessKey="THEKEY" 
            ssl="true"
            port="1234" />
    </providers>
</sessionState>

Redis Desktop Manager中可以看到存储在 Redis 中的 ASP.NET Session 数据,如下图所示:

Redis Cache 不仅可以用于存储 Session State,而且还可以用于 Output Cache,即将整个 HTTP 响应缓存。相应的库在 ASP.NET 4.x 中的安装方法同 Session State Provider 类似:

Install-Package Microsoft.Web.RedisOutputCacheProvider

这样,当在 MVC Controller 中使用 [OutputCache] 属性或在 Web Forms 中使用 OutputCache 指令(如 <%@ OutputCache Duration="60" VaryByParam="*" %>)时,响应就会通过 Redis 来处理。对于类似产品目录这样的应用,可使其响应速度提高 4~10 倍。

用户也可以通过编程使用 Redis,微软提供了在.NETNode.jsJavaPython中使用 Azure Redis Cache 的文档。如果不想在 Azure 甚或 Linux 上运行Redis,那么可以选用MSOpenTech 的 Redis on Windows 分支。安装完成后,就可以通过命令行使用 redis-cli.exe 同 Azure Redis Cache 交互。而如果使用了本地 Redis 服务器(redis-server.exe),那么在部署到 Azure 的时候需要修改应用的 Redis 连接字符串。


感谢魏星对本文的审校。

给 InfoQ 中文站投稿或者参与内容翻译工作,请邮件至editors@cn.infoq.com。也欢迎大家通过新浪微博(@InfoQ@丁晓昀),微信(微信号:InfoQChina)关注我们,并与我们的编辑和其他读者朋友交流(欢迎加入 InfoQ 读者交流群(已满),InfoQ 读者交流群(#2))。