XRootD
XrdFrmPurgMain.cc File Reference
#include <unistd.h>
#include <cctype>
#include <cerrno>
#include <cstdlib>
#include <cstring>
#include <strings.h>
#include <cstdio>
#include <sys/param.h>
#include "XrdFrc/XrdFrcTrace.hh"
#include "XrdFrm/XrdFrmConfig.hh"
#include "XrdFrm/XrdFrmPurge.hh"
#include "XrdNet/XrdNetOpts.hh"
#include "XrdNet/XrdNetSocket.hh"
#include "XrdOuc/XrdOucUtils.hh"
#include "XrdSys/XrdSysError.hh"
#include "XrdSys/XrdSysHeaders.hh"
#include "XrdSys/XrdSysLogger.hh"
#include "XrdSys/XrdSysPthread.hh"
#include "XrdSys/XrdSysTimer.hh"
#include "XrdSys/XrdSysUtils.hh"
+ Include dependency graph for XrdFrmPurgMain.cc:

Go to the source code of this file.

Functions

int main (int argc, char *argv[])
 
int mainConfig ()
 
void * mainServer (void *parg)
 

Variables

XrdOucTrace XrdTrace & Say
 
static const char * XrdFrmOpts = ":bc:dfhk:l:n:O:s:S:Tvz"
 
static const char * XrdFrmUsage
 
XrdSysError XrdLog (0, "")
 

Function Documentation

◆ main()

int main ( int  argc,
char *  argv[] 
)

Definition at line 130 of file XrdFrmPurgMain.cc.

131 {
133  extern int mainConfig();
134 
135 // Turn off sigpipe and host a variety of others before we start any threads
136 //
138 
139 // Set the default stack size here
140 //
141  if (sizeof(long) > 4) XrdSysThread::setStackSize((size_t)1048576);
142  else XrdSysThread::setStackSize((size_t)786432);
143 
144 // Perform configuration
145 //
146  Say.logger(&Logger);
147  XrdLog.logger(&Logger);
148  if (!Config.Configure(argc, argv, &mainConfig)) exit(4);
149 
150 // Display configuration (deferred because mum might have been in effect)
151 //
152  if (!Config.isOTO || Config.Verbose) XrdFrmPurge::Display();
153 
154 // Now simply poke the server every so often
155 //
156  if (Config.isOTO) XrdFrmPurge::Purge();
157  else do {if (Config.StopPurge)
158  {int n = 0;
159  struct stat buf;
160  while(!stat(Config.StopPurge, &buf))
161  {if (!n--)
162  {Say.Emsg("PurgMain", Config.StopPurge,
163  "exists; purging suspended."); n = 12;}
165  }
166  }
168  XrdSysTimer::Snooze(Config.WaitPurge);
169  } while(1);
170 
171 // All done
172 //
173  exit(0);
174 }
XrdOucTrace XrdTrace & Say
XrdSysError XrdLog(0, "")
int mainConfig()
#define stat(a, b)
Definition: XrdPosix.hh:105
static void Purge()
Definition: XrdFrmPurge.cc:586
static void Display()
Definition: XrdFrmPurge.cc:295
XrdSysLogger * logger(XrdSysLogger *lp=0)
Definition: XrdSysError.hh:175
static void setStackSize(size_t stsz, bool force=false)
static void Snooze(int seconds)
Definition: XrdSysTimer.cc:168
static bool SigBlock()
Definition: XrdSysUtils.cc:188
XrdCmsConfig Config
XrdSysLogger Logger
Definition: XrdGlobals.cc:47

References XrdCms::Config, XrdFrmPurge::Display(), XrdSysError::Emsg(), XrdGlobal::Logger, XrdSysError::logger(), mainConfig(), XrdFrmPurge::Purge(), XrdFrc::Say, XrdSysThread::setStackSize(), XrdSysUtils::SigBlock(), XrdSysTimer::Snooze(), stat, and XrdLog.

+ Here is the call graph for this function:

◆ mainConfig()

int mainConfig ( )

Definition at line 180 of file XrdFrmPurgMain.cc.

181 {
182  XrdFrmConfig::Policy *pP = Config.dfltPolicy.Next;
183  XrdFrmConfig::VPInfo *vP = Config.VPList;
184  XrdNetSocket *udpSock;
185  pthread_t tid;
186  int retc, udpFD;
187 
188 // If test is in effect, remove the fix flag
189 //
190  if (Config.Test) Config.Fix = 0;
191 
192 // Go through the policy list and add each policy
193 //
194  while((pP = Config.dfltPolicy.Next))
195  {if (!XrdFrmPurge::Policy(pP->Sname))
197  pP->Hold, pP->Ext);
198  Config.dfltPolicy.Next = pP->Next;
199  delete pP;
200  }
201 
202 // Make sure we have a public policy
203 //
204  if (!XrdFrmPurge::Policy("public"))
205  XrdFrmPurge::Policy("public", Config.dfltPolicy.minFree,
206  Config.dfltPolicy.maxFree,
207  Config.dfltPolicy.Hold,
208  Config.dfltPolicy.Ext);
209 
210 // Now add any missing policies (we need one for every space)
211 //
212  while(vP)
213  {if (!XrdFrmPurge::Policy(vP->Name))
214  XrdFrmPurge::Policy(vP->Name, Config.dfltPolicy.minFree,
215  Config.dfltPolicy.maxFree,
216  Config.dfltPolicy.Hold,
217  Config.dfltPolicy.Ext);
218  vP = vP->Next;
219  }
220 
221 // Enable the appropriate spaces and over-ride config value
222 //
223  if (!XrdFrmPurge::Init(Config.spacList, Config.cmdFree, Config.cmdHold))
224  return 1;
225 
226 // We are done if this is a one-time-only call
227 //
228  if (Config.isOTO) return 0;
229 
230 // Get a UDP socket for the server
231 //
232  if (!(udpSock = XrdNetSocket::Create(&Say, Config.AdminPath,
233  "purg.udp", Config.AdminMode, XRDNET_UDPSOCKET))) return 1;
234  else {udpFD = udpSock->Detach(); delete udpSock;}
235 
236 // Start the Server thread
237 //
238  if ((retc = XrdSysThread::Run(&tid, mainServer, (void *)&udpFD,
239  XRDSYSTHREAD_BIND, "Server")))
240  {Say.Emsg("main", retc, "create server thread"); return 1;}
241 
242 // All done
243 //
244  return 0;
245 }
void * mainServer(void *parg)
#define XRDNET_UDPSOCKET
Definition: XrdNetOpts.hh:79
#define XRDSYSTHREAD_BIND
static int Init(XrdOucTList *sP=0, long long minV=-1, int hVal=-1)
Definition: XrdFrmPurge.cc:409
static XrdFrmPurge * Policy(const char *sname)
Definition: XrdFrmPurge.hh:52
static XrdNetSocket * Create(XrdSysError *Say, const char *path, const char *fn, mode_t mode, int isudp=0)
static int Run(pthread_t *, void *(*proc)(void *), void *arg, int opts=0, const char *desc=0)
char Sname[XrdOssSpace::minSNbsz]

References XrdCms::Config, XrdNetSocket::Create(), XrdNetSocket::Detach(), XrdSysError::Emsg(), XrdFrmConfig::Policy::Ext, XrdFrmConfig::Policy::Hold, XrdFrmPurge::Init(), mainServer(), XrdFrmConfig::Policy::maxFree, XrdFrmConfig::Policy::minFree, XrdFrmConfig::VPInfo::Name, XrdFrmConfig::VPInfo::Next, XrdFrmConfig::Policy::Next, XrdFrmPurge::Policy(), XrdSysThread::Run(), XrdFrc::Say, XrdFrmConfig::Policy::Sname, XRDNET_UDPSOCKET, and XRDSYSTHREAD_BIND.

Referenced by main().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ mainServer()

void* mainServer ( void *  parg)

Definition at line 119 of file XrdFrmPurgMain.cc.

120 {
121 // int udpFD = *static_cast<int *>(parg);
122 // XrdFrmPurge::Server(udpFD);
123  return (void *)0;
124 }

Referenced by mainConfig().

+ Here is the caller graph for this function:

Variable Documentation

◆ Say

XrdOucTrace XrdTrace& Say

Definition at line 113 of file XrdFrmPurgMain.cc.

◆ XrdFrmOpts

const char* XrdFrmOpts = ":bc:dfhk:l:n:O:s:S:Tvz"
static

Definition at line 33 of file XrdFrmPurgMain.cc.

◆ XrdFrmUsage

const char* XrdFrmUsage
static
Initial value:
=
" [-b] [-c <cfgfile>] [-d] [-f] [-k {num|sz{k|m|g}|sig] [-l [=]<fn>] [-n name]"
" [-O free[,hold]] [-s pidfile] [-S site] [-T] [-v] [-z] [<spaces>] [<paths>]\n"

Definition at line 34 of file XrdFrmPurgMain.cc.

◆ XrdLog

XrdSysError XrdLog(0, "") ( ,
""   
)

Referenced by main().