最近做项目的时候,碰到这样的需求,由于一些页面的ajax请求数据太多,而且sql效率很低,导致压力测试时一个页面打开需要一分多钟,所以就想到如下几种解决方案:
1.将请求的数据,通过IO写入硬盘缓存文件,当发现有对应文件时,便从该文件读取存储的请求数据;
2.写一个工具类,在工具类定义一个map类型的成员变量,将请求数据存储到该map中;
3.修改数据库服务器的配置(当然这不是本文要讨论的内容)
既然有了方案,就开始实现,页面中有很多这样的action:
@Action("test")
public void test(){
writeJson(testService.getTestData());
}
基本都是通过service中的方法返回list(map(String,Object)) 类型的数据,然后通过writeJson返回json到前台
方案一:
//请求缓存数据方法
public void requestData(String requestName){
try {
//创建File对象,参数为String类型,表示目录名
File myFilePath = new File("D:\\cache");
//先创建父路径再创建文件
File myFile = new File("D:\\cache\\"+requestName+".json");
//如果父路径存在
if(myFilePath.exists()){
//如果文件存在
if(myFile.exists()){
//文件最后修改时间
Date date = new