Skip to content

BasicConcepts

David Anderson edited this page Sep 19, 2024 · 3 revisions

Basic concepts

Project

A project is an entity that does distributed computing using BOINC. Projects are independent; each one has its own applications, database, web site, and servers, and is not affected by the status of other projects. Each project is identified by a master URL, the URL of its web site. Multiple projects can coexist on a single server computer.

At the implementation level, a project consists of

  • a directory tree, containing files related to the project, and
  • a MySQL database.

A BOINC project involves a number of interrelated entities, described below. Each type of entity has a corresponding database table.

Application

An application includes several programs (for different platforms) and a set of workunits and results. A project can include multiple applications.

Platform

A platform is a compilation target - typically a combination of a CPU architecture and an operating system. BOINC defines a set of standard platforms.

Application versions

An application program may go through a sequence of versions. A particular version, compiled for a particular platform, is called an application version. An application version consists of one or more files.

Workunit

A workunit is a computation to be performed, i.e. a "job". It may include any number of input files. It has various attributes, such as resource requirements and deadline.

A workunit is associated with an application, not with an application version. In other words, you don't specify what platform the job is to be run on.

Result

A result describes an instance of a computation, either unstarted, in progress, or completed. Each result is associated with a workunit. In some cases there may be several instances, or "replicas", of a given workunit.

Account

Each volunteer in a project has an account, identified by an email address and password. An account has an associated amount of credit, a numerical measure of the work done by that volunteer's computers.

Clients and attachment

Volunteers run a program called the BOINC client; this is the only software they manually download.

A given computer running the BOINC client can be attached to accounts on one or more project. Each attachment has a resource share. If a computer is attached to multiple projects, its resources are divided among them in proportion to their resource shares.

BOINC in a nutshell

The overall flow of BOINC:

  • When a BOINC client runs low on work, it issues a scheduler request to one of its attached projects. The request message specifies the client's platform.
  • The project's scheduler (a daemon running on its server) scans the project's database for jobs that can be handled by the client, and returns one or more.
  • The client downloads the files associated with the application versions and workunits, and executes the programs.
  • When the jobs are completed, the client uploads the resulting output files.

This cycle is repeated indefinitely.

Clone this wiki locally