XRootD
Loading...
Searching...
No Matches
XrdPfc.hh
Go to the documentation of this file.
1#ifndef __XRDPFC_CACHE_HH__
2#define __XRDPFC_CACHE_HH__
3//----------------------------------------------------------------------------------
4// Copyright (c) 2014 by Board of Trustees of the Leland Stanford, Jr., University
5// Author: Alja Mrak-Tadel, Matevz Tadel, Brian Bockelman
6//----------------------------------------------------------------------------------
7// XRootD is free software: you can redistribute it and/or modify
8// it under the terms of the GNU Lesser General Public License as published by
9// the Free Software Foundation, either version 3 of the License, or
10// (at your option) any later version.
11//
12// XRootD is distributed in the hope that it will be useful,
13// but WITHOUT ANY emacs WARRANTY; without even the implied warranty of
14// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15// GNU General Public License for more details.
16//
17// You should have received a copy of the GNU Lesser General Public License
18// along with XRootD. If not, see <http://www.gnu.org/licenses/>.
19//----------------------------------------------------------------------------------
20#include <string>
21#include <list>
22#include <map>
23#include <set>
24
25#include "Xrd/XrdScheduler.hh"
26#include "XrdVersion.hh"
28#include "XrdOuc/XrdOucCache.hh"
30
31#include "XrdPfcFile.hh"
32#include "XrdPfcDecision.hh"
33
34class XrdOss;
35class XrdOucStream;
36class XrdSysError;
37class XrdSysTrace;
39
40namespace XrdPfc
41{
42class File;
43class IO;
44class PurgePin;
45class ResourceMonitor;
46
47
48template<class MOO>
50 MOO &mutex;
51 MutexHolder(MOO &m) : mutex(m) { mutex.Lock(); }
52 ~MutexHolder() { mutex.UnLock(); }
53};
54}
55
56
57namespace XrdPfc
58{
59
60//----------------------------------------------------------------------------
62//----------------------------------------------------------------------------
64{
66
67 bool are_file_usage_limits_set() const { return m_fileUsageMax > 0; }
69 bool is_uvkeep_purge_in_effect() const { return m_cs_UVKeep >= 0; }
70 bool is_dir_stat_reporting_on() const { return m_dirStatsStoreDepth >= 0 || ! m_dirStatsDirs.empty() || ! m_dirStatsDirGlobs.empty(); }
71 bool is_purge_plugin_set_up() const { return false; }
72
74
75 bool is_cschk_cache() const { return m_cs_Chk & CSChk_Cache; }
76 bool is_cschk_net() const { return m_cs_Chk & CSChk_Net; }
77 bool is_cschk_any() const { return m_cs_Chk & CSChk_Both; }
78 bool is_cschk_both() const { return (m_cs_Chk & CSChk_Both) == CSChk_Both; }
79
80 bool does_cschk_have_missing_bits(CkSumCheck_e cks_on_file) const { return m_cs_Chk & ~cks_on_file; }
81
82 bool should_uvkeep_purge(time_t delta) const { return m_cs_UVKeep >= 0 && delta > m_cs_UVKeep; }
83
87
88 std::string m_username;
89 std::string m_data_space;
90 std::string m_meta_space;
91
92 long long m_diskTotalSpace;
93 long long m_diskUsageLWM;
94 long long m_diskUsageHWM;
97 long long m_fileUsageMax;
102
103 std::set<std::string> m_dirStatsDirs;
104 std::set<std::string> m_dirStatsDirGlobs;
107
108 long long m_bufferSize;
114
115 long long m_cgi_min_bufferSize = 0;
116 long long m_cgi_max_bufferSize = 0;
121
122 long long m_hdfsbsize;
123 long long m_flushCnt;
124
125 time_t m_cs_UVKeep;
128
131
132 static constexpr long long s_min_bufferSize = 4 * 1024;
133 static constexpr long long s_max_bufferSize = 512 * 1024 * 1024;
134
135 static constexpr int s_max_prefetch_max_blocks = 4096;
136};
137
138//------------------------------------------------------------------------------
139
141{
142 std::string m_diskUsageLWM;
143 std::string m_diskUsageHWM;
146 std::string m_fileUsageMax;
147 std::string m_flushRaw;
148 std::string m_writemodeRaw;
149
151 m_diskUsageLWM("0.90"), m_diskUsageHWM("0.95"),
152 m_flushRaw("")
153 {}
154};
155
156
157//==============================================================================
158// Cache
159//==============================================================================
160
161//----------------------------------------------------------------------------
163//----------------------------------------------------------------------------
164class Cache : public XrdOucCache
165{
166public:
167 //---------------------------------------------------------------------
169 //---------------------------------------------------------------------
170 Cache(XrdSysLogger *logger, XrdOucEnv *env);
171
172 //---------------------------------------------------------------------
174 //---------------------------------------------------------------------
176
177 virtual XrdOucCacheIO *Attach(XrdOucCacheIO *, int Options = 0);
178
179 //---------------------------------------------------------------------
180 // Virtual function of XrdOucCache. Used for redirection to a local
181 // file on a distributed FS.
182 virtual int LocalFilePath(const char *url, char *buff=0, int blen=0,
183 LFP_Reason why=ForAccess, bool forall=false);
184
185 //---------------------------------------------------------------------
186 // Virtual function of XrdOucCache. Used for deferred open.
187 virtual int Prepare(const char *url, int oflags, mode_t mode);
188
189 // virtual function of XrdOucCache.
190 virtual int Stat(const char *url, struct stat &sbuff);
191
192 // virtual function of XrdOucCache.
193 virtual int Unlink(const char *url);
194
195 //---------------------------------------------------------------------
196 // Used by PfcFstcl::Fsctl function.
197 // Test if file is cached taking in onlyifcached configuration parameters.
198 //---------------------------------------------------------------------
199 virtual int ConsiderCached(const char *url);
200
201 bool DecideIfConsideredCached(long long file_size, long long bytes_on_disk);
202 void WriteFileSizeXAttr(int cinfo_fd, long long file_size);
203 long long DetermineFullFileSize(const std::string &cinfo_fname);
204
205 //--------------------------------------------------------------------
211 //--------------------------------------------------------------------
212 bool Decide(XrdOucCacheIO*);
213
214 //------------------------------------------------------------------------
216 //------------------------------------------------------------------------
217 const Configuration& RefConfiguration() const { return m_configuration; }
218
219 //---------------------------------------------------------------------
227 //---------------------------------------------------------------------
228 bool Config(const char *config_filename, const char *parameters, XrdOucEnv *env);
229
230 //---------------------------------------------------------------------
232 //---------------------------------------------------------------------
233 static Cache &CreateInstance(XrdSysLogger *logger, XrdOucEnv *env);
234
235 //---------------------------------------------------------------------
237 //---------------------------------------------------------------------
238 static Cache &GetInstance();
239 static const Cache &TheOne();
240 static const Configuration &Conf();
241
242 static ResourceMonitor &ResMon();
243
244 //---------------------------------------------------------------------
246 //---------------------------------------------------------------------
247 static bool VCheck(XrdVersionInfo &urVersion) { return true; }
248
249 //---------------------------------------------------------------------
251 //---------------------------------------------------------------------
252 int UnlinkFile(const std::string& f_name, bool fail_if_open);
253
254 //---------------------------------------------------------------------
256 //---------------------------------------------------------------------
257 void AddWriteTask(Block* b, bool from_read);
258
259 //---------------------------------------------------------------------
262 //---------------------------------------------------------------------
264
265 //---------------------------------------------------------------------
267 //---------------------------------------------------------------------
268 void ProcessWriteTasks();
269
270 long long WritesSinceLastCall();
271
272 char* RequestRAM(long long size);
273 void ReleaseRAM(char* buf, long long size);
274
277
279
280 void Prefetch();
281
282 XrdOss* GetOss() const { return m_oss; }
283
284 bool IsFileActiveOrPurgeProtected(const std::string&) const;
286 PurgePin* GetPurgePin() const { return m_purge_pin; }
287
288 File* GetFile(const std::string&, IO*, long long off = 0, long long filesize = 0);
289
290 void ReleaseFile(File*, IO*);
291
292 void ScheduleFileSync(File* f) { schedule_file_sync(f, false, false); }
293
294 void FileSyncDone(File*, bool high_debug);
295
296 XrdSysError* GetLog() const { return &m_log; }
297 XrdSysTrace* GetTrace() const { return m_trace; }
298
299 ResourceMonitor& RefResMon() { return *m_res_mon; }
300 XrdXrootdGStream* GetGStream() { return m_gstream; }
301
302 void ExecuteCommandUrl(const std::string& command_url);
303
305
306 bool blocksize_str2value(const char *from, const char *str, long long &val, long long min, long long max) const;
307 bool prefetch_str2value(const char *from, const char *str, int &val, int min, int max) const;
308
309 bool is_prefetch_enabled() const { return m_prefetch_enabled; }
310
311private:
312 bool ConfigParameters(std::string, XrdOucStream&, TmpConfiguration &tmpc);
313 bool ConfigXeq(char *, XrdOucStream &);
314 bool xcschk(XrdOucStream &);
315 bool xdlib(XrdOucStream &);
316 bool xplib(XrdOucStream &);
317 bool xtrace(XrdOucStream &);
318 bool test_oss_basics_and_features();
319
320 bool cfg2bytes(const std::string &str, long long &store, long long totalSpace, const char *name) const;
321
322 static Cache *m_instance;
323
324 XrdOucEnv *m_env;
325 mutable XrdSysError m_log;
326 XrdSysTrace *m_trace;
327 const char *m_traceID;
328
329 XrdOss *m_oss;
330
331 XrdXrootdGStream *m_gstream;
332
333 ResourceMonitor *m_res_mon;
334
335 std::vector<Decision*> m_decisionpoints;
336 PurgePin* m_purge_pin;
337
338 Configuration m_configuration;
339
340 XrdSysCondVar m_prefetch_condVar;
341 bool m_prefetch_enabled;
342
343 XrdSysMutex m_RAM_mutex;
344 long long m_RAM_used;
345 long long m_RAM_write_queue;
346 std::list<char*> m_RAM_std_blocks;
347 int m_RAM_std_size;
348
349 bool m_isClient;
350 bool m_dataXattr = false;
351 bool m_metaXattr = false;
352
353 struct WriteQ
354 {
355 WriteQ() : condVar(0), writes_between_purges(0), size(0) {}
356
357 XrdSysCondVar condVar;
358 std::list<Block*> queue;
359 long long writes_between_purges;
360 int size;
361 };
362
363 WriteQ m_writeQ;
364
365 // active map, purge delay set
366 typedef std::map<std::string, File*> ActiveMap_t;
367 typedef ActiveMap_t::iterator ActiveMap_i;
368 typedef std::set<std::string> FNameSet_t;
369
370 ActiveMap_t m_active;
371 FNameSet_t m_purge_delay_set;
372 mutable XrdSysCondVar m_active_cond;
373
374 void inc_ref_cnt(File*, bool lock, bool high_debug);
375 void dec_ref_cnt(File*, bool high_debug);
376
377 void schedule_file_sync(File*, bool ref_cnt_already_set, bool high_debug);
378
379 // prefetching
380 typedef std::vector<File*> PrefetchList;
381 PrefetchList m_prefetchList;
382};
383
384}
385
386#endif
struct stat Stat
Definition XrdCks.cc:49
#define stat(a, b)
Definition XrdPosix.hh:101
XrdOucString File
virtual XrdOucCacheIO * Attach(XrdOucCacheIO *ioP, int opts=0)=0
XrdOucCache(const char *ctype)
Attaches/creates and detaches/deletes cache-io objects for disk based cache.
Definition XrdPfc.hh:165
XrdSysError * GetLog() const
Definition XrdPfc.hh:296
long long DetermineFullFileSize(const std::string &cinfo_fname)
Definition XrdPfc.cc:930
void FileSyncDone(File *, bool high_debug)
Definition XrdPfc.cc:546
File * GetFile(const std::string &, IO *, long long off=0, long long filesize=0)
Definition XrdPfc.cc:393
static const Configuration & Conf()
Definition XrdPfc.cc:134
bool blocksize_str2value(const char *from, const char *str, long long &val, long long min, long long max) const
virtual int LocalFilePath(const char *url, char *buff=0, int blen=0, LFP_Reason why=ForAccess, bool forall=false)
Definition XrdPfc.cc:798
const Configuration & RefConfiguration() const
Reference XrdPfc configuration.
Definition XrdPfc.hh:217
static ResourceMonitor & ResMon()
Definition XrdPfc.cc:135
bool IsFileActiveOrPurgeProtected(const std::string &) const
Definition XrdPfc.cc:681
void ClearPurgeProtectedSet()
Definition XrdPfc.cc:689
void ReleaseRAM(char *buf, long long size)
Definition XrdPfc.cc:375
virtual int ConsiderCached(const char *url)
Definition XrdPfc.cc:1004
static Cache & GetInstance()
Singleton access.
Definition XrdPfc.cc:132
bool Config(const char *config_filename, const char *parameters, XrdOucEnv *env)
Parse configuration file.
void DeRegisterPrefetchFile(File *)
Definition XrdPfc.cc:715
void ExecuteCommandUrl(const std::string &command_url)
void RegisterPrefetchFile(File *)
Definition XrdPfc.cc:699
void WriteFileSizeXAttr(int cinfo_fd, long long file_size)
Definition XrdPfc.cc:915
void Prefetch()
Definition XrdPfc.cc:756
void ReleaseFile(File *, IO *)
Definition XrdPfc.cc:475
void AddWriteTask(Block *b, bool from_read)
Add downloaded block in write queue.
Definition XrdPfc.cc:225
XrdSysTrace * GetTrace() const
Definition XrdPfc.hh:297
Cache(XrdSysLogger *logger, XrdOucEnv *env)
Constructor.
Definition XrdPfc.cc:158
XrdXrootdGStream * GetGStream()
Definition XrdPfc.hh:300
bool Decide(XrdOucCacheIO *)
Makes decision if the original XrdOucCacheIO should be cached.
Definition XrdPfc.cc:137
int UnlinkFile(const std::string &f_name, bool fail_if_open)
Remove cinfo and data files from cache.
Definition XrdPfc.cc:1196
static XrdScheduler * schedP
Definition XrdPfc.hh:304
ResourceMonitor & RefResMon()
Definition XrdPfc.hh:299
File * GetNextFileToPrefetch()
Definition XrdPfc.cc:737
long long WritesSinceLastCall()
Definition XrdPfc.cc:324
void ProcessWriteTasks()
Separate task which writes blocks from ram to disk.
Definition XrdPfc.cc:277
virtual int Unlink(const char *url)
Definition XrdPfc.cc:1186
void RemoveWriteQEntriesFor(File *f)
Remove blocks from write queue which belong to given prefetch. This method is used at the time of Fil...
Definition XrdPfc.cc:244
virtual XrdOucCacheIO * Attach(XrdOucCacheIO *, int Options=0)
Definition XrdPfc.cc:179
static const Cache & TheOne()
Definition XrdPfc.cc:133
PurgePin * GetPurgePin() const
Definition XrdPfc.hh:286
bool prefetch_str2value(const char *from, const char *str, int &val, int min, int max) const
XrdOss * GetOss() const
Definition XrdPfc.hh:282
static bool VCheck(XrdVersionInfo &urVersion)
Version check.
Definition XrdPfc.hh:247
char * RequestRAM(long long size)
Definition XrdPfc.cc:335
virtual int Prepare(const char *url, int oflags, mode_t mode)
Definition XrdPfc.cc:1070
bool DecideIfConsideredCached(long long file_size, long long bytes_on_disk)
Definition XrdPfc.cc:971
static Cache & CreateInstance(XrdSysLogger *logger, XrdOucEnv *env)
Singleton creation.
Definition XrdPfc.cc:125
bool is_prefetch_enabled() const
Definition XrdPfc.hh:309
void ScheduleFileSync(File *f)
Definition XrdPfc.hh:292
Base cache-io class that implements some XrdOucCacheIO abstract methods.
Definition XrdPfcIO.hh:16
Base class for reguesting directory space to obtain.
@ CSChk_Cache
Contains parameters configurable from the xrootd config file.
Definition XrdPfc.hh:64
long long m_hdfsbsize
used with m_hdfsmode, default 128MB
Definition XrdPfc.hh:122
long long m_RamAbsAvailable
available from configuration
Definition XrdPfc.hh:109
long long m_flushCnt
nuber of unsynced blcoks on disk before flush is called
Definition XrdPfc.hh:123
long long m_cgi_max_bufferSize
max buffer size allowed in pfc.blocksize
Definition XrdPfc.hh:116
int m_accHistorySize
max number of entries in access history part of cinfo file
Definition XrdPfc.hh:101
int m_cgi_min_prefetch_max_blocks
min prefetch block count allowed in pfc.prefetch
Definition XrdPfc.hh:117
bool does_cschk_have_missing_bits(CkSumCheck_e cks_on_file) const
Definition XrdPfc.hh:80
bool m_cgi_prefetch_allowed
allow cgi setting of prefetch
Definition XrdPfc.hh:120
int m_wqueue_threads
number of threads writing blocks to disk
Definition XrdPfc.hh:112
bool m_write_through
flag indicating write-through mode is enabled
Definition XrdPfc.hh:84
long long m_diskTotalSpace
total disk space on configured partition or oss space
Definition XrdPfc.hh:92
long long m_fileUsageMax
cache purge - files usage maximum
Definition XrdPfc.hh:97
long long m_fileUsageBaseline
cache purge - files usage baseline
Definition XrdPfc.hh:95
int m_dirStatsStoreDepth
maximum depth for statistics write out
Definition XrdPfc.hh:106
bool m_allow_xrdpfc_command
flag for enabling access to /xrdpfc-command/ functionality.
Definition XrdPfc.hh:86
bool is_purge_plugin_set_up() const
Definition XrdPfc.hh:71
long long m_diskUsageHWM
cache purge - disk usage high water mark
Definition XrdPfc.hh:94
bool is_cschk_cache() const
Definition XrdPfc.hh:75
std::set< std::string > m_dirStatsDirGlobs
directory globs for which stat reporting was requested
Definition XrdPfc.hh:104
static constexpr long long s_min_bufferSize
Definition XrdPfc.hh:132
CkSumCheck_e get_cs_Chk() const
Definition XrdPfc.hh:73
static constexpr long long s_max_bufferSize
Definition XrdPfc.hh:133
bool is_uvkeep_purge_in_effect() const
Definition XrdPfc.hh:69
int m_prefetch_max_blocks
default maximum number of blocks to prefetch per file
Definition XrdPfc.hh:113
bool are_file_usage_limits_set() const
Definition XrdPfc.hh:67
bool is_cschk_any() const
Definition XrdPfc.hh:77
bool m_cs_ChkTLS
Allow TLS.
Definition XrdPfc.hh:127
long long m_fileUsageNominal
cache purge - files usage nominal
Definition XrdPfc.hh:96
int m_cs_Chk
Checksum check.
Definition XrdPfc.hh:126
bool should_uvkeep_purge(time_t delta) const
Definition XrdPfc.hh:82
int m_purgeAgeBasedPeriod
peform cold file / uvkeep purge every this many purge cycles
Definition XrdPfc.hh:100
bool m_hdfsmode
flag for enabling block-level operation
Definition XrdPfc.hh:85
int m_purgeColdFilesAge
purge files older than this age
Definition XrdPfc.hh:99
std::string m_data_space
oss space for data files
Definition XrdPfc.hh:89
bool is_cschk_both() const
Definition XrdPfc.hh:78
std::set< std::string > m_dirStatsDirs
directories for which stat reporting was requested
Definition XrdPfc.hh:103
long long m_diskUsageLWM
cache purge - disk usage low water mark
Definition XrdPfc.hh:93
int m_RamKeepStdBlocks
number of standard-sized blocks kept after release
Definition XrdPfc.hh:110
long long m_bufferSize
cache block size, default 128 kB
Definition XrdPfc.hh:108
long long m_cgi_min_bufferSize
min buffer size allowed in pfc.blocksize
Definition XrdPfc.hh:115
int m_dirStatsInterval
time between resource monitor statistics dump in seconds
Definition XrdPfc.hh:105
std::string m_meta_space
oss space for metadata files (cinfo)
Definition XrdPfc.hh:90
int m_wqueue_blocks
maximum number of blocks written per write-queue loop
Definition XrdPfc.hh:111
bool is_age_based_purge_in_effect() const
Definition XrdPfc.hh:68
int m_cgi_max_prefetch_max_blocks
max prefetch block count allowed in pfc.prefetch
Definition XrdPfc.hh:118
std::string m_username
username passed to oss plugin
Definition XrdPfc.hh:88
static constexpr int s_max_prefetch_max_blocks
Definition XrdPfc.hh:135
bool m_cgi_blocksize_allowed
allow cgi setting of blocksize
Definition XrdPfc.hh:119
bool is_cschk_net() const
Definition XrdPfc.hh:76
double m_onlyIfCachedMinFrac
minimum fraction of downloaded file, used by only-if-cached CGI option
Definition XrdPfc.hh:130
time_t m_cs_UVKeep
unverified checksum cache keep
Definition XrdPfc.hh:125
int m_purgeInterval
sleep interval between cache purges
Definition XrdPfc.hh:98
long long m_onlyIfCachedMinSize
minumum size of downloaded file, used by only-if-cached CGI option
Definition XrdPfc.hh:129
bool is_dir_stat_reporting_on() const
Definition XrdPfc.hh:70
MutexHolder(MOO &m)
Definition XrdPfc.hh:51
std::string m_writemodeRaw
Definition XrdPfc.hh:148
std::string m_diskUsageLWM
Definition XrdPfc.hh:142
std::string m_diskUsageHWM
Definition XrdPfc.hh:143
std::string m_fileUsageBaseline
Definition XrdPfc.hh:144
std::string m_fileUsageNominal
Definition XrdPfc.hh:145
std::string m_flushRaw
Definition XrdPfc.hh:147
std::string m_fileUsageMax
Definition XrdPfc.hh:146