写点什么

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:533965
用户头像

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

关注

评论

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

响应号召,开始14天的居家隔离 | 视频号 28 天 (14)

赵新龙

28天写作

竟然输给了一款软件「幻想小说 13/28」

道伟

28天写作

老龄化不可避免,灰犀牛是否可以成为黑天鹅?

JiangX

政策 28天写作 双循环 人口结构

Git学习【1】 -- 基本常用命令

秦怀杂货店

git GitHub

创业统一战线 Jan 21, 2021

王泰

28天写作

苹果的董事长是谁?别去搜了,看这。

Justin

28天写作 冷知识

DDD分层架构最佳实践

Barry的异想世界

Spring Boot DDD 架构设计 领域驱动设计DDD

LKA是如何实现的(28天写作 Day13/28)

mtfelix

自动驾驶 28天写作

两层和三层网络架构差异

【并发编程的艺术】JAVA并发机制的底层原理

程序员架构进阶

Java 架构 并发编程 内存模型 28天写作

Soul 学习笔记---使用 zookeeper 实现数据同步(六)

fightingting

Soul网关

Python实用代码-无限级分类树状结构生成算法

穿甲兵

Python 算法

CWE 4.3:强化你的数据自我保护能力

华为云开发者联盟

网络安全 安全 数据保护 cwe gdpr

28天瞎写的第二百二十四天:食品专业的编程高手

树上

28天写作

项目管理变更之交付目标的变化

L3C老司机

soul数据同步(一)概述及websocket同步策略

xzy

Soul网关 soul

存在即合理

lidaobing

比特币 28天写作

Soul 源码阅读 01|数据同步

哼干嘛

Java Soul网关

SpringCloud 从入门到精通14---OpenFeign服务调用

Felix

JavaScript对象

hao-kuai

JavaScript 继承 原型 原型链

甲方日常 88

句子

工作 随笔杂谈 日常

大数据知识专栏 - MapReduce的Combiner实现shuffle调优

小马哥

大数据 hadoop mapreduce 七日更

Go中的SSRF攻防战

Gopher指北

安全 Go 语言

Mybatis【13】-- Mybatis动态Sql标签的使用

秦怀杂货店

sql mybatis

HDFS杂谈:DFSAdmin Report解读

罗小龙

hadoop hdfs 28天写作 dfsadmin

如何成为分享高手(下)

熊斌

演讲 经验分享 成长笔记 28天写作

如何保持积极

Ian哥

28天写作

Windows DHCP最佳实践(三)

BigYoung

windows Windows Server 2012 R2 DHCP

【小菜学网络】交换机与MAC地址学习

fasionchan

网络编程 网络协议 TCP/IP 交换机

JavaScript函数

hao-kuai

JavaScript 闭包 Function 箭头函数

合约交易软件系统APP开发案例

系统开发

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