boinc/sched/time_stats_log.cpp

91 lines
2.6 KiB
C++
Raw Normal View History

// This file is part of BOINC.
// http://boinc.berkeley.edu
// Copyright (C) 2008 University of California
//
// BOINC is free software; you can redistribute it and/or modify it
// under the terms of the GNU Lesser General Public License
// as published by the Free Software Foundation,
// either version 3 of the License, or (at your option) any later version.
//
// BOINC is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
// See the GNU Lesser General Public License for more details.
//
// You should have received a copy of the GNU Lesser General Public License
// along with BOINC. If not, see <http://www.gnu.org/licenses/>.
2016-06-24 22:42:11 +00:00
// code related to "time stats logs".
// These are summaries of client availability send in scheduler requests.
// The scheduler writes them to a directory hierarchy for later analysis.
#include <sys/types.h>
#include <sys/stat.h>
#include "filesys.h"
#include "parse.h"
#include "sched_msgs.h"
#include "sched_config.h"
#include "sched_types.h"
#include "time_stats_log.h"
static char* stats_buf = 0;
// Got a <time_stats_log> flag in scheduler request.
// Copy the contents to a malloced buffer;
// don't write them to disk yet, since we haven't authenticated the host
//
int handle_time_stats_log(FILE* fin) {
return dup_element_contents(fin, "</time_stats_log>", &stats_buf);
}
// The host has been authenticated, so write the stats.
// Use a directory hierarchy since there may be many hosts
//
void write_time_stats_log() {
char filename[256];
const char *dirname;
int hostid = g_reply->host.id;
int dirnum = hostid % 1000;
dirname = config.project_path("time_stats_log/%d", dirnum);
if (!is_dir(dirname)) {
int retval = boinc_mkdir(dirname);
if (retval) {
log_messages.printf(MSG_CRITICAL,
"Can't make time stats log dir %s: %s\n",
dirname, boincerror(retval)
);
- Added checks for net/*.h, arpa/*.h, netinet/*.h and code to figure out which of those files to include - Modified MAC address check to work on some non-Linux unixes. (mac_address.cpp) - Added suggested change to "already attached to project" checking. (ProjectInfoPage.cpp) - changed includes of standard c header files to their c++ equivalents (i.e. replaced <stdio.h> with <cstdio>) for namespace protection. - replaced "using namespace std;" with more explicit "using std::function" in several files. - Fixed bug in checking whether the os is OS/2 and added conditional OS_OS2 to the build environment. (boinc_platform.m4,configure.ac) - Changed build environment to not use -nostandardlibs unless we are using G++ and static linkage is specified. (configure.ac) - Added makefiles and package building files for solaris CSW package manager. - Fixed bug with attempting to find login name using logname. (configure.ac) - Added ifdef HAVE_* protection around some include files commonly found in sys. - Added support for unified binary for x86_64/i686-pc-solaris. (cs_platforms.cpp) - generate_host_cpid() now uses MAC address on non-linux unix. (hostinfo_network.cpp) - Macro BOINC_SET_COMPILE_FLAGS now doesn't check gcc only flags on non-gcc compilers. (boinc_set_compile_flags.m4) - Library compiles no longer depend upon the library extension or require the library to be prefixed with lib. - More fixes for fcgi builds. - Added declaration of "struct ether_addr" and ether_ntoa(). Have not yet implemented ether_ntoa() for machines that don't have it, or where it is buggy. (unix_util.h) - Added FCGI::perror() which calls FCGI_perror(). (boinc_fcgi.{h,cpp}) - Fixed library Makefiles so that all required headers get installed. svn path=/trunk/boinc/; revision=17388
2009-02-26 00:23:23 +00:00
std::perror("mkdir");
return;
}
}
sprintf(filename, "%s/%d", dirname, hostid);
#ifndef _USING_FCGI_
FILE* f = fopen(filename, "w");
#else
FCGI_FILE *f = FCGI::fopen(filename, "w");
#endif
if (!f) {
log_messages.printf(MSG_CRITICAL,
"Can't create time stats file %s\n", filename
);
return;
}
fputs(stats_buf, f);
fclose(f);
free(stats_buf);
stats_buf = 0;
}
bool have_time_stats_log() {
int hostid = g_reply->host.id;
int dirnum = hostid % 1000;
return is_file(
config.project_path("time_stats_log/%d/%d", dirnum, hostid)
);
}