vue服务端渲染添加缓存
程序员文章站
2022-05-16 14:21:03
vue服务端渲染/vue-ssr 添加缓存 ;vue-ssr项目性能优化点 ......
缓存
虽然 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({
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了
上一篇: 月经颜色看健康状况 缓解痛经按摩法
下一篇: 4种脸色或预示疾病缠身