#include "squid.h"
#include "base/AsyncCbdataCalls.h"
#include "base/PackableStream.h"
#include "base/TextException.h"
#include "CacheDigest.h"
#include "CacheManager.h"
#include "CollapsedForwarding.h"
#include "comm/Connection.h"
#include "comm/Read.h"
#include "debug/Messages.h"
#include "ETag.h"
#include "event.h"
#include "fde.h"
#include "globals.h"
#include "http.h"
#include "HttpReply.h"
#include "HttpRequest.h"
#include "mem_node.h"
#include "MemObject.h"
#include "MemStore.h"
#include "mgr/Registration.h"
#include "mgr/StoreIoAction.h"
#include "repl_modules.h"
#include "RequestFlags.h"
#include "sbuf/Stream.h"
#include "SquidConfig.h"
#include "StatCounters.h"
#include "stmem.h"
#include "Store.h"
#include "store/Controller.h"
#include "store/Disk.h"
#include "store/Disks.h"
#include "store/SwapMetaOut.h"
#include "store_digest.h"
#include "store_key_md5.h"
#include "store_log.h"
#include "store_rebuild.h"
#include "StoreClient.h"
#include "StoreIOState.h"
#include "StrList.h"
#include "swap_log_op.h"
#include "tools.h"
#include "DelayPools.h"
#include "mem/Allocator.h"
#include "mem/Pool.h"
#include <climits>
#include <stack>
Go to the source code of this file.
Classes | |
struct | _storerepl_entry |
struct | _store_check_cachable_hist |
Macros | |
#define | REBUILD_TIMESTAMP_DELTA_MAX 2 |
#define | STORE_IN_MEM_BUCKETS (229) |
#define | MAINTAIN_MAX_SCAN 1024 |
#define | MAINTAIN_MAX_REMOVE 64 |
Typedefs | |
typedef struct _storerepl_entry | storerepl_entry_t |
Functions | |
static int | getKeyCounter (void) |
static void | StatQueues (StoreEntry *e) |
reports the current state of Store-related queues More... | |
void | destroyStoreEntry (void *data) |
StoreEntry * | storeGetPublic (const char *uri, const HttpRequestMethod &method) |
StoreEntry * | storeGetPublicByRequestMethod (HttpRequest *req, const HttpRequestMethod &method, const KeyScope keyScope) |
StoreEntry * | storeGetPublicByRequest (HttpRequest *req, const KeyScope keyScope) |
StoreEntry * | storeCreatePureEntry (const char *url, const char *log_url, const HttpRequestMethod &method) |
StoreEntry * | storeCreateEntry (const char *url, const char *logUrl, const RequestFlags &flags, const HttpRequestMethod &method) |
void | storeAppendPrintf (StoreEntry *e, const char *fmt,...) |
void | storeAppendVPrintf (StoreEntry *e, const char *fmt, va_list vargs) |
int | storeTooManyDiskFilesOpen (void) |
void | storeCheckCachableStats (StoreEntry *sentry) |
void | storeGetMemSpace (int size) |
static void | storeLateRelease (void *) |
static void | storeRegisterWithCacheManager (void) |
void | storeInit (void) |
void | storeConfigure (void) |
int | expiresMoreThan (time_t expires, time_t when) |
void | storeFsInit (void) |
void | storeReplAdd (const char *type, REMOVALPOLICYCREATE *create) |
RemovalPolicy * | createRemovalPolicy (RemovalPolicySettings *settings) |
static std::ostream & | operator<< (std::ostream &os, const Store::IoStatus &io) |
std::ostream & | operator<< (std::ostream &os, const StoreEntry &e) |
Variables | |
const char * | memStatusStr [] |
const char * | pingStatusStr [] |
const char * | storeStatusStr [] |
const char * | swapStatusStr [] |
static storerepl_entry_t * | storerepl_list = nullptr |
static OBJH | storeCheckCachableStats |
static EVH | storeLateRelease |
static std::stack< StoreEntry * > | LateReleaseStack |
struct _store_check_cachable_hist | store_check_cachable_hist |
Macro Definition Documentation
◆ MAINTAIN_MAX_REMOVE
◆ MAINTAIN_MAX_SCAN
◆ REBUILD_TIMESTAMP_DELTA_MAX
#define REBUILD_TIMESTAMP_DELTA_MAX 2 |
StoreEntry uses explicit new/delete operators, which set pool chunk size to 2MB XXX: convert to MEMPROXY_CLASS() API
◆ STORE_IN_MEM_BUCKETS
Typedef Documentation
◆ storerepl_entry_t
typedef struct _storerepl_entry storerepl_entry_t |
Function Documentation
◆ createRemovalPolicy()
RemovalPolicy * createRemovalPolicy | ( | RemovalPolicySettings * | settings | ) |
Definition at line 1657 of file store.cc.
References RemovalPolicySettings::args, _storerepl_entry::create, DBG_IMPORTANT, debugs, fatalf(), storerepl_list, RemovalPolicySettings::type, and _storerepl_entry::typestr.
Referenced by Fs::Ufs::UFSSwapDir::parse(), storeInit(), TestUfs::testUfsDefaultEngine(), and TestUfs::testUfsSearch().
◆ destroyStoreEntry()
void destroyStoreEntry | ( | void * | data | ) |
Definition at line 389 of file store.cc.
References assert, debugs, StoreEntry::destroyMemObject(), Store::Disk::disconnect(), StoreEntry::disk(), StoreEntry::hasDisk(), StoreEntry::hashDelete(), and hash_link::key.
Referenced by StoreEntry::release().
◆ expiresMoreThan()
int expiresMoreThan | ( | time_t | expires, |
time_t | when | ||
) |
Definition at line 1324 of file store.cc.
References squid_curtime.
◆ getKeyCounter()
|
static |
Definition at line 514 of file store.cc.
Referenced by StoreEntry::setPrivateKey().
◆ operator<<() [1/2]
|
static |
Definition at line 2011 of file store.cc.
References Store::ioDone, Store::ioReading, Store::ioUndecided, and Store::ioWriting.
◆ operator<<() [2/2]
std::ostream & operator<< | ( | std::ostream & | os, |
const StoreEntry & | e | ||
) |
◆ StatQueues()
|
static |
Definition at line 133 of file store.cc.
References assert, CollapsedForwarding::StatQueue(), and IpcIoFile::StatQueue().
Referenced by storeRegisterWithCacheManager().
◆ storeAppendPrintf()
void storeAppendPrintf | ( | StoreEntry * | e, |
const char * | fmt, | ||
... | |||
) |
Definition at line 841 of file store.cc.
References StoreEntry::vappendf().
Referenced by DiskThreadsIOStrategy::aioStats(), asnStats(), cacheDigestGuessStatsReport(), cacheDigestReport(), carpCachemgr(), clientdbDump(), commIncomingStats(), Auth::User::CredentialsCacheStats(), Store::Disks::Dump(), Fs::Ufs::UFSSwapDir::dump(), Ipc::ReadWriteLockStats::dump(), DelaySpec::dump(), Auth::SchemeConfig::dump(), DelayPool::dump(), MessageDelayPool::dump(), DiskdAction::dump(), Mgr::MenuAction::dump(), Mgr::ReconfigureAction::dump(), Mgr::RotateAction::dump(), Mgr::OfflineToggleAction::dump(), Mgr::FunAction::dump(), Mgr::InfoAction::dump(), Mgr::StoreIoAction::dump(), Format::Format::dump(), Note::dump(), ClientDelayPool::dump(), dump_access_log(), dump_acl(), dump_acl_address(), dump_acl_b_size_t(), dump_acl_tos(), dump_address(), dump_b_int64_t(), dump_b_size_t(), dump_b_ssize_t(), dump_cachemgrpasswd(), dump_CpuAffinityMap(), dump_denyinfo(), dump_externalAclHelper(), dump_generic_port(), dump_HeaderWithAclList(), dump_icap_service_failure_limit(), dump_int(), dump_int64_t(), dump_IpAddress_list(), dump_kb_int64_t(), dump_memcachemode(), dump_onoff(), dump_peer(), dump_peers(), dump_PortCfg(), dump_refreshpattern(), dump_removalpolicy(), dump_sslproxy_cert_adapt(), dump_sslproxy_cert_sign(), dump_string(), dump_time_nanoseconds(), dump_tristate(), dump_u_short(), dump_uri_whitespace(), dump_UrlHelperTimeout(), dump_wccp2_amethod(), dump_wccp2_method(), dump_wccp2_service(), dump_wccp2_service_info(), dump_wordlist(), DumpAvgStat(), DumpCountersStats(), PconnPool::dumpHash(), PconnPool::dumpHist(), DumpInfo(), DumpIoStats(), DumpMallocStatistics(), ClientDelayConfig::dumpPoolCount(), DelayConfig::dumpPoolCount(), Rock::SwapDir::dumpRateOption(), Adaptation::Config::dumpService(), Adaptation::Config::DumpServiceGroups(), DumpServiceTimesStats(), Rock::SwapDir::dumpSizeOption(), fde::dumpStats(), fde::DumpStats(), Rock::SwapDir::dumpTimeOption(), externalAclStats(), fqdnStats(), fwdStats(), header_mangler_dump_access(), header_mangler_dump_replacement(), httpHdrCcStatDumper(), httpHdrScStatDumper(), httpHdrScTargetStatDumper(), httpHeaderFieldStatDumper(), httpHeaderFldsPerHdrDumper(), httpHeaderStatDump(), httpHeaderStoreReport(), idnsStats(), ipcacheStatPrint(), lru_stats(), netdbBinaryExchange(), netdbDump(), Fs::Ufs::UFSSwapDir::optionIODump(), Store::Disk::optionObjectSizeDump(), DiskdIOStrategy::optionQ1Dump(), DiskdIOStrategy::optionQ2Dump(), Store::Disk::optionReadOnlyDump(), peerDigestStatsReport(), peerSourceHashCachemgr(), peerUserHashCachemgr(), printRadixNode(), redirectStats(), refreshCountsStats(), refreshCountsStatsEntry(), refreshStats(), squidaio_stats(), Store::Controller::stat(), Store::Disk::stat(), Store::Disks::stat(), MemStore::stat(), Transients::stat(), stat_ipcache_get(), statClientRequests(), statCountersHistograms(), statDigestBlob(), Fs::Ufs::UFSSwapDir::statfs(), Rock::SwapDir::statfs(), DiskdIOStrategy::statfs(), statHistBinDumper(), statHistEnumDumper(), statHistIntDumper(), statHistSBufDumper(), statObjects(), statPeerSelect(), DelayPools::Stats(), ClassCBucket::stats(), DelayBucket::stats(), DelayTaggedBucket::stats(), DelayUserBucket::stats(), Aggregate::stats(), VectorPool::stats(), ClassCHostPool::stats(), DelayTagged::stats(), DelayUser::stats(), DelaySpec::stats(), statUtilization(), storeCheckCachableStats(), storeDigestReport(), storeIdStats(), and storeLogTagsHist().
◆ storeAppendVPrintf()
void storeAppendVPrintf | ( | StoreEntry * | e, |
const char * | fmt, | ||
va_list | vargs | ||
) |
Definition at line 851 of file store.cc.
References StoreEntry::vappendf().
◆ storeCheckCachableStats()
void storeCheckCachableStats | ( | StoreEntry * | sentry | ) |
Definition at line 969 of file store.cc.
References _store_check_cachable_hist::Default, _store_check_cachable_hist::missing_parts, _store_check_cachable_hist::no, _store_check_cachable_hist::not_entry_cachable, _store_check_cachable_hist::private_key, store_check_cachable_hist, storeAppendPrintf(), _store_check_cachable_hist::too_big, _store_check_cachable_hist::too_many_open_fds, _store_check_cachable_hist::too_many_open_files, _store_check_cachable_hist::too_small, _store_check_cachable_hist::wrong_content_length, and _store_check_cachable_hist::yes.
◆ storeConfigure()
void storeConfigure | ( | void | ) |
Definition at line 1256 of file store.cc.
References Store::Controller::configure(), and Store::Root().
Referenced by configDoConfigure(), and storeSwapOutFileClosed().
◆ storeCreateEntry()
StoreEntry * storeCreateEntry | ( | const char * | url, |
const char * | logUrl, | ||
const RequestFlags & | flags, | ||
const HttpRequestMethod & | method | ||
) |
Like storeCreatePureEntry(), but also locks the entry and sets entry key.
Definition at line 745 of file store.cc.
References RequestFlags::cachable, RequestFlags::hierarchical, StoreEntry::lock(), neighbors_do_private_keys, StoreEntry::setPrivateKey(), StoreEntry::setPublicKey(), and storeCreatePureEntry().
Referenced by Ssl::ServerBump::ServerBump(), StoreEntry::adjustVary(), asnCacheStart(), TestRock::createEntry(), Mgr::Action::createStoreEntry(), clientReplyContext::createStoreEntry(), ClientHttpRequest::doCallouts(), netdbExchangeStart(), peerCountMcastPeersCreateAndSend(), peerDigestRequest(), clientReplyContext::processExpired(), UrnState::start(), storeDigestRewriteStart(), and TestUfs::testUfsSearch().
◆ storeCreatePureEntry()
StoreEntry * storeCreatePureEntry | ( | const char * | storeId, |
const char * | logUrl, | ||
const HttpRequestMethod & | method | ||
) |
Creates a new StoreEntry with mem_obj and sets initial flags/states.
Definition at line 727 of file store.cc.
References StoreEntry::createMemObject(), debugs, EBIT_SET, ENTRY_VALIDATED, StoreEntry::flags, StoreEntry::lastref, PING_NONE, StoreEntry::ping_status, StoreEntry::refcount, squid_curtime, STORE_PENDING, StoreEntry::store_status, and StoreEntry::timestamp.
Referenced by MimeIcon::load(), and storeCreateEntry().
◆ storeFsInit()
void storeFsInit | ( | void | ) |
◆ storeGetMemSpace()
void storeGetMemSpace | ( | int | size | ) |
Clear Memory storage to accommodate the given object len
Definition at line 1107 of file store.cc.
References Store::Controller::freeMemorySpace(), Store::Root(), and size.
Referenced by store_client::maybeWriteFromDiskToMemory(), and StoreEntry::write().
◆ storeGetPublic()
StoreEntry * storeGetPublic | ( | const char * | uri, |
const HttpRequestMethod & | method | ||
) |
Definition at line 490 of file store.cc.
References Store::Controller::find(), Store::Root(), and storeKeyPublic().
Referenced by StoreEntry::adjustVary(), asnCacheStart(), findPreviouslyCachedEntry(), TestRock::getEntry(), httpMaybeRemovePublic(), ICPState::isHit(), MimeIcon::load(), clientReplyContext::purgeDoPurge(), UrnState::start(), and urnParseReply().
◆ storeGetPublicByRequest()
StoreEntry * storeGetPublicByRequest | ( | HttpRequest * | req, |
const KeyScope | keyScope | ||
) |
Definition at line 502 of file store.cc.
References HttpRequest::method, Http::METHOD_GET, Http::METHOD_HEAD, and storeGetPublicByRequestMethod().
Referenced by htcpSpecifier::checkHit(), findPreviouslyCachedEntry(), htcpClrStore(), clientReplyContext::identifyStoreObject(), peerDigestRequest(), and clientReplyContext::processExpired().
◆ storeGetPublicByRequestMethod()
StoreEntry * storeGetPublicByRequestMethod | ( | HttpRequest * | req, |
const HttpRequestMethod & | method, | ||
const KeyScope | keyScope | ||
) |
Definition at line 496 of file store.cc.
References Store::Controller::find(), Store::Root(), and storeKeyPublicByRequestMethod().
Referenced by httpMaybeRemovePublic(), clientReplyContext::purgeDoPurge(), and storeGetPublicByRequest().
◆ storeInit()
void storeInit | ( | void | ) |
Definition at line 1243 of file store.cc.
References Config, createRemovalPolicy(), eventAdd(), Store::Controller::init(), mem_policy, SquidConfig::memPolicy, Store::Root(), storeDigestInit(), storeLateRelease, storeLogOpen(), storeRebuildStart(), and storeRegisterWithCacheManager().
Referenced by mainInitialize().
◆ storeLateRelease()
|
static |
Definition at line 1159 of file store.cc.
References debugs, eventAdd(), Important, LateReleaseStack, Store::Controller::store_dirs_rebuilding, storeLateRelease, and StoreEntry::unlock().
◆ storeRegisterWithCacheManager()
|
static |
Definition at line 1233 of file store.cc.
References Mgr::StoreIoAction::Create(), Mgr::RegisterAction(), StatQueues(), Store::Stats(), and storeCheckCachableStats.
Referenced by storeInit().
◆ storeReplAdd()
void storeReplAdd | ( | const char * | type, |
REMOVALPOLICYCREATE * | create | ||
) |
Definition at line 1631 of file store.cc.
References _storerepl_entry::create, DBG_IMPORTANT, debugs, storerepl_list, _storerepl_entry::typestr, and xrealloc().
Referenced by TestUfs::commonInit().
◆ storeTooManyDiskFilesOpen()
int storeTooManyDiskFilesOpen | ( | void | ) |
Definition at line 875 of file store.cc.
References Config, SquidConfig::max_open_disk_fds, and store_open_disk_fd.
Referenced by StoreEntry::checkCachable(), store_client::startSwapin(), and StoreEntry::swapOut().
Variable Documentation
◆ LateReleaseStack
|
static |
Definition at line 121 of file store.cc.
Referenced by StoreEntry::release(), and storeLateRelease().
◆ memStatusStr
const char* memStatusStr[] |
◆ pingStatusStr
const char* pingStatusStr[] |
◆ store_check_cachable_hist
struct _store_check_cachable_hist store_check_cachable_hist |
Referenced by StoreEntry::checkCachable(), and storeCheckCachableStats().
◆ storeCheckCachableStats
|
static |
Definition at line 115 of file store.cc.
Referenced by storeRegisterWithCacheManager().
◆ storeLateRelease
|
static |
Definition at line 116 of file store.cc.
Referenced by storeInit(), and storeLateRelease().
◆ storerepl_list
|
static |
Definition at line 109 of file store.cc.
Referenced by createRemovalPolicy(), and storeReplAdd().
◆ storeStatusStr
const char* storeStatusStr[] |
◆ swapStatusStr
const char* swapStatusStr[] |
Definition at line 91 of file store.cc.
Referenced by StoreEntry::attachToDisk().