Thread 'Work Unit Download Scheduling'

Message boards : BOINC client : Work Unit Download Scheduling
Message board moderation

To post messages, you must log in.

AuthorMessage
Mg

Send message
Joined: 27 Jan 14
Posts: 6
United States
Message 52600 - Posted: 17 Feb 2014, 5:34:24 UTC

Hey all, I've currently got my 2 laptops set to connect to the network only between 3a and 5a, but they pretty much always wait until 4:30a (exactly, it seems) to request work for the whole day, which for them takes longer than 30 minutes to download (Rosetta)

Is there any way I can tell them to request work earlier in the specified network window so they don't run out of network time? Like preferably at 3a?
ID: 52600 · Report as offensive
ProfileJord
Volunteer tester
Help desk expert
Avatar

Send message
Joined: 29 Aug 05
Posts: 15581
Netherlands
Message 52604 - Posted: 17 Feb 2014, 10:58:55 UTC - in response to Message 52600.  

If BOINC 7.0 or 7.2, BOINC will only request more work when it's going under the minimum work mark of Maintain enough tasks to keep busy for at least X days. It will then fill the cache for the minimum + the amount of ... and up to an additional Y days amount. So if you find that BOINC only does this at 4.30am, perhaps you should try to play with the values there.
ID: 52604 · Report as offensive
Mg

Send message
Joined: 27 Jan 14
Posts: 6
United States
Message 52654 - Posted: 19 Feb 2014, 10:20:34 UTC - in response to Message 52604.  
Last modified: 19 Feb 2014, 10:23:07 UTC

Currently X is 0.9 and Y is 2. Of course the extra work cached is less than Y almost immediately, and the total work on hand is rarely less than X. There are a few ways I could be adjusting the values for X and Y here; should X be even lower and Y higher to compensate?

Also, until I find the boinc-specific setting I'm looking for, I just set up a systemd job (running Arch linux; we shun cron):

/etc/systemd/system/boinc-scheduler-update.service
[Unit]
Description=For Rosetta@Home, forces a scheduler request.

[Service]
Type=oneshot
ExecStart=/usr/bin/boinccmd --passwd [from /var/lib/boinc/gui_auth_rpc.cfg] --project http://boinc.bakerlab.org/rosetta/ update

/etc/systemd/system/boinc-scheduler-update.timer
[Unit]
Description=the timer for daily BOINC project updates (currently pegged to the start of the network availability window at slightly after 3am)

[Timer]
OnCalendar=*-*-* 03:01:00
Unit=boinc-scheduler-update.service

[Install]
WantedBy=basic.target

Then of course in bash:
sudo systemctl enable boinc-scheduler-update.timer
sudo systemctl start boinc-scheduler-update.timer
ID: 52654 · Report as offensive
Mg

Send message
Joined: 27 Jan 14
Posts: 6
United States
Message 52664 - Posted: 19 Feb 2014, 22:23:58 UTC - in response to Message 52604.  

Ageless, I concede that a problem exists between the keyboard and chair here;

Your terms
Maintain enough tasks to keep busy for at least X days

and
the amount of ... and up to an additional Y days

Are not used as such on either WCG or Rosetta@Home, where the terms used are something like:
(1) Connect to network about every … days / Computer is connected to the internet every … days; and
(2) Cache … extra days of work / Maintain enough work for an addition … days

I presume that your x is their (1), and that your y is their (2), but that is unclear to me (and a project-specific question, I realize)
ID: 52664 · Report as offensive
ProfileJord
Volunteer tester
Help desk expert
Avatar

Send message
Joined: 29 Aug 05
Posts: 15581
Netherlands
Message 52667 - Posted: 19 Feb 2014, 23:00:33 UTC - in response to Message 52664.  

I presume that your x is their (1), and that your y is their (2), but that is unclear to me (and a project-specific question, I realize)

Newer BOINC versions (all BOINC 7) have these same options in their local advanced computing preferences. But when the project still uses the old values, you'll have to turn them around. So no, in your case then, my X is 2, and Y is 1.
ID: 52667 · Report as offensive
Mg

Send message
Joined: 27 Jan 14
Posts: 6
United States
Message 52698 - Posted: 21 Feb 2014, 19:17:22 UTC - in response to Message 52667.  
Last modified: 21 Feb 2014, 19:21:58 UTC

Setting
Connect to network about every … days / Computer is connected to the internet every … days
to 0 and setting
Cache … extra days of work / Maintain enough work for an addition … days
to 2 did not produce the desired result (i.e. contrary to my wishes, the client did not send scheduler update request until 4:30a, when there were only 30 minutes remaining in the allotted network window.)

My cron-like systemd script below though works fine (except I changed 3:01a to 4:00a since Rosetta@home was refusing to download until it got some uploads out of the way), and is a functional fix if slightly more jury-rigged than I would like, so I probably won't be conducting the obverse test (reversing 2 and 0 above).

Thanks for your time ageless, I was definitely confused by my project's network connectivity terminology
ID: 52698 · Report as offensive
Mg

Send message
Joined: 27 Jan 14
Posts: 6
United States
Message 52740 - Posted: 24 Feb 2014, 15:02:22 UTC - in response to Message 52698.  

Wouldn't you know, the obverse was just what I was looking for.

That is, (in World Community Grid),
Connect to network about every [2.0] days
Cache [0] extra days of work

And (in Rosetta@Home),
Computer is connected to the Internet about every [2.0] days
Maintain enough work for an additional [0.0] days

Sends scheduler requests at (well, really near) the beginning of the network availability window.
It's exactly the setup I was looking for, and was the one I hadn't yet tried.
Also, this setup renders obsolete the systemd setup mentioned below, which I turned off (disable; stop)
ID: 52740 · Report as offensive

Message boards : BOINC client : Work Unit Download Scheduling

Copyright © 2025 University of California.
Permission is granted to copy, distribute and/or modify this document under the terms of the GNU Free Documentation License, Version 1.2 or any later version published by the Free Software Foundation.