Transients.cc
Go to the documentation of this file.
static const SBuf MapLabel("transients_map")
shared memory segment path to use for Transients map
DefineRunnerRegistrator(TransientsRr)
static void Broadcast(const StoreEntry &e, const bool includingThisWorker=false)
notify other workers about changes in entry state (e.g., new data)
Definition: CollapsedForwarding.cc:70
Definition: Segment.h:85
Definition: StoreMap.h:57
aggregates anchor and slice owners for Init() caller convenience
Definition: StoreMap.h:233
Anchor * openForWriting(const cache_key *const key, sfileno &fileno)
Definition: StoreMap.cc:140
bool markedForDeletion(const cache_key *const)
Definition: StoreMap.cc:354
Anchor & writeableEntry(const AnchorId anchorId)
writeable anchor for the entry created by openForWriting()
Definition: StoreMap.cc:237
const Anchor & readableEntry(const AnchorId anchorId) const
readable anchor for the entry created by openForReading()
Definition: StoreMap.cc:244
static Owner * Init(const SBuf &path, const int slotLimit)
initialize shared memory
Definition: StoreMap.cc:42
void closeForWriting(const sfileno fileno)
successfully finish creating or updating the entry at fileno pos
Definition: StoreMap.cc:200
const Anchor * openOrCreateForReading(const cache_key *, sfileno &)
openForReading() but creates a new entry if there is no old one
Definition: StoreMap.cc:103
const Anchor * openForReading(const cache_key *const key, sfileno &fileno)
opens entry (identified by key) for reading, increments read level
Definition: StoreMap.cc:439
const Anchor * peekAtWriter(const sfileno fileno) const
Definition: StoreMap.cc:296
void closeForReadingAndFreeIdle(const sfileno fileno)
same as closeForReading() but also frees the entry if it is unlocked
Definition: StoreMap.cc:505
void startAppending(const sfileno fileno)
restrict opened for writing entry to appending operations; allow reads
Definition: StoreMap.cc:191
sfileno fileNoByKey(const cache_key *const key) const
computes map entry anchor position for a given entry key
Definition: StoreMap.cc:911
const Anchor & peekAtEntry(const sfileno fileno) const
Definition: StoreMap.cc:306
void switchWritingToReading(const sfileno fileno)
stop writing (or updating) the locked entry and start reading it
Definition: StoreMap.cc:211
void open(const int32_t anIndex, const Io anIo)
associate our StoreEntry with a Transients entry at the given index
Definition: MemObject.h:183
int64_t shared_transient_entries_limit
Definition: SquidConfig.h:345
Definition: Store.h:42
bool hasTransients() const
whether there is a corresponding locked transients table entry
Definition: Store.h:211
High-level store statistics used by mgr:info action. Used inside PODs!
Definition: StoreStats.h:14
void create() override
called when the runner should create a new memory segment
Definition: Transients.cc:406
int readers(const StoreEntry &e) const
number of entry readers some time ago
Definition: Transients.cc:297
bool hasWriter(const StoreEntry &)
whether we or somebody else is in the "writing to Transients" I/O state
Definition: Transients.cc:260
void monitorIo(StoreEntry *, const cache_key *, const Store::IoStatus)
Definition: Transients.cc:192
void addReaderEntry(StoreEntry &, const cache_key *)
Definition: Transients.cc:248
void noteFreeMapSlice(const Ipc::StoreMapSliceId sliceId) override
adjust slice-linked state before a locked Readable slice is erased
Definition: Transients.cc:268
TransientsMap * map
shared packed info indexed by Store keys, for creating new StoreEntries
Definition: Transients.h:103
void addWriterEntry(StoreEntry &, const cache_key *)
addEntry() helper used for cache entry creators/writers
Definition: Transients.cc:228
bool isWriter(const StoreEntry &) const
whether the entry is in "writing to Transients" I/O state
Definition: Transients.cc:376
void disconnect(StoreEntry &)
the caller is done writing or reading the given entry
Definition: Transients.cc:332
StoreEntry * findCollapsed(const sfileno xitIndex)
return a local, previously collapsed entry
Definition: Transients.cc:176
int64_t maxObjectSize() const override
the maximum size of a storable object; -1 if unlimited
Definition: Transients.cc:126
void addEntry(StoreEntry *, const cache_key *, const Store::IoStatus)
creates a new Transients entry
Definition: Transients.cc:211
bool markedForDeletion(const cache_key *) const
Definition: Transients.cc:363
void status(const StoreEntry &e, EntryStatus &entryStatus) const
copies current shared entry metadata into entryStatus
Definition: Transients.cc:274
uint64_t minSize() const override
the minimum size the store will shrink to via normal housekeeping
Definition: Transients.cc:99
void reference(StoreEntry &e) override
somebody needs this entry (many cache replacement policies need to know)
Definition: Transients.cc:133
void maintain() override
perform regular periodic maintenance; TODO: move to UFSSwapDir::Maintain
Definition: Transients.cc:93
static int64_t EntryLimit()
calculates maximum number of entries we need to store and map
Definition: Transients.cc:356
bool isReader(const StoreEntry &) const
whether the entry is in "reading from Transients" I/O state
Definition: Transients.cc:370
void completeWriting(const StoreEntry &e)
called when the in-transit entry has been successfully cached
Definition: Transients.cc:286
uint64_t currentCount() const override
the total number of objects stored right now
Definition: Transients.cc:120
size_t PageSize()
returns page size in bytes; all pages are assumed to be the same size
Definition: Pages.cc:28
size_t PageLimit()
the total number of shared memory pages that can be in use at any time
Definition: Pages.cc:55
class Ping::pingStats_ stats
bool UsingSmp()
Whether there should be more than one worker process running.
Definition: tools.cc:696