Store::Controlled Class Referenceabstract

#include <Controlled.h>

Inheritance diagram for Store::Controlled:
Collaboration diagram for Store::Controlled:

Public Member Functions

virtual StoreEntryget (const cache_key *)=0
virtual void reference (StoreEntry &e)=0
 somebody needs this entry (many cache replacement policies need to know) More...
virtual bool dereference (StoreEntry &e)=0
virtual void updateHeaders (StoreEntry *)
 make stored metadata and HTTP headers the same as in the given entry More...
virtual bool anchorToCache (StoreEntry &, bool &)
virtual bool updateAnchored (StoreEntry &)
virtual void create ()=0
 create system resources needed for this store to operate in the future More...
virtual void init ()=0
virtual uint64_t maxSize () const =0
virtual uint64_t minSize () const =0
 the minimum size the store will shrink to via normal housekeeping More...
virtual uint64_t currentSize () const =0
 current size More...
virtual uint64_t currentCount () const =0
 the total number of objects stored right now More...
virtual int64_t maxObjectSize () const =0
 the maximum size of a storable object; -1 if unlimited More...
virtual void getStats (StoreInfoStats &stats) const =0
 collect statistics More...
virtual void stat (StoreEntry &e) const =0
virtual void evictCached (StoreEntry &e)=0
virtual void evictIfFound (const cache_key *)=0
virtual int callback ()
 called once every main loop iteration; TODO: Move to UFS code. More...
virtual void maintain ()=0
 perform regular periodic maintenance; TODO: move to UFSSwapDir::Maintain More...
virtual void sync ()
 prepare for shutdown More...

Detailed Description

Storage controlled by a Controller. This API is shared among Disks, Disk, Memory caches and Transients.

Definition at line 18 of file Controlled.h.

Member Function Documentation

◆ anchorToCache()

virtual bool Store::Controlled::anchorToCache ( StoreEntry ,
bool &   

If Transients entry cannot be attached to this storage, return false. If the entry is not found, return false. Otherwise, return true after tying the entry to this cache and setting inSync to updateAnchored().

Reimplemented in MemStore, Store::Disks, and Rock::SwapDir.

Definition at line 40 of file Controlled.h.

Referenced by Store::Disks::anchorToCache().

◆ callback()

virtual int Store::Storage::callback ( )

Reimplemented in TestStore, Fs::Ufs::UFSSwapDir, Store::Controller, and Store::Disks.

Definition at line 72 of file Storage.h.

◆ create()

virtual void Store::Storage::create ( )
pure virtualinherited

◆ currentCount()

virtual uint64_t Store::Storage::currentCount ( ) const
pure virtualinherited

◆ currentSize()

virtual uint64_t Store::Storage::currentSize ( ) const
pure virtualinherited

◆ dereference()

virtual bool Store::Controlled::dereference ( StoreEntry e)
pure virtual

somebody no longer needs this entry (usually after calling reference()) return false iff the idle entry should be destroyed

Implemented in Fs::Ufs::UFSSwapDir, Rock::SwapDir, MemStore, Store::Disk, Store::Disks, and Transients.

◆ evictCached()

virtual void Store::Storage::evictCached ( StoreEntry e)
pure virtualinherited

Prevent new get() calls from returning the matching entry. If the matching entry is unused, it may be removed from the store now. The store entry is matched using either e attachment info or e.key.

Implemented in Rock::SwapDir, Fs::Ufs::UFSSwapDir, MemStore, Store::Controller, Store::Disks, TestSwapDir, and Transients.

Referenced by Store::Disks::evictCached().

◆ evictIfFound()

virtual void Store::Storage::evictIfFound ( const cache_key )
pure virtualinherited

An evictCached() equivalent for callers that did not get() a StoreEntry. Callers with StoreEntry objects must use evictCached() instead.

Implemented in Rock::SwapDir, Fs::Ufs::UFSSwapDir, MemStore, Store::Controller, Store::Disks, TestSwapDir, and Transients.

◆ get()

virtual StoreEntry * Store::Controlled::get ( const cache_key )
pure virtual
a possibly unlocked/unregistered stored entry with key (or nil) The returned entry might not match the caller's Store ID or method. The caller must abandon()/release() the entry or register it with Root(). This method must not trigger slow I/O operations (e.g., disk swap in).

Implemented in MemStore, Store::Disk, Store::Disks, Transients, and Rock::SwapDir.

◆ getStats()

virtual void Store::Storage::getStats ( StoreInfoStats stats) const
pure virtualinherited

◆ init()

virtual void Store::Storage::init ( )
pure virtualinherited

Start preparing the store for use. To check readiness, callers should use readable() and writable() methods.

Implemented in Rock::SwapDir, TestStore, Fs::Ufs::UFSSwapDir, MemStore, Store::Controller, Store::Disks, TestSwapDir, and Transients.

◆ maintain()

virtual void Store::Storage::maintain ( )
pure virtualinherited

◆ maxObjectSize()

virtual int64_t Store::Storage::maxObjectSize ( ) const
pure virtualinherited

◆ maxSize()

virtual uint64_t Store::Storage::maxSize ( ) const
pure virtualinherited

The maximum size the store will support in normal use. Inaccuracy is permitted, but may throw estimates for memory etc out of whack.

Implemented in TestStore, MemStore, Store::Controller, Store::Disk, Store::Disks, TestSwapDir, and Transients.

◆ minSize()

virtual uint64_t Store::Storage::minSize ( ) const
pure virtualinherited

◆ reference()

virtual void Store::Controlled::reference ( StoreEntry e)
pure virtual

◆ stat()

virtual void Store::Storage::stat ( StoreEntry e) const
pure virtualinherited

Output stats to the provided store entry. TODO: make these calls asynchronous

Implemented in TestStore, Store::Controller, Store::Disk, Store::Disks, TestSwapDir, MemStore, and Transients.

◆ sync()

virtual void Store::Storage::sync ( void  )

Reimplemented in Fs::Ufs::UFSSwapDir, Store::Controller, and Store::Disks.

Definition at line 78 of file Storage.h.

◆ updateAnchored()

virtual bool Store::Controlled::updateAnchored ( StoreEntry )

Update a local Transients entry with fresh info from this cache (if any). Return true iff the cache supports Transients entries and the given local Transients entry is now in sync with this storage.

Reimplemented in Rock::SwapDir, MemStore, and Store::Disks.

Definition at line 45 of file Controlled.h.

Referenced by Store::Disks::updateAnchored().

◆ updateHeaders()

virtual void Store::Controlled::updateHeaders ( StoreEntry )

Reimplemented in Store::Disks, Rock::SwapDir, and MemStore.

Definition at line 35 of file Controlled.h.

Referenced by Store::Disks::updateHeaders().

The documentation for this class was generated from the following file:






Web Site Translations