AICon 上海站|90%日程已就绪,解锁Al未来! 了解详情
写点什么

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

  • 2015-11-19
  • 本文字数:1358 字

    阅读完需:约 4 分钟

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,微软提供了在.NET Node.js Java Python 中使用 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))。

2015-11-19 18:002628
用户头像

发布了 1008 篇内容, 共 411.2 次阅读, 收获喜欢 346 次。

关注

评论

发布
暂无评论
发现更多内容

AI大模型之花,绽放在鸿蒙沃土

脑极体

鸿蒙 AI

金奖方案 | 一专多能、傲视寰宇,南大通用GBase8c数据库牛在哪里?

daydayup

Dify.AI 用户直面会总结:Embedding 技术与 Dify 数据集设计/规划

Dify

开源项目 AI技术实践 LLMOps

重磅更新 | 大幅提升数据集命中预期;AI 联网搜索能力也来了!

Dify

AI技术 开源软件 LLMOps

面部表情识别的技术实现

数据堂

数据库迁移系列】从MySQL到openGauss的数据库对象迁移实践

daydayup

openGauss内核荣获中国首个国际CC EAL4+级别认证

daydayup

这个Python项目让古诗变得更易读,看完《长安三万里》惊艳了!

程序员晚枫

Python 拼音 长安三万里 古诗词

openGauss的SQL引擎在3.1.0版本中做了哪些优化?

daydayup

java代码加壳加密工具 jar-protect

车江毅

语义检索系统之排序模块:基于ERNIE-Gram的Pair-wise和基于RocketQA的CrossEncoder训练的单塔模型

汀丶人工智能

人工智能 自然语言处理 排序算法 语义搜索 搜索推荐系统

阿里云出品—高分计算机好书推荐榜

穿过生命散发芬芳

计算机图书

openGauss内核分析(二.二):简单查询的执行

daydayup

基于无监督训练SimCSE+In-batch Negatives策略有监督训练的语义索引召回

汀丶人工智能

人工智能 自然语言处理 语义搜索 搜索推荐系统

2023-08-02:给定一棵树,一共有n个点, 每个点上没有值,请把1~n这些数字,不重复的分配到二叉树上, 做到 : 奇数层节点的值总和 与 偶数层节点的值总和 相差不超过1。 返回奇数层节点分配

福大大架构师每日一题

福大大架构师每日一题

Sprint Boot学习路线4

小万哥

Java spring 微服务 Spring Cloud Spring Boot

openGauss —— 智能优化器之基数估计

daydayup

openGauss数据库从3.0.0升级到3.1.0操作实践

daydayup

Amazon Aurora Serverless v2 正式发布:针对要求苛刻的工作负载的即时扩展

亚马逊云科技 (Amazon Web Services)

MySQL

openGauss赋能企业核心场景应用 | 华为全联接大会2022专题回顾

daydayup

openGauss内核分析(二.一):简单查询的执行

daydayup

如何利用 AI 在 5 分钟批量产出 100 篇 SEO 文章?

Dify

批量任务 SEO AI技术实践 LLMOps

面部表情识别的挑战和前景

数据堂

语义检索系统:基于Milvus 搭建召回系统抽取向量进行检索,加速索引

汀丶人工智能

自然语言处理 nlp 搜索推荐系统 语义搜索系统 向量搜索

“数智新应用”不再是口号,看汽车、医药、制造企业如何突出重围?

Kyligence

数智化转型

既要增长又要人效,零售人准备好接受老板的灵魂拷问了吗

Kyligence

数据分析 零售行业

活动预告 | 中国数据库联盟(ACDU)中国行第二站定档杭州,邀您探讨数据库技术与实践!

墨天轮

数据库 oracle postgresql AntDB oceanbase

语义检索系统:基于无监督预训练语义索引召回:SimCSE、Diffcse

汀丶人工智能

自然语言处理 nlp 向量检索 语义检索 搜索推荐系统

在微软Azure中用Redis为ASP.NET应用加速_微软_谢丽_InfoQ精选文章