mirror of https://github.com/BOINC/boinc.git
108 lines
3.5 KiB
PHP
108 lines
3.5 KiB
PHP
<?php
|
|
require_once("docutil.php");
|
|
page_head("Storage");
|
|
echo "
|
|
<h3>Files and data servers</h3>
|
|
<p>
|
|
The BOINC storage model is based on <b>files</b>.
|
|
Examples of files:
|
|
<ul>
|
|
<li> The inputs and/or outputs of computation;
|
|
<li> Components of application: executables, libraries, etc.
|
|
<li> Data for its own sake,
|
|
e.g. to implement a distributed storage system.
|
|
</ul>
|
|
<p>
|
|
The BOINC core client transfers files to and from project-operated
|
|
<b>data servers</b> using HTTP.
|
|
<p>
|
|
Once a file is created (on a data server or a participant host) it
|
|
is <b>immutable</b>.
|
|
This means that all replicas of that file are assumed (and required) to be identical.
|
|
|
|
<h3>File properties</h3>
|
|
Files have various <b>properties</b>, including:
|
|
<ul>
|
|
<li> <b>Sticky</b>: don't delete file on client (see below).
|
|
<li> <b>Report on RPC</b>: include a description of this file
|
|
in scheduler requests.
|
|
<li> <b>Maximum size</b>: if an output file exceeds its maximum size,
|
|
the computation is aborted.
|
|
</ul>
|
|
File properties are specified in XML.
|
|
For example, the properties of input files are described in
|
|
the <a href=tools_work.php>workunit template</a>,
|
|
and XML document describing the task.
|
|
The XML format is described <a href=xml.php>here</a>.
|
|
|
|
<a name=file_ref></a>
|
|
<h3>File management</h3>
|
|
<p>
|
|
BOINC's default behavior is to delete files
|
|
when they aren't needed any more.
|
|
Specifically:
|
|
<ul>
|
|
<li> On the client, input files are deleted when no workunit refers to them,
|
|
and output files are deleted when no result refers to them.
|
|
Application-version files are deleted when they are referenced
|
|
only from superceded application versions.
|
|
<li> On the client, the 'sticky' flag overrides the above mechanisms
|
|
and suppresses the deletion of the file.
|
|
The file may deleted by an explicit
|
|
<a href=delete_file.php>server request</a>.
|
|
The file may also be deleted at any time by the core client
|
|
in order to honor limits on disk-space usage.
|
|
<li> On the server, the <a href=file_deleter.php>file deleter daemon</a>
|
|
deletes input and output files that are no longer needed.
|
|
This can be suppressed using the 'no_delete' flag,
|
|
or using command-line options to the file deleter.
|
|
</ul>
|
|
|
|
<a name=compression></a></a>
|
|
<h3>File compression</h3>
|
|
|
|
<p>
|
|
Starting with version 5.4, the BOINC client
|
|
is able to handle HTTP Content-Encoding types 'deflate' (zlib algorithm)
|
|
and 'gzip' (gzip algorithm).
|
|
The client decompresses these files 'on the fly' and
|
|
stores them on disk in uncompressed form.
|
|
<p>
|
|
Projects can set this encoding in two ways:
|
|
|
|
<ul>
|
|
<li>
|
|
Use the Apache 2.0 mod_deflate module to automatically
|
|
compress files on the fly.
|
|
This method will work with all BOINC clients,
|
|
but it will do compression only for 5.4+ clients.
|
|
|
|
<li>
|
|
Compress their workunits when they create them and use
|
|
a filename suffix such as '.gz'.
|
|
In httpd.conf make sure that the following line is present:
|
|
<pre>
|
|
AddEncoding x-gzip .gz
|
|
</pre>
|
|
This will add the content encoding to the header so that
|
|
the client will decompress the file automatically.
|
|
This method has the advantage of reducing server disk usage
|
|
and server CPU load,
|
|
but it will only work with 5.4+ clients.
|
|
Use the 'min_core_version' field of the app_version table to enforce this.
|
|
|
|
</ul>
|
|
|
|
You can also use these in conjunction because the mod_deflate module
|
|
allows you to exempt certain filetypes from on-the-fly compression.
|
|
|
|
<p>
|
|
Neither of these methods stores files in compressed form on the client.
|
|
For this, you must do compression at the application level.
|
|
The BOINC source distribution includes
|
|
<a href=boinc_zip.txt>a version of the zip library</a>
|
|
designed for use by BOINC applications on any platform.
|
|
";
|
|
page_tail();
|
|
?>
|