开发一个cube.js schemaVersion 包装

默认dev环境schema 是不cache,所以会每次执行,生成环境是必须cache的,但是cache就有schemaversion 的问题
所以基于cache-manager 包装了一个cache处理的,代码很简单,但是可以减少对于schemaversion的时间消耗

参考包装代码

schemaversion.js

 
const cacheManager = require('cache-manager');
const crypto = require('crypto');
const redisStore = require('cache-manager-ioredis');
const redisCache = cacheManager.caching({
  store: redisStore,
  host: process.env.REDIS_HOST || "localhost", // default value
  port: process.env.REDIS_PORT? parseInt(process.env.REDIS_PORT):6379, // default value
  db: 0,
  password: process.env.REDIS_PASS || null,
  ttl: process.env.REDIS_TTL? parseInt(process.env.REDIS_TTL):10
});
 
function pause(ms) {
    return new Promise(resolve => setTimeout(resolve, ms));
}
module.exports = {
    schemaVersion: async (securityContext,func)=> {
         let cachekey = `SCHEMAVERSION_${crypto.createHash('md5').update(JSON.stringify(securityContext)).digest('hex')}`
         return redisCache.wrap(cachekey, function() {
          return func(securityContext);
        });
    },
    pause:pause
}
  • 说明
    使用很简单,引用模块,同时自己包装一个promise 的函数就可以,需要传递的参数为securityContext 以及一个自定义的函数

参考使用

 
// Cube.js configuration options: https://cube.dev/docs/config
const {CubejsHandlerError} = require("@cubejs-backend/api-gateway")
=const index = require("./index")
const {pause,schemaVersion} = require("./schemaversion")
async function fetchVersion(securityContext){
  await pause(3000)
  console.log("call version")
  return `"dalong"---${parseInt(Math.random()*100)}`
}
module.exports = {
  schemaVersion: async ({ securityContext }) =>{
    return schemaVersion(securityContext,fetchVersion)
  },
  contextToAppId: ({ securityContext }) => {
   return  `CUBEJS_APP_${securityContext.user_id}`
  }
};

说明

以上代码很简单,对于cache key 可以自己调整,同时对于scheduledRefreshContexts也可以使用类似的方法

posted on 2021-04-24 19:29  荣锋亮  阅读(107)  评论(0编辑  收藏  举报

导航