写点什么

PDC 09:ASP.NET 4 运行时的改进

  • 2009-11-26
  • 本文字数:1513 字

    阅读完需:约 5 分钟

在近期举办的 PDC 09 大会中,ASP.NET 团队的程序经理 Stefan Schackow 展示了 ASP.NET 4 在运行时方面的改进。改进主要围绕“性能”和“可扩展性”两个方面进行,具体表现三点:新的资源监视选项、会话状态以及输出缓存的扩展能力。

对于一个 Web 服务器来说,CPU 和内存占用量是两个较为重要的性能指标,而两者相比之下,内存相对又更容易成为瓶颈。自从 IIS 6 引入了“应用程序池”的概念开始,多个 ASP.NET 应用程序便可以工作在单个进程之中。但是在这种情况下,我们就很难通过性能监视器来获得某个特定的 Web 应用程序所占用的系统资源,这有时会让问题的定位变得困难重重。由于 CLR 4 可以获得某个单独的应用程序域所占用的 CPU,以及堆上托管内存的数量,于是在 ASP.NET 4 中引入了一个名为“应用程序域资源管理(AppDomain Resource Management,ARM)”的功能,它会检测并预估单个 Web 应用程序资源占用的趋势,并将各种数据开放给性能计数器。

在 ASP.NET 4 中,ARM 功能默认并不会开放。ARM 功能无法通过修改单独应用程序的 web.config 文件打开,你需要去系统的.NET 配置目录中修改 Aspnet.config 文件,在节点中将 AppDomainResourceMonitoring 启用,最后还需要重启应用程序池。然后便可以在性能监视器中查看 ASP.NET Applications 分类中的相应计数器。值得注意的是,性能监视器中显示的托管内存占用并非是精确值,而是一个“预测”,这是因为只有在第 2 代的 GC 发生时,CLR 才能获得托管堆中内存占用的准确数量。

在会话状态(Session State)使用方面,ASP.NET 4 也作出了有效的改进。Stefan 表示,客户中使用会话状态的 ASP.NET 应用程序数量之多超过了他的想象,尤其是跨进程(Out of Process)的 Session 使用方式更是影响 Web 应用程序性能的主要因素之一。因此,ASP.NET 4 利用.NET 中的压缩功能,对跨进程的会话状态进行了压缩,包括 SQL Server 和会话状态服务器——而这一切只需要在 web.config 中进行配置即可。进行压缩之后可以节省 1/3 到 2/3 的流量,不过会带来一些 Web 服务器的 CPU 压力。

目前,ASP.NET 运行时会根据当前请求的 Http Handler 是否实现 IRequireSessionState 接口来判断是否启用 Session。在 ASP.NET 4 中,开发人员可以通过编程接口来控制某个请求是否启用会话状态。此外,ASP.NET 4 还提供了“部分会话状态(Partial Session State)”的功能,即只加载会话状态指定 key 的数据,这除了有效减少会话状态的通信开销外,也提供了额外的扩展能力。例如,ASP.NET 团队打算在 AppFabric 分布式缓存(其前身为 Velocity)正式发布后,基于 AppFabric 构建一个新的 Session State Provider。

ASP.NET4 在输出缓存(Output Cache)上也增加了一些扩展点,主要可以让开发人员为控件和请求级别的缓存定制存储机制,例如磁盘,分布式缓存,甚至是云中,而在目前的 ASP.NET 中,所有数据都只能缓存在进程的内存中。这个扩展机制支持缓存的绝对过期(Absolute Expiration)时间,文件依赖,和静态替换和验证回调功能,不过为了保证缓存实现的通用性,它不支持相对过期(Sliding Expiration)时间和其他形式的依赖。与会话状态一样,在 AppFabric 发布之后,ASP.NET 团队也会提供相应的 Ouput Cache Provider,不过按照计划这会在 ASP.NET 4 RTM 之后才会发布了。Stefan 表示,这些额外的 Provider 扩展都会作为开源项目托管在 CodePlex 网站上。

最后,基于 IIS 7.5 的“预热”功能,ASP.NET 4 可以让IIS 7.5 自动运行web.config 中指定的页面。Stefan 表示,这个功能并不会给程序性能带来提高,只是让用户避免遭遇程序冷启动所带来的延迟效果。

你可以在 PDC 2009 的网站上浏览或下载本次演讲的完整录像及幻灯片等资源。

2009-11-26 04:534416
用户头像

发布了 157 篇内容, 共 60.8 次阅读, 收获喜欢 6 次。

关注

评论

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

Dify入门篇(3)| 配置你的第一个LLM:OpenAI/Claude/Ollama

测吧(北京)科技有限公司

人工智能 自动化测试 测试开发 dify

自控学习历程系列 自控维护经验总结(9)

万里无云万里天

工厂运维

2025年2月安全更新深度解析:微软与Adobe关键漏洞修复指南

qife122

安全更新 微软补丁

自控学习历程系列 人才梯队建设经验总结(1)

万里无云万里天

工厂运维

自控学习历程系列 人才梯队建设经验总结(2)

万里无云万里天

工厂运维

YashanDB ALTER DATABASE语句

YashanDB

数据库

【免费开源】基于 STM32F4 的四轴飞行器设计与实现——从零开始到成功起飞(项目源码打包分享)

申公豹

嵌入式

从京东的新AI计划,看到电商与大模型的新连接

脑极体

AI

天翼云与飞轮科技达成战略合作,共筑云数融合新生态

SelectDB

Doris SelectDB 天翼云 数据库 大数据 飞轮数据

自控学习历程系列 团队建设经验总结(1)

万里无云万里天

工厂运维

怎样进行YashanDB性能监控与优化?

数据库砖家

怎样利用YashanDB的存储过程优化查询性能

数据库砖家

分布式数据高效可靠检索新方法

qife122

分布式计算 信息检索

YashanDB ALTER DATABASE LINK语句

YashanDB

数据库

技术文档 | Pulsar 中的消息保留、过期及积压机制解析(上)

AscentStream

消息队列 pulsar

自控学习历程系列 自控维护经验总结(11)

万里无云万里天

工厂运维

机器学习数据收集优化技术解析

qife122

机器学习 算法优化

PromptPilot全模型兼容,数据产品能力上新!

新消费日报

AI公平性研究的三大挑战与解决方案

qife122

人工智能 机器学习

[LDAP: error code 34 - invalid DN]

刘大猫

人工智能 算法 智慧城市 智慧交通 invalid DN

自控学习历程系列 自控设计经验总结(1)

万里无云万里天

工厂运维

YashanDB ALTER FUNCTION语句

YashanDB

数据库

C#记录类型与集合的深度解析:从默认行为到自定义比较

qife122

C# 不可变集合

AI自我提升的五种技术路径

qife122

人工智能 自动化

运用YashanDB数据库构建智能分析平台的方法

数据库砖家

基于RankSVM改进相似案例检索排序性能

qife122

机器学习 法律AI

自控学习历程系列 自控维护经验总结(10)

万里无云万里天

工厂运维

自控学习历程系列 信息化经验总结(1)

万里无云万里天

工厂运维

自控学习历程系列 系统维护经验总结(1)

万里无云万里天

工厂运维

实用AI代理提示工程指南

qife122

机器学习 AI代理

苹果紧急修复针对Chrome用户的零日漏洞

qife122

零日漏洞 系统更新

PDC 09:ASP.NET 4运行时的改进_.NET_赵劼_InfoQ精选文章