文章目录

  • 什么是静态化
  • 什么时候静态化
  • Nginx的角色
  • Thymeleaf静态化组件
  • Context:运行上下文
  • TemplateResolver:模板解析器
  • TemplateEngine:模板引擎
  • 引擎处理函数
  • 实现静态化

什么是静态化

静态化是指把动态生成的HTML页面变为静态内容保存,以后用户的请求到来,直接访问静态页面,不再经过服务的渲染。

而静态的HTML页面可以部署在nginx中,从而大大提高并发能力,减小tomcat压力。

什么时候静态化

第一次请求页面的时候,除了返回页面视图外,还应该创建一个静态页面,那么下次就不会再来访问leyou-goods-web服务了。
如果大部分的商品都有了静态页面。那么用户的请求都会被nginx拦截下来,根本不会到达我们的leyou-goods-web服务。

Nginx的角色

它对商品请求进行监听,先指向本地静态页面,如果本地没找到,再进行反向代理

nginx中静态页面部分png图片加载不出来 nginx页面静态化_静态化

Thymeleaf静态化组件

Context:运行上下文

与SpringBoot结合使用时,我们把Model的数据放到Context,作为模板渲染的数据使用。
当模板引擎渲染时,可以从Context上下文中获取数据用于渲染。

TemplateResolver:模板解析器

当与SpringBoot结合时,TemplateResolver已经由其创建完成,并且各种配置也都有默认值,比如模板存放位置,其默认值就是:templates。比如模板文件类型,其默认值就是html。

TemplateEngine:模板引擎

用来解析模板的引擎,需要使用到上下文、模板解析器。分别从两者中获取模板中需要的数据,模板文件。然后利用内置的语法规则解析,从而输出解析后的文件。SpringBoot中已经自动配置了模板引擎。

引擎处理函数

templateEngine.process("模板名", context, writer);

三个参数:

  • 模板名称
    上下文:里面包含模型数据
    writer:输出目的地的流

在输出时,我们可以指定输出的目的地,如果目的地是Response的流,那就是网络响应。如果目的地是本地文件,那就实现静态化了。

实现静态化

* @Feature: 实现页面静态化接口
 */
@Service
public class GoodsHtmlServiceImpl implements GoodsHtmlService {
 
    @Autowired
    private GoodsService goodsService;
 
    @Autowired
    private TemplateEngine templateEngine;
 
    private static final Logger LOGGER = LoggerFactory.getLogger(GoodsHtmlService.class);
 
 
    @Override
    public void createHtml(Long spuId) {
        PrintWriter writer = null;
 
        //获取页面数据
        Map<String,Object> spuMap = this.goodsService.loadModel(spuId);
        //创建Thymeleaf上下文对象
        Context context = new Context();
        //把数据放入上下文对象
        context.setVariables(spuMap);
 
        //创建输出流
        File file = new File("D:\\nginx-1.12.2\\html\\item"+spuId+".html");
        try {
            writer = new PrintWriter(file);
 
            //执行页面静态化方法,输出到本地
            templateEngine.process("item",context,writer);
        } catch (FileNotFoundException e) {
            LOGGER.error("页面静态化出错:{}"+e,spuId);
        }finally {
            if (writer != null){
                writer.close();
            }
        }
    }
 
    /**
     * 新建线程处理页面静态化
     * @param spuId
     */
    @Override
    public void asyncExecute(Long spuId) {
        ThreadUtils.execute(() ->createHtml(spuId));
    }
}

线程工具、

public class ThreadUtils {
 
    private static final ExecutorService es = Executors.newFixedThreadPool(10);
 
    public static void execute(Runnable runnable){
        es.submit(runnable);
    }
}

【注意】注意:生成html 的代码不能对用户请求产生影响,所以这里使用额外的线程进行异步创建。