asp.net Web form和asp.net MVC的一次性能比较

本文涉及的产品
性能测试 PTS,5000VUM额度
简介: 前次写完《别总以为asp.net mvc比asp.net web form好--web form的页面也可以体积小巧》后,收到不少评论。多数人不赞成本人提出的将viewstate放入session的做法。

前次写完《别总以为asp.net mvc比asp.net web form好--web form的页面也可以体积小巧》后,收到不少评论。多数人不赞成本人提出的将viewstate放入session的做法。那么就来试验一下。搭建一个性能测试对比的平台。做一个应用,分别用asp.net web form来实现和用asp.net MVC来实现。两个应用的页面外观是一致的。再搭建分布式的服务器,反向代理等。再加上一个性能测试用的http负载产生服务器。

 

性能测试环境

 

如下图:

性能测试服务器产生大量http请求来轰击反向代理的服务器。反向代理服务器用Round Robin的算法将这些请求导向到里面的服务器。里面的服务器返回http响应给反向代理的服务器,反向代理服务器再向性能测试服务器响应。

Server1和Server2的配置:2GB RAM, 1个 2GHz CPU,300G 硬盘   Windows Server 2008 R2

反向代理服务器的配置: 1GB RAM,  1个 2GHz CPU, 80G硬盘   Ubuntu Linux 11.04,

性能测试服务器配置:1GB RAM, 1 个 2GHz CPU, 80G硬盘   Windows XP

数据库服务器配置: 4GB RAM, 1 个 2G Hz CPU, 500G硬盘   Windows Server 2008 R2

也看到了,都是普通的机器。

反向代理所用软件 squid 3.1.4

Server1和Server2部署的是一样的应用程序,即asp.net web form的应用程序和asp.net MVC的应用程序都部署到这两台服务器上。同时Server1和Server2访问的是同一个数据库。在应用程序里做了一些web farm的配置。使得session存储在sql server的ASPState数据库中。Session数据就可在不同服务器上进行浮动。http请求可由Server1和Server2任何一个来响应。当然这里是只用了两个IIS服务器,可以加更多的。但是条件有限,只找得到两台。这是最小的分布式的场景。如果有更多的话,整个系统的总体性能会更好一些。这里的网络都是局域网络。

这里说一下如何对比。这里是用同一个应用程序的asp.net web form版本和asp.net MVC版本进行对比。从上面看到了,硬件都是一样的。软件这块,划分了常见的三层,BLL, DAL, 都是一样的。唯一的不同是表示层的技术,一个用的是asp.net web form, 一个用的是asp.net MVC。其他的环节都是一样的,只有这个表示层技术不同。对比的就是这个表示层技术。得说明的是,在asp.net web form中,采用了将viewstate放入session的方式。这样做的目的,其实前文的时候已经在评论中说明过,是为了将web form的HTML页面体积缩小,同时使viewstate和session一样获得在不同服务器之间浮动的特性。

这里是代码的download:(用的最古老的ado.net,没有采用TransactionScope,原因自己想。没有采用aop,所以重复代码好多,代码生成器生成的,根本不费事、、、不跑题太远,实在想说可以另写文章)。

 

性能测试

 

 下面就说这个性能测试了。采用了loadrunner 8.1。先录脚本,再调试一下脚本,这都是基本功了,不多说。准备好脚本,一个脚本是测试asp.net web form的,另一个脚本是测试asp.net MVC的。之后将这些脚本对着这个反向代理服务器轰击。开始时是试探性的,只用10个用户,没有问题,再加,试了还没有问题,再加,如此循环下去,直到,加压到一定程度,这个性能测试中返回有失败的case时,才停下。采用这种方式,试了很多,发现这些数据:

asp.net web form用户为600时:

 

 

asp.net web form 用户数为800时:

 

asp.net web form 用户数为1200时:

 

asp.net web form 用户数为1500时,才出现了失败的case:

 

asp.net MVC 用户数为600时,就已经开始有失败的case:

  

asp.net mvc 用户数为800时,失败的case多了一点点:

 

 

asp.net mvc 用户数为1200时,失败的case又多了一些:

 

asp.net mvc 用户数为1500时,失败的case又多了一些:

 

完整的测试结果下载: download   包括loadrunner报告和loadrunner截屏。

 

结论

    经过这些对比。asp.net web form加上viewstate放入session中的安排,其性能并不输给asp.net MVC。而且略有一点点占优。还是之前说的观点:只要没有过度地使用viewstate或者session,合理地利用viewstate和session(如何合理利用,可以见《关于大型asp.net应用系统的架构—如何做到高性能高可伸缩性》),asp.net web form也可以在性能上表现比较好的,甚至有可能超过asp.net MVC的表现。所以不要轻易地下结论,也不要轻易地否定一个技术。当然了,这里可能还是有些局限性,看到的是片面的。期望大家给予你们的真知灼见。

 

 

2012.07.10. 21:47增加内容

针对下面评论中的意见,做了一个web form未优化时的性能测试。之前做的所谓优化,就是将viewstate放到session里了。见web form工程里的那个BasePage类。如果让所有aspx的后端类都继承System.Web.UI.Page类,就去掉了这个所谓的优化。经过测试,发现即使什么优化都没有,web form还是要比asp.net mvc的性能好。一直压到1400个用户时才出现失败的case.

 

可以看到,未加viewstate放入session特性,最大用户为1400,加了viewstate放入session特性,最大用户为1500,所以将viewstate放入session中后,所带来的性能的改进似乎很有限。

当然还有评论建议都做优化后再对比。可以以后再来做。今天就暂时这样了。谢谢

end of 20120710添加内容

相关实践学习
通过性能测试PTS对云服务器ECS进行规格选择与性能压测
本文为您介绍如何利用性能测试PTS对云服务器ECS进行规格选择与性能压测。
目录
相关文章
|
2月前
|
开发框架 前端开发 JavaScript
ASP.NET Web Pages - 教程
ASP.NET Web Pages 是一种用于创建动态网页的开发模式,采用HTML、CSS、JavaScript 和服务器脚本。本教程聚焦于Web Pages,介绍如何使用Razor语法结合服务器端代码与前端技术,以及利用WebMatrix工具进行开发。适合初学者入门ASP.NET。
|
4月前
|
XML JSON API
ServiceStack:不仅仅是一个高性能Web API和微服务框架,更是一站式解决方案——深入解析其多协议支持及简便开发流程,带您体验前所未有的.NET开发效率革命
【10月更文挑战第9天】ServiceStack 是一个高性能的 Web API 和微服务框架,支持 JSON、XML、CSV 等多种数据格式。它简化了 .NET 应用的开发流程,提供了直观的 RESTful 服务构建方式。ServiceStack 支持高并发请求和复杂业务逻辑,安装简单,通过 NuGet 包管理器即可快速集成。示例代码展示了如何创建一个返回当前日期的简单服务,包括定义请求和响应 DTO、实现服务逻辑、配置路由和宿主。ServiceStack 还支持 WebSocket、SignalR 等实时通信协议,具备自动验证、自动过滤器等丰富功能,适合快速搭建高性能、可扩展的服务端应用。
243 3
|
2月前
|
开发框架 .NET PHP
ASP.NET Web Pages - 添加 Razor 代码
ASP.NET Web Pages 使用 Razor 标记添加服务器端代码,支持 C# 和 Visual Basic。Razor 语法简洁易学,类似于 ASP 和 PHP。例如,在网页中加入 `@DateTime.Now` 可以实时显示当前时间。
|
5月前
|
开发框架 监控 前端开发
在 ASP.NET Core Web API 中使用操作筛选器统一处理通用操作
【9月更文挑战第27天】操作筛选器是ASP.NET Core MVC和Web API中的一种过滤器,可在操作方法执行前后运行代码,适用于日志记录、性能监控和验证等场景。通过实现`IActionFilter`接口的`OnActionExecuting`和`OnActionExecuted`方法,可以统一处理日志、验证及异常。创建并注册自定义筛选器类,能提升代码的可维护性和复用性。
|
5月前
|
开发框架 .NET 中间件
ASP.NET Core Web 开发浅谈
本文介绍ASP.NET Core,一个轻量级、开源的跨平台框架,专为构建高性能Web应用设计。通过简单步骤,你将学会创建首个Web应用。文章还深入探讨了路由配置、依赖注入及安全性配置等常见问题,并提供了实用示例代码以助于理解与避免错误,帮助开发者更好地掌握ASP.NET Core的核心概念。
137 3
|
5月前
|
开发框架 前端开发 .NET
VB.NET中如何利用ASP.NET进行Web开发
在VB.NET中利用ASP.NET进行Web开发是一个常见的做法,特别是在需要构建动态、交互式Web应用程序时。ASP.NET是一个由微软开发的开源Web应用程序框架,它允许开发者使用多种编程语言(包括VB.NET)来创建Web应用程序。
102 6
|
5月前
|
前端开发 安全 Java
技术进阶:使用Spring MVC构建适应未来的响应式Web应用
【9月更文挑战第2天】随着移动设备的普及,响应式设计至关重要。Spring MVC作为强大的Java Web框架,助力开发者创建适应多屏的应用。本文推荐使用Thymeleaf整合视图,通过简洁的HTML代码提高前端灵活性;采用`@ResponseBody`与`Callable`实现异步处理,优化应用响应速度;运用`@ControllerAdvice`统一异常管理,保持代码整洁;借助Jackson简化JSON处理;利用Spring Security增强安全性;并强调测试的重要性。遵循这些实践,将大幅提升开发效率和应用质量。
85 7
|
5月前
|
前端开发 测试技术 开发者
MVC模式在现代Web开发中有哪些优势和局限性?
MVC模式在现代Web开发中有哪些优势和局限性?
|
6月前
|
开发者 前端开发 Java
架构模式的诗与远方:如何在MVC的田野上,用Struts 2编织Web开发的新篇章
【8月更文挑战第31天】架构模式是软件开发的核心概念,MVC(Model-View-Controller)通过清晰的分层和职责分离,成为广泛采用的模式。随着业务需求的复杂化,Struts 2框架应运而生,继承MVC优点并引入更多功能。本文探讨从MVC到Struts 2的演进,强调架构模式的重要性。MVC将应用程序分为模型、视图和控制器三部分,提高模块化和可维护性。
55 0
|
6月前
|
Java 开发者 前端开发
Struts 2、Spring MVC、Play Framework 上演巅峰之战,Web 开发的未来何去何从?
【8月更文挑战第31天】在Web应用开发中,Struts 2框架因强大功能和灵活配置备受青睐,但开发者常遇配置错误、类型转换失败、标签属性设置不当及异常处理等问题。本文通过实例解析常见难题与解决方案,如配置文件中遗漏`result`元素致页面跳转失败、日期格式不匹配需自定义转换器、`<s:checkbox>`标签缺少`label`属性致显示不全及Action中未捕获异常影响用户体验等,助您有效应对挑战。
119 0