4

Zend Framework プロジェクトがあり、Rediskaを Redis クライアントとして使用することにしました。Rediska には、ZF 用のキャッシュ バックエンド アダプター - Rediska_Zend_Cache_Backend_Redis があります。

オブジェクトの DB コレクションからフェッチし、キャッシュに保存しようとしましたが、エラーが発生しました: 接続の読み取りがタイムアウトしました。コードの私の例:

$rediskaOptions = array(
                    'name' => 'cache',
                    'namespace' => 'Cache_',
                    'servers' => array( 'cache' => array(
                        'host'   => Rediska_Connection::DEFAULT_HOST,
                        'port'   => Rediska_Connection::DEFAULT_PORT,
                        'password' => 'qwerty'
                        )
                    )
        );

$cache = Zend_Cache::factory('Core', 'Rediska_Zend_Cache_Backend_Redis',
  array('lifetime' => NULL, 'automatic_serialization' => true),
  array('rediska' => $rediskaOptions), false, true
);
$cacheId = 'news_main';
if (!($topics = $cache->load($cacheId))) {
    $topics = DAOFactory::getInstance()->getTopicDAO()->fetchTopic(1);
    $cache->save($topics, $cacheId);
}

シリアル化後のコンテンツのサイズは 26787 バイトです。たぶん、Redisには送信のサイズ制限がありますか?

4

1 に答える 1

0

それが役立つ場合は、ZF でも Rediska を使用しています。これが私がそれを設定した方法です。

$options = array(
                'servers' => array(
                    array(  'host'     => '127.0.0.1',
                            'port'     => 6379,
                            'alias'    => 'cache'
                ),
                //'name' => 'cache',
                //'namespace' => 'Cache_'
                )
            );

    $rediska = new Rediska($options);

    $frontendOptions = array('automatic_serialization' => true);
    $backendOptions  = array('rediska' => $rediska);

    $cache = Zend_Cache::factory( 'Core',
            'Rediska_Zend_Cache_Backend_Redis',
            $frontendOptions,
            $backendOptions,
            false,
            true
    );

私が見る違いは、バックエンド オプションにあります。rediska を rediska インスタンスにポイントします。

于 2012-02-20T23:30:20.817 に答える