mirror of https://github.com/BOINC/boinc.git
99 lines
3.3 KiB
HTML
99 lines
3.3 KiB
HTML
<title>Overview of BOINC</title>
|
|
<body bgcolor=ffffff>
|
|
<h2>Overview of BOINC</h2>
|
|
<p>
|
|
BOINC is a software platform for distributed computing
|
|
using volunteer computer resources.
|
|
The features of BOINC fall into several areas:
|
|
|
|
<h3>Resource sharing among independent projects</h3>
|
|
<p>
|
|
Many different projects can use BOINC.
|
|
Projects are independent; they operate their own servers and databases.
|
|
However, projects can share resources in the following sense:
|
|
Participants install a <b>core client</b> program
|
|
which in turn downloads and executes project-specific application programs.
|
|
Participants control which projects they participate in,
|
|
and how their resources are divided among these projects.
|
|
When a project is down or has no work,
|
|
the processing power of its participants is divided among
|
|
the other projects in which the participants are registered.
|
|
<p>
|
|
|
|
<h3>Project features</h3>
|
|
<p>
|
|
BOINC provides features that simplify
|
|
the creation and operation of distributed computing projects.
|
|
<ul>
|
|
<li>
|
|
<b>Flexible application framework</b>
|
|
<br>
|
|
Existing applications in common languages (C, C++, Fortran)
|
|
can run as BOINC applications with little or no modification.
|
|
An application can consist of several files
|
|
(e.g. multiple programs and a coordinating script).
|
|
New versions of applications can be deployed without
|
|
participant involvement.
|
|
<li>
|
|
<b>Security</b>
|
|
<br>
|
|
BOINC protects against several types of attacks.
|
|
For example, it uses digital signatures based on public-key encryption
|
|
to protect against the distribution of viruses.
|
|
<li>
|
|
<b>Multiple servers and fault-tolerance</b>
|
|
<br>
|
|
Projects can have separate scheduling and data servers,
|
|
with multiple servers of each type.
|
|
Clients automatically try alternate servers;
|
|
if all servers are unavailable, they do exponential backoff.
|
|
<li>
|
|
<b>Open source</b>
|
|
<br>
|
|
BOINC is open source; it's distributed under the Mozilla
|
|
Public License version 1.0.
|
|
Application programs need not be open source.
|
|
BOINC can be used for private, commercial, or public distributed
|
|
computing projects.
|
|
Each project must provide and maintain its own server systems;
|
|
these systems can be set up easily using
|
|
open-source components (MySQL, PHP, Apache).
|
|
<li>
|
|
<b>Support for large data</b>
|
|
<br>
|
|
BOINC supports applications that produce or consume large amounts of data,
|
|
or that use large amounts of memory.
|
|
Data distribution and collection can be spread across many servers,
|
|
and participant hosts transfer large data unobtrusively.
|
|
Users can specify limits on disk usage and network bandwidth.
|
|
Work is dispatched only to hosts able to handle it.
|
|
</ul>
|
|
|
|
<h3>Participant features</h3>
|
|
<p>
|
|
BOINC provides the following features to participants:
|
|
<ul>
|
|
<li>
|
|
<b>Multiple participant platforms</b>
|
|
<br>
|
|
The BOINC core client is available for most common platforms (Mac OS X,
|
|
Windows, Linux and other Unix systems).
|
|
The client can use multiple CPUs.
|
|
|
|
<li>
|
|
<b>Web-based administrative interfaces</b>
|
|
<br>
|
|
BOINC provides web-based interfaces for
|
|
account creation, preference editing, and participant status display.
|
|
A participant's preferences are automatically propagated to all their hosts,
|
|
making it easy to manage large numbers of hosts.
|
|
|
|
<li>
|
|
<b>Configurable host work caching</b>
|
|
<br>
|
|
The core client downloads enough work to keep its host
|
|
busy for a user-specifiable amount of time.
|
|
This allows the host to continue to function during project downtimes,
|
|
and decreases the frequency of connections.
|
|
</ul>
|