Sto lavorando su una classe client che deve caricare i dati da un database di rete. È stato suggerito che l'aggiunta di un servizio di memorizzazione nella cache standard al client potrebbe migliorare le sue prestazioni.Esiste una classe di caching Python standard di terze parti?
Mi piacerebbe molto non dover costruire la mia classe di cache: è noto che questi forniscono punti comuni di errore. Sarebbe molto meglio usare una classe che qualcun altro ha sviluppato piuttosto che spendere una quantità enorme del mio tempo per il debug di un sistema di caching fatto in casa.
sviluppatori Java hanno questo: http://ehcache.sourceforge.net/
Si tratta di una classe di caching ad alte prestazioni per uso generico in grado di supportare tutti i tipi di stoccaggio. Ha opzioni per la scadenza basata sul tempo e altri metodi per la raccolta dei rifiuti. Sembra davvero buono Purtroppo non riesco a trovare nulla di buono per Python.
Quindi, qualcuno può suggerire una classe cache che è pronta per me da usare. La mia lista dei desideri è:
- Possibilità di limitare il numero di oggetti nella cache.
- Possibilità di limitare l'età massima degli oggetti nella cache.
- LRU oggetto expirey
- Possibilità di selezionare più forme di stoccaggio (ad esempio memoria, disco)
- Bene debug, ben mantenuto, in uso da almeno una conosciuta applicazione.
- Buona prestazione.
Quindi, qualche suggerimento?
AGGIORNAMENTO: Sto cercando la memorizzazione nella cache LOCALE degli oggetti. Il server a cui mi collego è già pesantemente memorizzato nella cache. Memcached non è appropriato perché richiede un ulteriore traffico di rete tra il client Windows e il server.
Non è appropriato in questo caso ... Sto cercando di velocizzare un'applicazione di rete aggiungendo una cache LOCAL. Una cache di rete sarà lenta per gli utenti finali dato che potrebbero essere ovunque nel mondo. –
Purtroppo, a questo stadio è complicato usare Jython. –