// This file is part of BOINC.
// http://boinc.berkeley.edu
// Copyright (C) 2012 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 .
// classes for volunteer data archival (VDA)
//
// Note: these classes are used by both the simulator (ssim.cpp)
// and the VDA server software (vdad.cpp, sched_vda.cpp)
#include
#include
#include "boinc_db.h"
#include "stats.h"
#include "vda_policy.h"
// a host with rpc_time < now-HOST_TIMEOUT is considered dead.
// Make sure you set next_rpc_delay accordingly (e.g., to 86400)
//
#define VDA_HOST_TIMEOUT (86400*4)
extern void show_msg(char*);
extern char* time_str(double);
extern const char* status_str(int status);
struct META_CHUNK;
struct VDA_FILE_AUX : VDA_FILE {
POLICY policy;
META_CHUNK* meta_chunk;
VDA_FILE_AUX(){
meta_chunk = NULL;
}
VDA_FILE_AUX(DB_VDA_FILE f) : VDA_FILE(f){}
// the following stuff is for the simulator
//
double accounting_start_time;
STATS_ITEM disk_usage;
STATS_ITEM upload_rate;
STATS_ITEM download_rate;
STATS_ITEM fault_tolerance;
int pending_init_downloads;
// # of initial downloads pending.
// When this is zero, we start collecting stats for the file
inline bool collecting_stats() {
return (pending_init_downloads == 0);
}
// the following for vdad
//
std::vector available_hosts;
// list of IDs of hosts with no chunks of this file
int init();
int get_state();
int choose_host();
};
#define PRESENT 0
#define RECOVERABLE 1
#define UNRECOVERABLE 2
// base class for chunks and meta-chunks
//
struct DATA_UNIT {
virtual int recovery_plan(){return 0;};
virtual int recovery_action(double){return 0;};
int status;
bool in_recovery_set;
bool data_now_present;
bool data_needed;
double cost;
int min_failures;
// min # of host failures that would make this unrecoverable
char name[64];
char dir[1024];
bool keep_present;
bool need_present;
int delete_file();
};
struct META_CHUNK : DATA_UNIT {
std::vector children;
META_CHUNK* parent;
int n_children_present;
bool have_unrecoverable_children;
VDA_FILE_AUX* dfile;
bool uploading;
CODING coding;
bool bottom_level;
bool need_reconstruct;
bool needed_by_parent;
double child_size;
// used by ssim
META_CHUNK(
VDA_FILE_AUX* d, META_CHUNK* par, double size,
int coding_level, int index
);
// used by vdad
META_CHUNK(VDA_FILE_AUX* d, META_CHUNK* p, int index);
int init(const char* dir, POLICY&, int level);
int get_state(const char* dir, POLICY&, int level);
virtual int recovery_plan();
virtual int recovery_action(double);
void decide_reconstruct();
int reconstruct_and_cleanup();
int expand();
bool some_child_is_unrecoverable() {
for (unsigned int i=0; i hosts;
META_CHUNK* parent;
double size;
bool present_on_server;
bool new_present_on_server;
CHUNK(META_CHUNK* mc, double s, int index);
int start_upload();
void host_failed(VDA_CHUNK_HOST* p);
bool download_in_progress();
void upload_complete();
void download_complete();
int assign();
virtual int recovery_plan();
virtual int recovery_action(double);
bool need_more_replicas() {
return ((int)hosts.size() < parent->dfile->policy.replication);
}
};
// names
//
// chunk name: c1.c2.cn
// (in VDA_CHUNK_HOST)
//
// chunk/file name: c1.c2.cn_filename.ext
//
// physical file name: vda_hostid_c1.c2.cn_filename.ext
inline void physical_file_name(
int hostid, char* chunk_name, char* file_name, char* buf
) {
sprintf(buf, "vda_%d_%s_%s", hostid, chunk_name, file_name);
}
inline void physical_file_name(
int hostid, char* chunk_file_name, char* buf
) {
sprintf(buf, "vda_%d_%s", hostid, chunk_file_name);
}
//
// download WU/result name: vda_download_c1.c2.cn_filename.ext
//
// upload WU/result name: vda_upload_c1.c2.cn_filename.ext