这是我目前的设置:
snc_redis:
clients:
default:
type: predis
alias: cache
dsn: "redis://127.0.0.1"
doctrine:
metadata_cache:
client: cache
entity_manager: default
document_manager: default
result_cache:
client: cache
entity_manager: [bo, aff, fs]
query_cache:
client: cache
entity_manager: default我有一个API,它获得多个重复请求(通常是快速连续的),我可以使用这个设置在重复请求时返回缓存的响应吗?此外,是否可以设置缓存过期?
发布于 2015-08-24 07:48:34
从您提供的配置示例中,我猜您希望缓存Doctrine结果,而不是完整的HTTP响应(尽管后者是可能的,参见下面)。
如果是这样的话,最简单的方法是,每当您创建Doctrine查询时,将其设置为使用上面设置的结果缓存来使用redis。
$qb = $em->createQueryBuilder();
// do query things
$query = $qb->getQuery();
$query->useResultCache(true, 3600, 'my_cache_id');这将使用缓存ID将查询的结果缓存一个小时。
$cache = $em->getConfiguration()->getResultCacheImpl();
$cache->delete('my_cache_id');如果您想要缓存完整的响应--即在应用程序中进行一些处理,这需要很长时间--那么有很多方法可以这样做。序列化并将其弹出到redis中是可能的:
$myResults = $service->getLongRunningResults();
$serialized = serialize($myResults);
$redisClient = $container->get('snc_redis.default');
$redisClient->setex('my_id', $serialized, 3600);或者,查看像清漆这样的专用HTTP缓存解决方案,或者查看关于HTTP缓存的Symfony文档。
编辑: SncRedisBundle提供了自己版本的Doctrine's CacheProvider。因此,在您的回答中,您创建了您自己的类,您也可以这样做:
my_cache_service:
class: Snc\RedixBundle\Doctrine\Cache\RedisCache
calls:
- [ setRedis, [ @snc_redis.default ] ]这几乎可以和你的班级所做的一样。所以,与$app_cache->get('id')不同,您可以做$app_cache->fetch('id')。这样,您就可以切换出缓存的后端,而无需更改应用程序类,只需更改服务描述。
发布于 2015-08-24 09:18:23
最后,我创建了一个缓存管理器,并将其注册为一个名为@app_cache的服务。
use Predis;
class CacheManager
{
protected $cache;
function __construct()
{
$this->client = new Predis\Client();
}
/**
* @return Predis\Client
*/
public function getInstance()
{
return $this->client;
}
}在控制器中,我可以md5 request_uri
$id = md5($request->getRequestUri()); 检查它是否存在,如果它确实返回$result
if($result = $app_cache->get($id)) {
return $result;
}如果没有,do..whatever...and将响应保存到下一次
$app_cache->set($id,$response);要设置到期时间,请使用第3和第4参数ex =秒和px =毫秒。
$app_cache->set($id,$response,'ex',3600);https://stackoverflow.com/questions/32176436
复制相似问题