This bundle provides cache with tags.
- Stores a cache with multiple tags. And deletes cache by using tag.
- Provides controller cache.
- Annotations for Controllers.
editing the composer.json file in the root project.
"rickysu/tagcache-bundle": "1.0.*",
php composer.phar update
<?php
//app/AppKernel.hpp
public function registerBundles()
{
$bundles = array(
// ...
new RickySu\TagcacheBundle\TagcacheBundle(),
);
}
# app/config/config.yml
tagcache:
driver: Memcache
debug: %kernel.debug%
options:
hashkey: true
enable_largeobject: false
cache_dir: "%kernel.cache_dir%/tagcache"
servers:
- 'localhost:11211:10'
- 'otherhost:11211:20'
# app/config/config_dev.yml
tagcache:
namespace: 'Name_Space_For_Your_Project:dev'
# app/config/config_prod.yml
tagcache:
namespace: 'Name_Space_For_Your_Project:prod'
The cache driver. Currently support "Memcache,Memcached,File,Sqlite,Apc,Nullcache". Nullcache is for testing only.
some driver like Memcached,only support 250 characters key length. Enable this option will use md5 hashed key.
Memcache cannot store object over 1MB.Enable these option will fix this issue,but cause lower performance.default false.
Memcache server configs. format => "Host:Port:Weight"
<?php
$Tagcache=$container->get('tagcache');
//store cache with Tags:{TagA,TagB} for 300 secs.
$Tagcache->set('Key_For_Store','Data_For_Store',array('TagA','TagB'),300);
//get cache.
$Tagcache->get('Key_For_Store');
//delete cache.
$Tagcache->delete('Key_For_Store');
//delete cache by Tag.
$Tagcache->deleteTag('TagA');
//acquire a lock.If a lock already exists,It will be blocked for 5 secs.
$Tagcache->getLock('Your_Lock_Name',5);
//release a lock.
$Tagcache->releaseLock('Your_Lock_Name');
//increment a cache
$Tagcache->inc('Key_For_increment');
//decrement a cache
$Tagcache->dec('Key_For_decrement');
<?php
//in Controller
namespace Acme\DemoBundle\Controller;
// these import the "@Tagcache" annotations
use RickySu\TagcacheBundle\Configuration\Tagcache;
class DemoController extends Controller
{
/**
* @Route("/hello/{name}", name="_demo_hello")
* @Tagcache(expires=600,cache=true)
* @Template()
*/
public function helloAction($name)
{
return array('name' => $name);
}
/**
* @Route("/test", name="_demo_test")
* @Tagcache(expires=600,tags={"TagA","TagB"},key="custom_cache_key",cache=true)
* @Template()
*/
public function testAction()
{
return;
}
}
{#in view render a controller#}
{%render 'AcmeDemoBundle:Demo:test' with {
'tagcache': {
'key': 'custom_cache_key',
'tags': ['TagA','TagB'],
'expires': 300
}
}%}
{#in view render a controller#}
{%render(
controller(
'AcmeDemoBundle:Demo:test',
{
'tagcache': {
'key': 'custom_cache_key',
'tags': ['TagA','TagB'],
'expires': 300
}
}
)
)%}
app/console cache:clear
If you both define cache params in view and controller. "tagcache" variable in view will overwrite controller annotations. But remember,controller annotation config "cache" must set to false,If you want to turn off controller cache.
MIT