From 4d8cc8367ed00b94fa310580fe87c2b6c884b951 Mon Sep 17 00:00:00 2001 From: Bruce Allen Date: Sun, 19 Nov 2006 11:39:01 +0000 Subject: [PATCH] server: file_deleter would turn off -delete_antiques if it encountered a stale .nfs* lockfile which was more than 60 days older than the oldest WU. This should not happen! After these modifications, antique deletion will not be turned off, but a CRITICAL error message will be logged. svn path=/trunk/boinc/; revision=11548 --- checkin_notes | 10 ++++++++++ sched/file_deleter.C | 22 ++++++++++++++++++++-- 2 files changed, 30 insertions(+), 2 deletions(-) diff --git a/checkin_notes b/checkin_notes index 4d9a6ad97a..b6bed146d2 100755 --- a/checkin_notes +++ b/checkin_notes @@ -12680,3 +12680,13 @@ Charlie 17 Nov 2006 sg_DlgMessages.cpp, h sg_ProjectsComponent.cpp ViewMessages.cpp + +Bruce 19 Nov 2006 + - server: file_deleter would turn off -delete_antiques if it encountered a + stale .nfs* lockfile which was more than 60 days older than the oldest WU. + This should not happen! After these modifications, antique deletion + will not be turned off, but a CRITICAL error message will be logged. + + sched/ + file_deleter.C + diff --git a/sched/file_deleter.C b/sched/file_deleter.C index 2fee60e00a..1fa6191d7f 100644 --- a/sched/file_deleter.C +++ b/sched/file_deleter.C @@ -406,7 +406,7 @@ int add_antiques_to_list(int days) { int nchars=strlen(single_line); struct stat statbuf; const char *err=NULL; - FILE_RECORD fr; + FILE_RECORD fr; // We can interrupt this at any point. // pclose() is called when process exits. @@ -427,6 +427,16 @@ int add_antiques_to_list(int days) { if (!err && !(fname_at_end=rindex(single_line+dirlen, '/'))) err="no trailing filename"; if (!err) fname_at_end++; if (!err && !strlen(fname_at_end)) err="trailing filename too short"; + + // skip NFS file system markers of form .nfs* + // + if (!err && !strncmp(fname_at_end, ".nfs", 4)) { + log_messages.printf(SCHED_MSG_LOG::MSG_CRITICAL, + "Ignoring antique (stale) NFS lockfile %s\n", single_line + ); + continue; + } + if (!err && get_file_path(fname_at_end, config.upload_dir, config.uldl_dir_fanout, pathname)) err="get_file_path() failed"; if (!err && strcmp(pathname, single_line)) err="file in wrong hierarchical upload subdirectory"; @@ -499,12 +509,20 @@ bool do_antique_pass(bool& delete_antiques) { // int howmany = find_antique_files(); if (howmany < 0) { + log_messages.printf(SCHED_MSG_LOG::MSG_CRITICAL, + "Problem 1 [%d] in antique file deletion: turning OFF -delete_antiques switch\n", howmany + ); delete_antiques=false; return did_something; } howmany = delete_antique_files(10); - if (howmany < 0) delete_antiques=false; + if (howmany < 0) { + log_messages.printf(SCHED_MSG_LOG::MSG_CRITICAL, + "Problem 2 [%d] in antique file deletion: turning OFF -delete_antiques switch\n", howmany + ); + delete_antiques=false; + } if (howmany > 0) did_something=true; return did_something;