Es ist die Natur von Anwendungen eine Vielzahl an Caches jedes Types zu benötigen oft
abhängig vom Controller, der Bibliothek oder dem Domainmodell auf das zugegriffen wird.
Um die einfache Definition von Zend_Cache
Optionen zu erlauben
(wie von der Bootstrap), damit auf ein Cacheobjekt zugegriffen werden kann und nur ein
minimales Setup im Sourcecode der Anwendung benötigt wird, wurde die Klasse
Zend_Cache_Manager
geschrieben. Diese Klasse wird von
Zend_Application_Resource_Cachemanager
verwendet um sicherzustellen
das die Konfiguration der Bootstrap vorhanden ist, und
Zend_Controller_Action_Helper_Cache
um einen einfachen Zugriff und
eine einfache Instanzierung von Controllern und anderen Helfern zu erlauben.
Die grundsätzliche Operation dieser Komponente ist wie folgt. Der Cache Manager erlaubt es
Benutzern "Option Templates" zu konfigurieren, grundsätzlich Optionen für ein Set von
benannten Caches. Diese können gesetzt werden indem die Methode
Zend_Cache_Manager::setCacheTemplate()
verwendet wird. Diese
Templates führen einen Cache nicht aus solange der Benutzer nicht versucht einen benannten
Cache zu empfangen (assoziiert mit einem existierenden Optionstemplate) indem die Methode
Zend_Cache_Manager::getCache()
verwendet wird.
$manager = new Zend_Cache_Manager; $dbCache = array( 'frontend' => array( 'name' => 'Core', 'options' => array( 'lifetime' => 7200, 'automatic_serialization' => true ) ), 'backend' => array( 'name' => 'Core', 'options' => array( 'cache_dir' => '/path/to/cache' ) ) ); $manager->setCacheTemplate('database', $dbCache); /** * Überall anders wo der Cache Manager vorhanden ist... */ $databaseCache = $manager->getCache('database');
Der Cache Manager erlaubt das einfache Erstellen von vor-instanzierten Caches durch
Verwenden der Methode Zend_Cache_Manager::setCache()
.
$frontendOptions = array( 'lifetime' => 7200, 'automatic_serialization' => true ); $backendOptions = array( 'cache_dir' => '/path/to/cache' ); $dbCache = Zend_Cache::factory('Core', 'File', $frontendOptions, $backendOptions); $manager = new Zend_Cache_Manager; $manager->setCache('database', $dbCache); /** * Überall anders wo der Cache Manager vorhanden ist... */ $databaseCache = $manager->getCache('database');
Wenn man aus irgendeinem Grund unsicher ist ob der Cache Manager einen vor-instanzierten
Cache enthält oder ein relevantes Option Cache Template um einen auf Anfrage zu erstellen,
kann die Existenz einer benannten Cachekonfiguration oder Instanz geprüft werden indem die
Methode Zend_Cache_Manager::hasCache()
verwendet wird.
$manager = new Zend_Cache_Manager; $dbCache = array( 'frontend' => array( 'name' => 'Core', 'options' => array( 'lifetime' => 7200, 'automatic_serialization' => true ) ), 'backend' => array( 'name' => 'Core', 'options' => array( 'cache_dir' => '/path/to/cache' ) ) ); $manager->setCacheTemplate('database', $dbCache); /** * Überall anders wo der Cache Manager vorhanden ist... */ if ($manager->hasCache('database')) { $databaseCache = $manager->getCache('database'); } else { // Erstelle einen Cache wenn keiner from Manager vorhanden ist }
In einigen Szenarios könnte man eine Anzahl von generell zu verwendenden Caches definiert
haben indem Zend_Cache_Manager
verwendet wird, aber deren Optionen
feintunen bevor Sie anhängig von Ihren Notwendigkeiten verwendet werden. Man kann vorher
gesetzte Cache Templates on the fly bearbeiten bevor Sie instanziert werden indem die
Methode Zend_Cache_Manager::setTemplateOptions()
verwendet wird.
$manager = new Zend_Cache_Manager; $dbCache = array( 'frontend' => array( 'name' => 'Core', 'options' => array( 'lifetime' => 7200, 'automatic_serialization' => true ) ), 'backend' => array( 'name' => 'Core', 'options' => array( 'cache_dir' => '/path/to/cache' ) ) ); $manager->setCacheTemplate('database', $dbCache); /** * Überall anders wo der Cache Manager vorhanden ist... * Hier haben wir entschieden einige kommende Datenbankabfragen zu Memcache zu * Speichern statt dem vorkonfigurierten File Backend */ $fineTuning = array( 'backend' => array( 'name' => 'Memcached', 'options' => array( 'servers' => array( array( 'host' => 'localhost', 'port' => 11211, 'persistent' => true, 'weight' => 1, 'timeout' => 5, 'retry_interval' => 15, 'status' => true, 'failure_callback' => '' ) ) ) ) ); $manager->setTemplateOptions('database', $fineTuning); $databaseCache = $manager->getCache('database');
Um zu helfen den Cache Manager sinnvoller zu machen wird
Zend_Application_Resource_Cachemanager
und auch der Action Helfer
Zend_Controller_Action_Helper_Cache
angeboten. Beide sind in den
betreffenden Abschnitten des Referenz Handbuchs beschrieben.
Zend_Cache_Manager
enthält bereits vier vordefinierte Cache Templates
welche "skeleton", "default", "page" und "tagcache" heißen. Der Standardcache ist ein
einfacher Dateibasierter Cache welcher das Core Frontend verwendet und annimmt das ein
cache_dir auf dem gleichen Level wie das konventionelle "public" Verzeichnis einer Zend
Framework Anwendung existiert und "cache" heißt. Der Skeleton Cache ist aktuell ein
NULL
Cache, er enthält also keine Optionen. Die verbleibenden zwei
Caches werden verwendet um einen standardmäßigen statischen Seitencache zu implementieren
wobei statisches HTML, XML oder sogar
JSON in statische Dateien unter /public
geschrieben
sein können. Die Kontrolle über einen statischen Seitencache wird über
Zend_Controller_Action_Helper_Cache
angeboten, und man kann
die Einstellungen dieser "page" verändern und den "tagcache" den Sie verwendet um Tags
zu verfolgen indem Zend_Cache_Manager::setTemplateOptions()
verwendet wird, oder sogar Zend_Cache_Manager::setCacheTemplate()
wenn alle deren Optionen überladen werden.