2011-07-08 20 views
5

Estoy tratando de obtener solo objetos válidos de la caché. si lo hago List list = cache.getKeys();, devolverá las claves caducadas también. Pensé en agregar un oyente e intentar eliminar la clave yo mismo, pero mi escucha notifyElementExpired nunca se llama.Ehcache ¿cómo eliminar las claves cuando el elemento ha expirado?

Aquí está mi código:

public static void main(String[] args) throws Exception { 
    // TODO Auto-generated method stub 

    CacheManager.getInstance().addCache("test"); 

    Cache cache = CacheManager.getInstance().getCache("test"); 

    cache.getCacheConfiguration().setTimeToLiveSeconds(10); 

    cache.getCacheEventNotificationService().registerListener(new CacheEventListener() { 

     public void notifyRemoveAll(Ehcache arg0) { 
      // TODO Auto-generated method stub 
      System.out.println("notifyRemoveAll cache=" + arg0); 
     } 

     public void notifyElementUpdated(Ehcache arg0, Element arg1) 
       throws CacheException { 
      // TODO Auto-generated method stub 
      System.out.println("notifyElementUpdated cache=" + arg0 + " element=" + arg1); 
     } 

     public void notifyElementRemoved(Ehcache arg0, Element arg1) 
       throws CacheException { 
      // TODO Auto-generated method stub 
      System.out.println("notifyElementRemoved cache=" + arg0 + " element=" + arg1); 
     } 

     public void notifyElementPut(Ehcache arg0, Element arg1) 
       throws CacheException { 
      // TODO Auto-generated method stub 
      System.out.println("notifyElementPut cache=" + arg0 + " element=" + arg1); 
     } 

     public void notifyElementExpired(Ehcache arg0, Element arg1) { 
      // TODO Auto-generated method stub 
      System.out.println("notifyElementExpired cache=" + arg0 + " element=" + arg1); 
     } 

     public void notifyElementEvicted(Ehcache arg0, Element arg1) { 
      // TODO Auto-generated method stub 
      System.out.println("notifyElementEvicted cache=" + arg0 + " element=" + arg1); 
     } 

     public void dispose() { 
      // TODO Auto-generated method stub 
      System.out.println("dispose"); 
     } 

     public Object clone() throws CloneNotSupportedException { 
      throw new CloneNotSupportedException(); 
     } 
    }); 

    //cache.getCacheConfiguration().setTimeToLiveSeconds(0); 

    String key = "key"; 
    String value = "value1"; 

    System.out.println("created at = " + new Date()); 
    //cache.put(new Element(key, value, false, new Integer(1), new Integer(5))); 
    cache.put(new Element(key, value, false, new Integer(1), new Integer(5))); 
    System.out.println("key=" + key + "will expired at object=" + new Date(cache.get(key).getExpirationTime())); 


    Thread.sleep(7000); 

    @SuppressWarnings("unchecked") 
    List list = cache.getKeys(); 

    System.out.println("current time = " + new Date()); 
    for (Object item : list) { 
     System.out.println("created at = " + new Date()); 
     //System.out.println("key=" + item + " object=" + new Date(cache.get(item).getExpirationTime())); 

     //System.out.println(item + " isExpired=" + cache.get(item).isExpired()); 
    } 

    Thread.sleep(30000); 

} 

Respuesta

0

He añadido el código de oyente a mi caché. Y noté que el evento elementExpired se dispara cuando intento obtener el elemento de la memoria caché. Entonces, es una acción floja o bajo demanda.

Puede utilizar el método .getKeysWithExpiryCheck() para eliminar los elementos caducados de la lista.

1

Antes de obtener el recuento de las claves de la memoria caché, puede desalojar los elementos caducados como se muestra a continuación. cache.evictExpiredElements();

Para que solo obtenga las teclas activas.

Cuestiones relacionadas