在拉拉维尔,你可以做这样的事情
$object = Cache->remember(key, duration, function() {
$result = mysql_fetch_something();// retrieve from MySQL here
return $result;
});
基本上,Laravel首先检查缓存是否存在,如果不存在,则允许从数据库中检索值,并在返回值的同时自动将其放入缓存中。节点中是否存在类似的构造,即1停止缓存检查,db故障转移机制?
发布于 2015-03-08 15:12:47
在节点中没有专门的命令,但是您可以自己构建它。
只需使用redis命令检查键是否在redis中,如果不是,只检查mysql并存储它。
发布于 2015-03-25 15:55:05
你可以做一些这样的事。在cache.js
中
var isCacheAvailable = true;
exports.init = function () {
var server = config.get('Cache.server');
var port = config.get('Cache.port');
client = redis.createClient(port,server);
// handle redis connection temporarily going down without app crashing
client.on("error", function (err) {
logger.error("Error connecting to redis server " + server + ":" + port, err);
isCacheAvailable = false;
});
}
exports.isCacheAvailable = function(){
return isCacheAvailable;
}
检查您打算使用缓存的isCacheAvailable()
函数。
if(cache.isCacheAvailable()) {
// use cache to fetch data
} else {
// fallback to mysql db
}
希望这能有所帮助。
https://stackoverflow.com/questions/28924300
复制相似问题