2

我正在使用 APC 缓存进行昂贵的查询,该查询检索具有相关文件、付款、事件等的作业。我想知道在 Doctrine 1.* 中是否有可用的缓存失效解决方案。

我想出了以下可行的解决方案,它确实有效,我只是不想发明一个轮子。

如果有更好/其他现有的解决方案,请建议我。

记录侦听器尝试清除具有给定 idpostSave事件的缓存:

class My_Doctrine_Record_Listener_ClearCache extends Doctrine_Record_Listener
{
    /**
     * Clear cache by table tags
     * 
     * @param Doctrine_Event $event
     * @return null 
     */
    public function postSave(Doctrine_Event $event)
    {
        $cache = new Doctrine_Cache_Apc(); 

        /* @var $model Doctrine_Record */
        $model = $event->getInvoker();
        $name  = get_class($model);

        /* @var $table Doctrine_Table */
        $table = $model->getTable($name);
        if (method_exists($table, 'getCacheTags')) {
            foreach ($table->getCacheTags() as $tag) {
                $id = preg_replace('/%([\w]+)%/e', '$model->{\\1}', $tag);
                $cache->delete($id);
            }
        }
    }
}

这就是我在表格中的内容:

class FileTable extends Doctrine_Table
{
   /* ... */
   public function getCacheTags()
   {
        return array(
            'job_view_%job_id%'
        );
   }
   /* ... */ 
}

class JobTable extends Doctrine_Table
{
    /* ... */
    public function getCacheTags()
    {        
        return array(
           'job_view_%id%'
        );
    }
    /* ... */ 
}
4

1 回答 1

0

上述解决方案已经在生产环境中使用了 7 年,所以可以肯定地说 - 它确实工作得很好。

于 2019-03-24T22:46:00.357 回答