提升网站性能的方式有很多,例如使用缓存技术,页面静态化等.对于一个网站来说,如果数据更新频率不高的话,那就没有必要没次都要从数据库取数据,一来调动数据库,响应速度慢,二来增加服务器对数据响应的负荷,三来不利于优化引擎.随着一个网站的访问量的加大,每次从数据库读取数据是以效率为代价的,特别是一些门户网站,网站访问慢对用户体验很不好.所以页面静态化是一个不错的选择.
页面静态化适合的场景:
- 数据更新不高的网站,如新闻型网站
- 实时性不是很高的网站,当然跟静态的方式有关,如果做成没增删改都静态化一次那就没这个问题,如果做成每隔一段时间更新一次就不可以了.
- 数据量不是很大的网站,如果一个网站有上万条记录,每条都生成一个页面谁受得了.
页面静态化的方法很多,这次我是基于freemarker.freeMarker是一个用Java语言编写的模板引擎,它基于模板来生成文本输出。当然还有比较出名的是Velocity.在使用freeMarker前有必要先讲一下freeMarker标签的用法.
freeMarker一些内置函数:
内置函数freeMa sequence?first 返回sequence的第一个值。
sequence?last 返回sequence的最后一个值。
sequence?reverse 将sequence的现有顺序反转,即倒序排序
sequence?size 返回sequence的大小
sequence?sort 将sequence中的对象转化为字符串后顺序排序
sequence?sort_by(value) 按sequence中对象的属性value进行排序
直接获取Controller传过来的变量.
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title></title> </head> <body> ${title} </body> </html>
获取Controller传过来的对象.
${user.userPassword}
遍历集合:
<#list lists as user> 用户名:${user.userName}<br/> 密码:${user.userPassword}<br/> 住址:${user.userInfo.address}<br/> </#list>
这是关于遍历集合其它一些用法,不多说.看了就懂:
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title></title> </head> <body> <#list lists as user> 用户名:${user.userName}<br/> 密码:${user.userPassword}<br/> 住址:${user.userInfo.address}<br/> </#list> <br/> list隐含变量item_index, 当前迭代项在所有迭代项中的位置<br/> <#list lists as user> 第${user_index + 1}个用户<br/> 用户名:${user.userName}<br/> 密码:${user.userPassword}<br/> 住址:${user.userInfo.address}<br/> <hr/> </#list> list隐含变量item_has_next, 用于判断当前迭代项是否是所有迭代项中的最后一项。<br/> <#list lists as user> 用户名:${user.userName}<br/> 密码:${user.userPassword}<br/> 住址:${user.userInfo.address}<br/> <hr/> <#if !user_has_next> 共有${lists?size}最后一个用户名是:${user.userName} </#if> </#list> <h4>list隐含变量sort_by有一个参数,该参数用于指定想要排序的子变量,排序是按照变量对应的值进行排序</h4><br/> <#list lists?sort_by("userName") as user> 用户名:${user.userName}<br/> 密码:${user.userPassword}<br/> 住址:${user.userInfo.address}<br/> <hr/> </#list> <h4>list隐含变量reverse还可以同sort_by一起使用 </h4><br/> <#list lists?sort_by("userName")?reverse as user> 用户名:${user.userName}<br/> 密码:${user.userPassword}<br/> 住址:${user.userInfo.address}<br/> <hr/> </#list> </body> </html>
获取Map数据:
Hash的内置函数
hash?keys 返回hash里的所有key,返回结果为sequence
hash?values 返回hash里的所有value,返回结果为sequence
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title></title> </head> <body> <#list maps?keys as testKey> 键${testKey} 值${maps[testKey].userName} </#list> </body> </html>
直接获取Map的值:
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title></title> </head> <body> <#list maps?values as value> 值${value} </#list> </body> </html>
讲了freemarker后下一篇就讲一讲如何使用freemarker结合spring mvc实现页面静态化.
提升网站性能的方式有很多,例如使用缓存技术,页面静态化等.对于一个网站来说,如果数据更新频率不高的话,那就没有必要没次都要从数据库取数据,一来调动数据库,响应速度慢,二来增加服务器对数据响应的负荷,三来不利于优化引擎.随着一个网站的访问量的加大,每次从数据库读取数据是以效率为代价的,特别是一些门户网站,网站访问慢对用户体验很不好.所以页面静态化是一个不错的选择. 页面静态化适合的场景:- 数据更新不高的网站,如新闻型网站
- 实时性不是很高的网站,当然跟静态的方式有关,如果做成没增删改都静态化一次那就没这个问题,如果做成每隔一段时间更新一次就不可以了.
- 数据量不是很大的网站,如果一个网站有上万条记录,每条都生成一个页面谁受得了.