The Pencil Guy: Hourann's illogical blog

Setting up BOINC on Debian from the command line

BOINC is an awesome piece of software that lets you donate your computer’s processing power to a variety of worthy scientific causes. Unfortunately, if you’re running it on Linux without a graphical interface, the control tool’s documentation is a little lacking.

So here is a miniature howto on getting started with BOINC from the command line. I’m assuming you have a recent version of Debian or Ubuntu and a passing familiarity with how BOINC works (if not, browse the official site).

Step 1: setting up

For starters, you need the BOINC client. If you’ll only be working from the command line, you don’t need the other BOINC packages.

sudo apt-get install boinc-client

This gives you the control utility boinc_cmd and creates the directory /var/lib/boinc-client where your data will be stored.

If you’re running on a 64-bit box, there are two extra steps: first, install the 32-bit version of glibc.

sudo apt-get install ia32-libs

Now edit BOINC’s client config file:

vi /var/lib/boinc-client/client_state.xml

Find the <platform_name> element and change its value to i686-pc-linux-gnu — it should look like this:

<platform_name>i686-pc-linux-gnu</platform_name>

This will tell BOINC to download the 32-bit versions of each project application, rather than asking for 64-bit binaries (which most projects don’t offer).

Step 2a: find your account key

If you’ve already registered a username and password with a BOINC project, you can go to its Web site and hit the “your account” page — you should find a link (such as this one) to have your account key mailed to you.

Step 2b: get a new account key

Alternatively, if you’re starting out with a new project and haven’t registered before, you can use boinc_cmd to register by giving it the create_account option, followed by the project URL, your e-mail address, a password, and your desired username.

boinc_cmd --create_account http://www.malariacontrol.net/ me@example.com hardToGuessPassword myUserName

This command drops you back to the shell having outputted nary a whimper, but if you look in the working directory you’ll find a file called create_account.xml with your account key in the <authenticator>...</authenticator> tags.

less /var/lib/boinc-client/create_account.xml

Step 3: start computing!

Once you’ve signed up for a project, you can attach to it by running boinc_cmd with the --project_attach switch, followed by the project URL and your account key.

boinc_cmd --project_attach http://boinc.bakerlab.org/rosetta a1b2c3d4f5a6b7c8d9e0f

And that’s the hardest part done! Your computer should now be registered with the project and will start downloading numbers to crunch. You can confirm this by looking in the control daemon’s log file, which is also the best place to look if you have trouble:

less /var/lib/boinc-client/stdoutdae.txt

Step 4: what’s happening?

To find out what your system is doing, use the (very verbose) --get_state option.

boinc_cmd --get_state

Step 5: stopping work

Two common tasks (for me at least) are to stop work right now, and to stop after the current unit is finished (i.e. don’t fetch more work). You can do these with the --project option:

boinc_cmd --project http://issofty17.is.noda.tus.ac.jp/ suspend

boinc_cmd --project http://boinc.bio.wzw.tum.de/boincsimap nomorework

The opposites of those commands after the URL are resume and allowmorework respectively. You can also use detach to disconnect your computer from a project completely.

Step 6: for more information …

My recommendations are the official documentation, the unofficial BOINC wiki, the Debian wiki, or any of the various forums. Good luck!

No comments on this post.

Care to leave a comment?