Message boards :
CMS Application :
Multithreading/Multicore?
Message board moderation
Author | Message |
---|---|
Send message Joined: 27 Jun 06 Posts: 8 Credit: 2,592,725 RAC: 2,536 |
Why is CMS not threaded/using multiple cores like ATLAS does? Running on a single core sometimes takes a whole day to complete a single CMS Wu. Can it be made to run on multiple cores? |
Send message Joined: 2 May 07 Posts: 2244 Credit: 173,902,375 RAC: 456 |
60.70 (vbox64_mt_mcore_cms) This is the Testversion in -dev Windows and Linux. |
Send message Joined: 15 Jun 08 Posts: 2541 Credit: 254,608,838 RAC: 34,609 |
Multithreading/Multicore is not necessarily more efficient. The CMS scientific app runs in singlecore mode by design and each subtask typically takes 3-4 h. CMS VMs usually run a couple of them consecutively until the target time of 12 h is reached. This is a weak target meaning sometimes a VM runs only 1 (or 2 ...) subtask(s) for whatever reason and sometimes the runtime extends to more than 12 h to allow a subtask in progress to finish. The VMs sent out by -dev can be multicore VMs. In the past there were tests to run n singlecore CMS subtasks concurrently on the same n-core VM (each subtask in a separate slot). This has been stopped long ago and since then the backend queues are configured to send only 1 subtask to a VM regardless of the VM's core count. Hence, even if it is possible to run multicore CMS VMs on -dev n-1 (with n>1) CPUs will just sit there doing nothing (except a small fraction of a core used for the OS and peripheral helper processes). |
Send message Joined: 27 Jun 06 Posts: 8 Credit: 2,592,725 RAC: 2,536 |
@computezrmle I have no idea what you just said. English? @maeax Good to know! I don't run test apps, though. Will wait. |
Send message Joined: 15 Jun 08 Posts: 2541 Credit: 254,608,838 RAC: 34,609 |
I have no idea what you just said. OK, in short. It is not planned to publish a multithreading/multicore CMS application. |
Send message Joined: 7 Nov 23 Posts: 2 Credit: 37,618 RAC: 0 |
What is the reason for filling one task with multiple subtasks? I would very much prefer the work units to be shorter. The reason I'm asking, is because the CMS tasks are problematic because they cannot be suspended. If you resume them after suspending, they will almost always fail, either with a generic compute error, or with a small pop-up window saying 'breakpoint reached'. Do you know why this is so difficult for CMS tasks? I had been wondering why sometimes I would still get credit for these tasks, but now I understand that some of the subtasks may still have been succesfully completed earlier. The result of this, is that I will only allow LHC@home to get new work if I know I can leave my computer running for 12 hours or more, which is not often. If not, I cannot reliably complete the tasks, because I cannot shut down and resume. I have tried, by suspending BOINC first, then checking VirtualBox to see whether the VMs have paused and saved correctly, but still I guess >95% of work units fail when you resume after suspend. I guess you could consider this post as a friendly request to either make the work units shorter, or to make them properly handle pausing and resuming. |
Send message Joined: 15 Jun 08 Posts: 2541 Credit: 254,608,838 RAC: 34,609 |
What is the reason for filling one task with multiple subtasks? Mainly to update the CVMFS cache only once at the beginning of the task and use the data for a couple of subtasks. In addition each task runs some benchmarks at the beginning to get an idea how many subtasks could be run within the 12 h target. That target plus a 6 h grace period results in the 18 h max task runtime. At the end of the 18 h runtime a task will be cancelled forcefully which avoids tasks that got stuck will run forever. At the end this is already a compromise between the scientific apps being developed to run 24/7 in a datacenter environment and the BOINC environment. I would very much prefer the work units to be shorter. The scientists prefer subtasks with even more events which would lead to longer runtimes. ATM average core time per subtask is 2-4 h. CMS tasks are problematic because they cannot be suspended CMS allows tasks to be suspended up to 2 h. After this period the subtask is marked as lost by the backend systems. If you resume them after suspending, they will almost always fail, either with a generic compute error, or with a small pop-up window saying 'breakpoint reached'. Very unusual. Since BOINC suspends the whole VM it should continue from the same point. You may check if "leave non GPU apps in RAM if suspended" is enabled. In addition the task's runtime should already be longer than the global checkpoint interval set for your BOINC client. Also a good idea: make your computers visible and post links to example tasks that are marked as failed. but still I guess >95% of work units fail when you resume after suspend You don't mean 95 % of all tasks sent out by the server, do you? |
Send message Joined: 7 Nov 23 Posts: 2 Credit: 37,618 RAC: 0 |
Thank you for your reply. It is useful to know a task can be suspended for up to two hours but not any longer. My 95% (guestimate) fail rate with suspended tasks is indeed with tasks I have suspended for a whole night for example. I did not mean that 95% of tasks in general fail, only that when they're suspended for a while, 95% of those will fail after resuming. It is now clear why that happens. I have enabled the 'leave in RAM' option now; thanks for the advice. Checkpoint interval was already set to 60 seconds which should be good I think. |
Send message Joined: 27 Jun 06 Posts: 8 Credit: 2,592,725 RAC: 2,536 |
I have no problem with suspending CMS units. My desktop is usually up 24/7 and I only occasionally reboot due to some update that requires it (eg, systemd) or a new kernel. CMS happily resumes after the system is back up. I've never had a task error out because it was suspended and then resumed. This is on 2 different Linux systems. |
Send message Joined: 18 Dec 15 Posts: 1821 Credit: 118,941,109 RAC: 22,079 |
I have no problem with suspending CMS units. My desktop is usually up 24/7 and I only occasionally reboot due to some update that requires itI assume by doing this, your tasks are being suspended only for short time. As computezrmle wrote above, suspending up to2 hours should not be a problem anyway. |
©2024 CERN