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 ... 
随机推荐
- 解决Cacti监控图像断断续续问题
			最近cacti的图像全都是断断续续.新加的设备,图像也是这样,查看cacti 的log发现大量下面类似的错误信息:04/12/2011 03:54:37 PM - SPINE: Poller[0] H ... 
- Windows8 正式版最简单的去除桌面水印方法
			方法一: 优点:无需替换文件,无需任何工具,对系统没有副作用缺点:更换主题或者壁纸之后水印再现方法:按住 “win键+P” 进入 “第二屏幕 ”选择 “扩展”再按住 “win键+P” 进入 “第二屏幕 ... 
- 武汉科技大学ACM :1001: 零起点学算法34——继续求多项式
			Problem Description 输入1个正整数n, 计算1+(1+2)+(1+2+3)+...+(1+2+3+...+n) Input 输入正整数n(多组数据) Output 输出1+(1+2 ... 
- JAVA-1-HelloWorld
			public class HelloWorld{ public static void main(String[] args){ System.out.println("HelloWorld ... 
- C++ Const成员函数
			一些成员函数改变对象,一些成员函数不改变对象. 例如: int Point::GetY() { return yVal; } 这个函数被调用时,不改变Point对象,而下面的函数改变Point对象 ... 
- Netty 5 传送大文件的方法
			Netty 5 提供了 一个ChunkedWriterHandler 来传送大文件,发送端如下: 添加chunedwriterhandler: ChannelPipeline p = ...; p.a ... 
- 记一次MySQl 安装1067错误
			1.今天阿里云windows server 2008 r2服务器上安装mysql,配置完发现无法启动mysql服务(并发设置的是500),查询windows日志提示 Unknown/unsupport ... 
- ssh登陆设置快捷方式
			在自己的环境下配置 ~/.ssh/config Host k231 HostName 192.168.1.231 User kyee 原来ssh 登陆192.168.1.231 的命令是 ssh ky ... 
- Android实现三级联动下拉框 下拉列表spinner
			Android实现(省.市.县)三级联动下拉框 下拉列表spinner 转载请注明出处: http://www.goteny.com/articles/2013/11/46.html http://w ... 
- git设置过滤忽略的文件或文件夹
			我们一般向代码仓库提交项目的时候,一般需要忽略编译生成的中间文件以及文件夹的提交,因为它们是无用的,而且也会占用仓库的空间.一般只用提交.pro,.sln,makefile,程序源文件等编译必须用到的 ... 
