虽然 Vue 的服务器端渲染(SSR)相当快速,但是由于创建组件实例和虚拟 DOM 节点的开销,无法与纯基于字符串拼接(pure string-based)的模板的性能相当。在 SSR 性能至关重要的情况下,明智地利用缓存策略,可以极大改善响应时间并减少服务器负载。

vue服务区缓存分为页面缓存、组建缓存和接口缓存

页面缓存:

在server.js中设置

const LRU = require('lru-cache')
const microCache = LRU({max: 100, // 最大缓存的数目maxAge: 1000 // 重要提示:条目在 1 秒后过期。
})const isCacheable = req => {//判断是否需要页面缓存if (req.url && req.url === '/') {return req.url} else {return false}
}
app.get('*', (req, res) => {
const cacheable = isCacheable(req)if (cacheable) {const hit = microCache.get(req.url)if (hit) {return res.end(hit)}}
const errorHandler = err => {if (err && err.code === 404) {// 未找到页面res.status(404).sendfile('public/404.html');} else {// 页面渲染错误res.status(500).end('500 - Internal Server Error')console.error(`error during render : ${req.url}`)console.error(err)}
}
const context = {title: 'vue',keywords: 'vue-ssr服务端脚手架',description: 'vue-ssr-template, vue-server-renderer',version: v,url: req.url,cookies: req.cookies
}
renderer.renderToString(context, (err, html) => {if (err) {return errorHandler(err)}res.end(html)microCache.set(req.url, html) // 设置当前缓存页面的内容
})
})
复制代码

组建缓存:

在server.js中设置如下:

function createRenderer(bundle, template) {return require('vue-server-renderer').createBundleRenderer(bundle, {template,cache: LRU({max: 1000,maxAge: 1000 * 60 * 5 // 组建缓存时间})})
}
let renderer
if (isProd) {// 生产环境使用本地打包文件来渲染const bundle = require('./output/vue-ssr-bundle.json')const template = fs.readFileSync(resolve('./output/index.html'), 'utf-8')renderer = createRenderer(bundle, template)
} else {// 开发环境使用webpack热更新服务require('./build/dev-server')(app, (bundle, template) => {renderer = createRenderer(bundle, template)})
}
复制代码

 要缓存的组建

export default {name: 'Home',title() {return {title: 'vue-ssr',keywords: 'vue-ssr服务端脚手架, home',description: 'vue-ssr-template, vue-server-renderer, home'}},created() {},computed: {},asyncData({ store }) {},methods: {},serverCacheKey: props => props.id
}
复制代码

serverCacheKey 返回的 key 应该包含足够的信息,来表示渲染结果的具体情况。如果渲染结果仅由 props.item.id 决定,则上述是一个很好的实现。但是,如果具有相同 id 的 item 可能会随时间而变化,或者如果渲染结果依赖于其他 prop,则需要修改 serverCacheKey 的实现,以考虑其他变量。如果

serverCacheKey

返回常量将导致组件始终被缓存,这对纯静态组件是有好处的。

接口缓存:

在create-api-server.js中设置缓存

import qs from 'qs'
import axios from 'axios'
import md5 from 'md5'
import LRU from 'lru-cache'
复制代码

const microCache = LRU({ <br> max: 100,<br> maxAge: 5000 // 设置数据多久过期<br>})

export function createAPI({baseUrl, timeout}) {
let api
复制代码
if (process.__API__) { api = process.__API__ } else {<br>// 定义全局变量 process.__API__api = process.__API__ = {get(url, params = {}) {const key = md5(url + JSON.stringify(params))// 判断是否有缓存,直接返回缓存结果if (params.cache && microCache.get(key)) {console.log('返回缓存')return Promise.resolve(microCache.get(key))}return new Promise((resolve, reject) => {axios({url,params,headers: {'X-Requested-With': 'XMLHttpRequest'// 'Cookie': parseCookie(SSR.cookies)},method: 'get'}).then(res => {// 判断是否需要缓存 如果需要缓存缓存数据if (params.cache && microCache) {microCache.set(key, res.data)}console.log('返回新数据')resolve(res.data)}).catch(error => {reject(error)})})},post(url, params = {}) {const key = md5(url + JSON.stringify(params))// 判断是否有缓存,直接返回缓存结果if (params.cache && microCache.get(key)) {return Promise.resolve(microCache.get(key))}return new Promise((resolve, reject) => {axios({url,data: qs.stringify(params),method: 'post',headers: {'X-Requested-With': 'XMLHttpRequest','Content-Type': 'application/x-www-form-urlencoded'// 'Cookie': parseCookie(SSR.cookies)}}).then(res => {// 判断是否需要缓存 如果需要缓存缓存数据if (params.cache && microCache) {microCache.set(key, res.data)}resolve(res.data)}).catch(error => {reject(error)})})}}}<br>return api<br>}复制代码

vue服务端渲染添加缓存相关推荐

  1. vue添加html开启服务器_vue服务端渲染添加缓存

    虽然 Vue 的服务器端渲染(SSR)相当快速,但是由于创建组件实例和虚拟 DOM 节点的开销,无法与纯基于字符串拼接(pure string-based)的模板的性能相当.在 SSR 性能至关重要的 ...

  2. java vue 服务端渲染_vue服务端渲染缓存应用详解

    服务端渲染简介 服务端渲染不是一个新的技术:在 Web 最初的时候,页面就是通过服务端渲染来返回的,用 PHP 来说,通常是使用 Smarty 等模板写模板文件,然后 PHP 服务端框架将数据和模板渲 ...

  3. Vue 服务端渲染(SSR)、Nuxt.js - 从入门到实践

    前言 10月初有幸接到公司官网改版需求,要求采用服务端渲染模式对原网站进行seo优化. 由于团队一直使用的vue技术栈,所以我第一时间想到的就是采用vue 服务端渲染(SSR)来实现该需求,即能减少团 ...

  4. egg html模板,egg+vue服务端渲染模板项目介绍

    egg-vue-webpack-boilerplate 基于 Egg + Vue + Webpack SSR 服务端渲染和 CSR 前端渲染工程骨架项目,包括前台系统(SSR MPA)和后台管理系统( ...

  5. 手把手教你 Vue 服务端渲染

    写在前面 在写这篇文章之前,我有写一篇 Vue 预渲染的教程 以及 在线示例,有需要的可以看一下~ [下面开始 Vue 服务端渲染] 服务端渲染 = SSR = Server-Side Renderi ...

  6. vue服务端渲染——基础

    文章目录 vue服务端渲染(基础) Nuxt框架 文件目录结构 项目启动.打包 生命周期 SSR nuxtserverInit middleware 中间件 全局中间件 页面级中间件 validate ...

  7. Vue 服务端渲染原理 拆分成三步个步骤简单的实现一个案例

    前言 可能我们平常接触比较多的是使用 vue + vue全家桶来搭建起一个单页(SPA)应用.用 服务端渲染 搭建项目比较少,本文是记录我在学习 服务端渲染 过程中的一些见解,如有出错或疏漏,麻烦帮忙 ...

  8. vue服务端渲染之nuxtjs

    前言 本篇主要针对nuxtjs中的一些重要概念整理和代码实现! 在学习vue服务端渲染之前,先搞清楚几个概念: 什么是客户端渲染(CSR) 什么是服务端渲染(SSR) CSR和SSR有什么异同 客户端 ...

  9. java vue 服务端渲染_vue ssr服务端渲染小白解惑

    vue ssr服务端渲染小白解惑 >初学ssr入坑 初学vue服务端渲染疑惑非常多,我们大部分前端都是半路出家,上手都是前后端分离,对服务端并不了解,不说java.php语言了,连node服务都 ...

最新文章

  1. Linux系统下统计目录及其子目录文件个数
  2. Java线程池实现原理及其在美团业务中的实践
  3. 七彩岁月【我与51CTO一“七”成长】
  4. 福师计算机导论在线作业一,福师《计算机导论》在线作业一..doc
  5. 拉肚子,不能吃东西的痛苦
  6. 任正非:我若贪生怕死,何来让你们去英勇奋斗
  7. 数据管理 - 每天5分钟玩转 Docker 容器技术(147)
  8. “局域网聊天”开始了
  9. html页面的盒子边框怎么做的,HTML+CSS入门 用三层盒子结构实现多边框详解
  10. 谭浩强 c语言 swap,C语言谭浩强完整教案.ppt
  11. 《自己动手写操作系统》实践(一)
  12. 大话数据结构 - 串
  13. IBM x3850 x5U盘启动或光驱启动不起作用
  14. 为什么要学习鸿蒙,HarmonyOS不只是操作系统
  15. 银行客户用户画像_客户分类、客户标签与用户画像,怎样助力转化?
  16. c语言求阶乘的两种算法(递归和循环)
  17. SuperMap WebGL拖拽式画圆和画矩形
  18. 【MySQL】exists与in的比较
  19. Eclipse下载以及旧版本下载
  20. PCA (主成分分析)详解 (写给初学者)

热门文章

  1. Python reload 函数 - Python零基础入门教程
  2. mysql 中 end like,MySQL 这三道必问面试题,你都会吗?
  3. java写出http数据包_java用jpcap怎么识别出http和https的数据包?
  4. mysql数据应用从入门_MYSQL数据库应用从入门到精通----读书笔记
  5. 上课点名app_【APP种草】网瘾少年的自我救赎之最强锁机软件
  6. python123外汇兑换计算器_Python 3.x--使用re模块,实现计算器运算实例
  7. ios时间相差多少天_iOS 计算某个时间到现在是多少月/天/时
  8. 河北大学计算机复试题,2016年河北大学综合卷计算机科学与技术学院之数据库系统概论复试笔试最后押题五套卷...
  9. mysql2012更改表名_T-SQL入門攻略之13-修改数据表
  10. mysql主从表结构差异_mysqldiff对比主从表结构是否一致