Memcached::getAllKeys

(PECL memcached >= 2.0.0)

Memcached::getAllKeysПолучает все ключи, хранящиеся на серверах

Описание

public Memcached::getAllKeys(): array|false

Memcached::getAllKeys() отправляет запрос на каждый сервер и получает массив всех ключей, хранящихся на нем в данный момент. Это не атомарная операция, так что это не по-настоящему непротиворечивый снимок ключей в данный момент времени. Memcache не может гарантировать возврата всех ключей, вы также не можете полагаться на то, что все ключи были возвращены.

Замечание:

Метод предназначен для отладки и не должен использоваться в больших масштабах!

Список параметров

У этой функции нет параметров.

Возвращаемые значения

Возвращает список ключей, хранящихся на всех серверах в случае успешного выполнения или false в случае возникновения ошибки.

add a note add a note

User Contributed Notes 6 notes

up
6
flaviu dot chelaru at gmail dot com
7 years ago
// initiate the memcached instance
$cache = new \Memcached();
$cache->addServer('localhost', '11211');

// get all stored memcached items

$keys = $cache->getAllKeys();
$cache->getDelayed($keys);

$store = $cache->fetchAll();

// delete by regex keys

$keys = $cache->getAllKeys();
$regex = 'product_.*';
foreach($keys as $item) {
    if(preg_match('/'.$regex.'/', $item)) {
        $cache->delete($item);
    }
}
up
4
xiangku7890 at gmail dot com
8 years ago
First I use the lastest memcached version 1.4.25, but unfortunately I found memcached::getAllkeys do not work with it, though i follow the others suggestion to disable Memcached::OPT_BINARY_PROTOCOL. So i try to use history versions, when i use memcached version 1.4.17, it works.
up
2
harold at snel dot me
5 years ago
/**
* Get all memcached keys. Special function because getAllKeys() is broken since memcached 1.4.23. Should only be needed on php 5.6
*
* cleaned up version of code found on Stackoverflow.com by Maduka Jayalath
*
* @return array|int - all retrieved keys (or negative number on error)
*/
public function getMemcachedKeys($host = '127.0.0.1', $port = 11211)
{
    $mem = @fsockopen($host, $port);
    if ($mem === false)
    {
        return -1;
    }

    // retrieve distinct slab
    $r = @fwrite($mem, 'stats items' . chr(10));
    if ($r === false)
    {
        return -2;
    }

    $slab = [];
    while (($l = @fgets($mem, 1024)) !== false)
    {
        // finished?
        $l = trim($l);
        if ($l == 'END')
        {
            break;
        }

        $m = [];
        // <STAT items:22:evicted_nonzero 0>
        $r = preg_match('/^STAT\sitems\:(\d+)\:/', $l, $m);
        if ($r != 1)
        {
            return -3;
        }
        $a_slab = $m[1];

        if (!array_key_exists($a_slab, $slab))
        {
            $slab[$a_slab] = [];
        }
    }

    reset($slab);
    foreach ($slab as $a_slab_key => &$a_slab)
    {
        $r = @fwrite($mem, 'stats cachedump ' . $a_slab_key . ' 100' . chr(10));
        if ($r === false)
        {
            return -4;
        }

        while (($l = @fgets($mem, 1024)) !== false)
        {
            // finished?
            $l = trim($l);
            if ($l == 'END')
            {
                break;
            }

            $m = [];
            // ITEM 42 [118 b; 1354717302 s]
            $r = preg_match('/^ITEM\s([^\s]+)\s/', $l, $m);
            if ($r != 1)
            {
                return -5;
            }
            $a_key = $m[1];

            $a_slab[] = $a_key;
        }
    }

    // close the connection
    @fclose($mem);
    unset($mem);

    $keys = [];
    reset($slab);
    foreach ($slab AS &$a_slab)
    {
        reset($a_slab);
        foreach ($a_slab AS &$a_key)
        {
            $keys[] = $a_key;
        }
    }
    unset($slab);

    return $keys;
}
up
0
danb1974 at gmail dot com
4 years ago
The right way to dump slab keys seems to be by using lru_crawler metadump instead of stats cachedump, see https://github.com/memcached/memcached/issues/405

<?php

function getAllKeys(string $host, int $port): array
{
   
$sock = fsockopen($host, $port, $errno, $errstr);
    if (
$sock === false) {
        throw new
Exception("Error connection to server {$host} on port {$port}: ({$errno}) {$errstr}");
    }

    if (
fwrite($sock, "stats items\n") === false) {
        throw new
Exception("Error writing to socket");
    }

   
$slabCounts = [];
    while ((
$line = fgets($sock)) !== false) {
       
$line = trim($line);
        if (
$line === 'END') {
            break;
        }

       
// STAT items:8:number 3
       
if (preg_match('!^STAT items:(\d+):number (\d+)$!', $line, $matches)) {
           
$slabCounts[$matches[1]] = (int)$matches[2];
        }
    }

    foreach (
$slabCounts as $slabNr => $slabCount) {
        if (
fwrite($sock, "lru_crawler metadump {$slabNr}\n") === false) {
            throw new
Exception('Error writing to socket');
        }

       
$count = 0;
        while ((
$line = fgets($sock)) !== false) {
           
$line = trim($line);
            if (
$line === 'END') {
                break;
            }

           
// key=foobar exp=1596440293 la=1596439293 cas=8492 fetch=no cls=24 size=14908
           
if (preg_match('!^key=(\S+)!', $line, $matches)) {
               
$allKeys[] = $matches[1];
               
$count++;
            }
        }

//        if ($count !== $slabCount) {
//            throw new Exception("Surprise, got {$count} keys instead of {$slabCount} keys");
//        }
   
}

    if (
fclose($sock) === false) {
        throw new
Exception('Error closing socket');
    }
   
    return
$allKeys;
}
up
-8
Cuchac
9 years ago
This command returns always FALSE when binary protocol in use (Memcached::OPT_BINARY_PROTOCOL = true). Without binary protocol it works.
up
-7
fykknd at 163 dot com
8 years ago
I got this answer..
My libmemcached version is 1.0.18. php-memcached version is 2.2.0
In Libmemcached at memcache.h line 84:
#define MAX_NUMBER_OF_SLAB_CLASSES (63 + 1)
Modify it to 201, compile again. It's ok.
主要还是版本不兼容造成的。libmemchaed里的一个bug,
memcached_return_t这个方法里的for循环,最大数是200,和上面的常量64定义不一致造成的。
To Top