博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
vue服务端渲染添加缓存
阅读量:4690 次
发布时间:2019-06-09

本文共 4416 字,大约阅读时间需要 14 分钟。

缓存

虽然 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 rendererif (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({   max: 100,   maxAge: 5000 // 设置数据多久过期 })
export function createAPI({baseUrl, timeout}) {
let api
if (process.__API__) { api = process.__API__ } else {
// 定义全局变量 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) }) }) } } } return api }

  

这样就ok了

 

转载于:https://www.cnblogs.com/wing-sky/p/9664320.html

你可能感兴趣的文章
postgressql数据库中limit offset使用
查看>>
测试思想-集成测试 关于接口测试 Part 2
查看>>
windows下mysql密码忘了怎么办?【转】
查看>>
java文件上传和下载
查看>>
SQL联合查询(内联、左联、右联、全联)的语法(转)
查看>>
枚举和实用类
查看>>
python基础知识第二篇(字符串)
查看>>
php生成器使用总结
查看>>
T-SQL中的indexof函数
查看>>
javascript基础之数组(Array)对象
查看>>
mysql DML DDL DCL
查看>>
RAMPS1.4 3d打印控制板接线与测试1
查看>>
python with语句中的变量有作用域吗?
查看>>
24@Servlet_day03
查看>>
初级ant的学习
查看>>
redis数据结构--String
查看>>
POJ 3279 Fliptile (二进制枚举)
查看>>
memcached 细究(三)
查看>>
future
查看>>
关于main函数传参数的问题
查看>>