38 lines
1.3 KiB
PHP
38 lines
1.3 KiB
PHP
<?php
|
|
|
|
/*
|
|
* This file is part of the Symfony package.
|
|
*
|
|
* (c) Fabien Potencier <fabien@symfony.com>
|
|
*
|
|
* For the full copyright and license information, please view the LICENSE
|
|
* file that was distributed with this source code.
|
|
*/
|
|
|
|
namespace Symfony\Component\Cache\Adapter;
|
|
|
|
use Symfony\Component\Cache\Marshaller\MarshallerInterface;
|
|
use Symfony\Component\Cache\Traits\MemcachedTrait;
|
|
|
|
class MemcachedAdapter extends AbstractAdapter
|
|
{
|
|
use MemcachedTrait;
|
|
|
|
protected $maxIdLength = 250;
|
|
|
|
/**
|
|
* Using a MemcachedAdapter with a TagAwareAdapter for storing tags is discouraged.
|
|
* Using a RedisAdapter is recommended instead. If you cannot do otherwise, be aware that:
|
|
* - the Memcached::OPT_BINARY_PROTOCOL must be enabled
|
|
* (that's the default when using MemcachedAdapter::createConnection());
|
|
* - tags eviction by Memcached's LRU algorithm will break by-tags invalidation;
|
|
* your Memcached memory should be large enough to never trigger LRU.
|
|
*
|
|
* Using a MemcachedAdapter as a pure items store is fine.
|
|
*/
|
|
public function __construct(\Memcached $client, string $namespace = '', int $defaultLifetime = 0, MarshallerInterface $marshaller = null)
|
|
{
|
|
$this->init($client, $namespace, $defaultLifetime, $marshaller);
|
|
}
|
|
}
|