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);
 | |
|     }
 | |
| }
 |