web性能优化——JSP
一、啰嗦
做web开发的都知道,性能的重要性就不必强调了。就前端展示的工作来说,jsp大家都熟悉html更熟悉;web服务器tomcat应该是最熟悉的了;web方面的基础知识上来说,静态页面比动态页面效率要高(什么是动态页面什么是静态页面不说了),在项目初期或者孵化阶段,人手少,工期短,资金更少,不可能按照高性能的架构一步到位,那么怎么在有效的资源上做出牛逼的东西呢——优化
jsp页面中可以写java代码、el表达式、jstl标签等。对于jsp里面的静态标签(html的标签等)应该效率是最高的,其次应该是java了,因为jsp会被编译为java代码(理论,没有测试),在接下来就是el和jstl了。
二、问题
今天遇到的一个问题是:
一些配置信息,可以从后台全局性的传到jsp页面中,然后进行资源的读取;也可以在页面中使用java代码读取这些静态的配置,然后在模板里面使用jstl设置变量,再做访问。
这两种方式个人认为前者的效率会更高,可能自己知识面太窄,没有充足的理论依据。
三、验证
带着问题,首先希望是在网上巴拉了一大圈,没找到相关的文章;又搜了一些tomcat解析原理,没找到有用的,直接DEMO试一下。
机器:个人pc(12g+256ssd+i5)
服务器:tomcat
框架:spring mvc
测试流程:每次会把tomcat停止后,重新启动tomcat,进行第二次测试
controller定义:
jstl方法中直接返回视图;var方法中在视图中添加变量;如下:
@RequestMapping("jstl")
public ModelAndView jstlTest() {
ModelAndView mv = new ModelAndView();
mv.setViewName("jstl");
return mv;
}
@RequestMapping("var")
public ModelAndView varTest() {
ModelAndView mv = new ModelAndView();
mv.addObject("v", 120);
mv.setViewName("var");
return mv;
}
JSP页面:
jstl.jsp页面,使用jstl设置变量,然后使用el表达式在读出来。如下:
<c:set var="v" value="120"></c:set>
${v }
var.jsp页面,在直接读取controller中的变量。如下:
${v }
一切就绪了,下面是测试程序,对指定页面访问10w次:
@Test
public void testJstl() {
long start = System.currentTimeMillis();
for (int i = 0; i < 100000; i++) {
try {
String document = Jsoup.connect("http://localhost:8080/news/test/jstl").get().body().text();
System.out.println(document);
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
long end = System.currentTimeMillis();
System.out.println(end + "-" + start + "=" + (end - start));
} @Test
public void testVar() {
long start = System.currentTimeMillis();
for (int i = 0; i < 100000; i++) {
try {
String document = Jsoup.connect("http://localhost:8080/news/test/var").get().body().text();
System.out.println(document);
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
long end = System.currentTimeMillis();
System.out.println(end + "-" + start + "=" + (end - start));
}
测试结果:
|
变量设置方式 |
开始时间 |
结束时间 |
耗时 |
|
controller |
1479991964321 |
1479991897879 |
66442 |
|
jstl |
1479991819067 |
1479991750981 |
68086 |
只有一个变量的情况的下,访问10次,在controller中设置变量,比使用jstl中设置变量快了1718毫秒
测试两个变量的情况:
jstl页面如下:
<c:set var="v" value="120"></c:set>
<c:set var="v1" value="120"></c:set>
${v }
${v1 }
var页面如下:
${v }
${v1 }
controller中只有var方法有变动,如下:
@RequestMapping("var")
public ModelAndView varTest() {
ModelAndView mv = new ModelAndView();
mv.addObject("v", 120);
mv.addObject("v1", 120);
mv.setViewName("var");
return mv;
}
测试结果:
| 变量设定方式 | 开始时间 | 结束时间 | 耗时 |
| controller | 1479991384043 | 1479991316874 | 67169 |
| jstl | 1479991153541 | 1479991084654 | 68887 |
测试用例取样值汇总
测试一共取了五个值测试,不知道准确性怎么样,希望高手指点一二
|
变量个数 |
变量设置方式 |
开始时间 |
结束时间 |
耗时 |
|
1 |
controller |
1479991964321 |
1479991897879 |
66442 |
|
jstl |
1479991819067 |
1479991750981 |
68086 |
|
|
2 |
controller |
1479991384043 |
1479991316874 |
67169 |
|
jstl |
1479991153541 |
1479991084654 |
68887 |
|
|
4 |
controller |
1479996126484 |
1479996055448 |
71036 |
|
jstl |
1479995801444 |
1479995716369 |
85075 |
|
|
8 |
controller |
1479996391785 |
1479996321319 |
70466 |
|
jstl |
1479996573521 |
1479996500165 |
73356 |
|
|
16 |
controller |
1479997049876 |
1479996974712 |
75164 |
|
jstl |
1479996906690 |
1479996830374 |
76316 |
测试结果在图表中展示,如下:

结论
不管从数据还是折线图,都可以明显得出在controller中设置变量,使用el在jsp中读取的性能优于,在页面存储读取。但是此次的测试数据和我心中的结果差别还是比较大的,测试之前,认为性能差距会随着变量的数量增多,而更加明显,然而结果和我想的有些不一样。
web性能优化——JSP的更多相关文章
- 关于WEB 性能优化 (摘抄)
压缩源代码和图片 JavaScript文件源代码可以采用混淆压缩的方式,CSS文件源代码进行普通压缩,JPG图片可以根据具体质量来压缩为50%到70%,PNG可以使用一些开源压缩软件来压缩,比如24色 ...
- Web性能优化-合并js与css,减少请求
Web性能优化已经是老生常谈的话题了, 不过笔者也一直没放在心上,主要的原因还是项目的用户量以及页面中的js,css文件就那几个,感觉没什么优化的.人总要进步的嘛,最近在被angularjs吸引着,也 ...
- web性能优化——浏览器相关
简介 优化是一个持续的过程.所以尽可能的不要有人为的参与.所以能自动化的或者能从架构.框架级别解决的就最更高级别解决. 这样即能实现面对开发人员是透明的.不响应,又能确保所有资源都是被优化过的. 场景 ...
- Web性能优化系列
web性能优化之重要,这里并不打算赘述.本系列课程将带领大家认识.熟悉.深刻体会并且懂得如果去为不同的站点做性能优化 同时,本系列将还会穿插浏览器兼容性相关问题的解决方案,因为在我看来,兼容性同样属于 ...
- 移动web性能优化笔记
移动web性能优化 最近看了一些文章,对移动web性能优化方法,做一个简单笔记 笔记内容主要出自 移动H5前端性能优化指南和移动前端系列——移动页面性能优化
- web性能优化 来自《web全栈工程师的自我修养》
最近在看<web全栈工程师的自我修养>一书,作者是来自腾讯的前端工程师.作者在做招聘前端的时候问应聘者web新能优化有什么了解和经验,应聘者思索后回答“在发布项目之前压缩css和 Java ...
- web性能优化之--合理使用http缓存和localStorage做资源缓存
一.前言 开始先扯点别的: 估计很多前端er的同学应该遇到过:在旧项目中添加新的功能模块.或者修改一些静态文件时候,当代码部署到线上之后,需求方验收OK,此时你送了一口气,当你准备开始得意于自己的ma ...
- Web 性能优化:Preload与Prefetch的使用及在 Chrome 中的优先级
摘要: 理解Preload与Prefetch. 原文:Web 性能优化:Preload,Prefetch的使用及在 Chrome 中的优先级 作者:前端小智 Fundebug经授权转载,版权归原作者所 ...
- Web 性能优化:21 种优化 CSS 和加快网站速度的方法
这是 Web 性能优化的第 4 篇,上一篇在下面看点击查看: Web 性能优化:使用 Webpack 分离数据的正确方法 Web 性能优化:图片优化让网站大小减少 62% Web 性能优化:缓存 Re ...
随机推荐
- 黑马程序员-out和ref
C# 方法参数关键字:ref.out 当希望方法返回多个值时,声明 out方法很有用.使用 out参数的方法仍然可以将变量用作返回类型(请参见 return),但它还可以将一个或多个对象作为 out参 ...
- linux性能分析命令top
发布时间: 2013-12-14浏览次数:154分类: 服务器 top是linux最常用的性能分析工具了,它是个交互式工具,提供系统的整体性能,如正在执行的进程信息包括进程ID,内存占用率,CPU占用 ...
- 去掉eclipse上编辑时的提示
用eclipse时,鼠标移到类上时会给出提示,如下图:
- QT5-控件-QProgressBar-进度条-用来做下载进度,文件读取进度还不错
#ifndef MAINWINDOW_H #define MAINWINDOW_H #include <QMainWindow> #include <QProgressBar> ...
- 洛谷 P1515 旅行
P1515 旅行 题目描述 你要进行一个行程为7000KM的旅行,现在沿途有些汽车旅馆,为了安全起见,每天晚上都不开车,住在汽车旅馆,你手里现在已经有一个旅馆列表,用离起点的距离来标识,如下: 0, ...
- 关于keil单片机编程中的data,idata,xdata,pdata,code数据类型
从数据存储类型来说,8051系列有片内.片外程序存储器,片内.片外数据存储器,片内程序存储器还分直接寻址区和间接寻址类型,分别对应code.data.xdata.idata以及根据51系列特点而设定的 ...
- 拿起cl.exe,放下IDE
笔者在这里介绍一种使用cl.exe编译源文件的方法,可以手动执行编译过程而不再依赖IDE,此外,笔者还介绍一些使用cl.exe编译简单源代码的方式. cl.exe是windows平台下的编译连接程序, ...
- jQuery get/post区别及contentType取值
1.GET访问 浏览器 认为 是等幂的 就是 一个相同的URL 只有一个结果[相同是指 整个URL字符串完全匹配]所以 第二次访问的时候 如果 URL字符串没变化浏览器是直接拿出了第一次访问的结果,表 ...
- QQ登录api
<?php namespace Api\Member; class QQConnect{ /** * 获取QQconnect Login 跳转到的地址值 * @return array 返回包含 ...
- tomcat context标签中resource配置