NodeJS解决了API缓存的最佳实践

时间:2016-03-29 13:30:38

标签: javascript node.js caching

我是NodeJS的新手,我正在使用restify构建我的第一个API。 我想找出缓存响应数据的最佳做法 - 每个API调用必须有自己的缓存时间。

我查看了res.cache(),但这似乎只是针对每个用户请求而不是全局应用程序缓存。

然后我查看restify-cache,但文档没有明确告诉我如何使用它。

我的应用程序是这样的:

server.js代码:

var restify = require('restify');
var mysqlDB = require('./config/connection');

// REST server declaration and configuration
var server = restify.createServer({
  name: 'test-api',
  version: '0.0.1'
});

server.pre(restify.pre.sanitizePath());
server.use(restify.queryParser());
server.use(restify.acceptParser(server.acceptable));
server.use(restify.queryParser());
server.use(restify.bodyParser());

server.listen(9007, function() {
  console.log('%s listening at %', server.name, server.url);
  mysqlDB.handleDisconnect();
  console.log(new Date() +': Started Cricket API on port 9007');
});

var routes = require('./routes')(server);

routes.js代码:

module.exports = function(app) {
app.get('/', function(req, res, next) {
    return res.send("You have reached the test API");
});

var fixtures = require('./controllers/fixtures');
    app.get('/getfixtures', fixtures.getFixtures);  // Get All Fixtures
};

fixtures.js代码段:

this.getFixtures = function (req, res, next) {

res.header("Access-Control-Allow-Origin", "*"); 
res.header("Access-Control-Allow-Headers", "X-Requested-With");

console.log("Get All Fixtures");
var mysql = mysqlDB.getConnection();

var query = "SELECT * FROM fixtures WHERE fixture_date >= CURDATE() ORDER BY fixture_date, fixture_time";          
      mysql.query(query,function(err,rows){
        if(err) {
            var status = mysqlDB.getErrorStatus(err.code);
            return res.status(status.code).send("Error : "+ status.Message);                  
        } else {
          var data = [];
          for (i in rows){
            var item = rows[i];

            var output = util.formatDate(item.fixture_date);
            item.fixture_date = output;

            data.push(item);
          };

          return res.send(data);
        }
      });
  };

有人可以向我发送正确的方向吗?我不知道在哪里添加缓存部分?

2 个答案:

答案 0 :(得分:2)

从库文件中: <!DOCTYPE html> <html lang="en"> <head> <title></title> <meta charset="utf-8" /> <script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> </head> <body> <textarea id="ta_1" rows="5" cols="28"></textarea> </body> </html>是一个中间件,在处理请求之前将被触发加载,转到Redis并检查server.use(cache.before);密钥和header_{url}是否退出,并且在这种情况下返回值。

你可以按照这个要点提到它: https://gist.github.com/jeffstieler/3d84fa5468c7eadb7685

payload_{url}

在您的代码中,我会在您清理路径后添加var server = restify.createServer({ name: 'test-api', version: '0.0.1' }); server.pre(restify.pre.sanitizePath()); server.use(cache.before); server.use(restify.queryParser()); server.use(restify.acceptParser(server.acceptable)); server.use(restify.queryParser()); server.use(restify.bodyParser()); server.on('after', cache.after); ,因为它将保存在Redis中。每个缓存的路由都应包含cache.before

答案 1 :(得分:0)

我最终使用node-cache 它很容易使用,因为我来自Java / Play框架背景 - 希望它在将来帮助其他人。

使用示例:

var nodeCache = require( "node-cache" );
var myCache = new nodeCache();

var cachedValue = myCache.get("alltests", true);

if (cachedValue != undefined) {
  return res.send(cachedValue);
} else {
  // Do work here and then:
  success = myCache.set("alltests", valueHere, cacheTime);
}
相关问题