Beklendiği gibi APC çalışmıyor?

1 Cevap php

Ben aşağıdaki işlevi var:

function Cache($key, $value = null, $ttl = 60)
{
    if (isset($value) === true)
    {
        apc_store($key, $value, intval($ttl));
    }

    return apc_fetch($key);
}

Ve ben aşağıdaki kodu kullanarak test ediyorum:

Cache('ktime', time(), 3); // Store

sleep(1);
var_dump(Cache('ktime') . '-' . time()); echo '<hr />'; // Should Fetch
sleep(5);
var_dump(Cache('ktime') . '-' . time()); echo '<hr />'; // Should NOT Fetch
sleep(1);
var_dump(Cache('ktime') . '-' . time()); echo '<hr />'; // Should NOT Fetch
sleep(1);
var_dump(Cache('ktime') . '-' . time()); echo '<hr />'; // Should NOT Fetch

Ve bu çıktı:

string(21) "1273966771-1273966772"
string(21) "1273966771-1273966777"
string(21) "1273966771-1273966778"
string(21) "1273966771-1273966779"

Bu gibi bakmak gerekir:

string(21) "1273966771-1273966772"
string(11) "-1273966777"
string(11) "-1273966778"
string(11) "-1273966779"

Herkes bana bu garip davranışı anlamaya yardımcı olabilir ben anlamıyorum?

1 Cevap

Görünüşe göre bu APC 3.0.16 (2007-12-26) ve daha sonra bilinen bir sorundur, ve sabit olmayacaktır.

http://pecl.php.net/bugs/bug.php?id=13331

Ttl çalışır, ama "t", belirli bir istek sırasında bir sabittir. Yani bir önbelleğe alınan nesne, en azından bir sonraki isteği kadar dolmaz.