A fairly simple solution to speed up your 🍰 Cake tasks using parallel execution
Are you fed up with long running build processes? That's enough! Let's get rid of it. The proposed solution allows you to save lots of time during daily routines. The steps are pretty easy:
- Review your Cake build process and find some independent and long running tasks. For instance, it might be separate build and deployment tasks for backend and frontend parts of the solution. Usually such tasks do not depend on the order of execution, nor on each other. So they can be started separately. Found some? Good. Now let's create a wrappers for them.
- Add new import for your
build.cake
script if it doesn't exist already:
#addin nuget:?package=Cake.Powershell
- Wrap your task(s) with a call to a new Powershell instance:
start powershell {.\\build.ps1 -Target 'Your-Task-Name'; echo 'Parallel task execution finished.'; Read-Host}
- Create a new parallel wrapper:
// Initializes a task to run in parallel
Task("Init-Parallel-Your-Task-Name")
.Does(() => {
// Runs in parallel
StartPowershellScript("start powershell {.\\build.ps1 -Target 'Your-Task-Name'; echo 'Parallel task execution finished.'; Read-Host}");
});
- Replace your sequental task with the parallel one. Change:
// Initializes a task to run in parallel
Task("Build")
.IsDependentOn("Some-Task-Name")
.IsDependentOn("Your-Task-Name")
.IsDependentOn("Last-Task-Name");
To:
// Initializes a task to run in parallel
Task("Build")
.IsDependentOn("Some-Task-Name")
.IsDependentOn("Init-Parallel-Your-Task-Name")
.IsDependentOn("Last-Task-Name");
- Replace any other parallelizable task if needed.
Let's compare sequential and parallelized runs of typical build and deployment process for web application. It consists of the 2 major tasks - backend and frontend.
I'm using a laptop with Intel Core i5-10310U processor which constantly suffers from 15W power limit. The difference may be even more significant, if you have let's say AMD Ryzen 9 5950X with 16 cores/32 threads and no power limit. You are welcome to share your results in discussions.
CPU | Intel Core i5-10310U |
Cores | 4 |
Threads | 8 |
Run | Time, mm:ss.ms |
---|---|
1 | 08:03.1562279 |
2 | 08:07.0316733 |
3 | 08:59.2787849 |
4 | 08:34.0494476 |
5 | 08:37.1383982 |
AVERAGE | 08:28.1300000 |
Run | Time, mm:ss.ms |
---|---|
1 | 05:50.4245998 |
2 | 06:33.5425879 |
3 | 06:24.1244980 |
4 | 06:31.0146683 |
5 | 06:55.8249122 |
AVERAGE | 06:26.9800000 |
Type | Average time, mm:ss.ms | Time saved, mm:ss.ms | Performance gain |
---|---|---|---|
Sequential | 08:28.13 508,13 | 0 | 0 |
Parallel | 06:26.98 386,98 | 02:01.15 | ~ 23% |
As you can see, we managed to save almost a quarter of the time using parallel tasks. Moreover, the worst parallelized result still better than the best sequential with the minute break. It's 18% of time saving!
Measurements have been taken from Intel Extreme Tuning Utility monitoring.
Type | Average active core | Average CPU utilization |
---|---|---|
Sequential | 1 | 28 % |
Parallel | 3 | 45 % |
It is clear that processor resources are used most efficiently with parallel tasks execution.
Explore /examples/
folder to know how it works.
As it was mentioned earlier this solution is applicable to parallelizable and long-running tasks. If the task run time is less than Cake build time it may be better to leave it as is and run in a sequential order.
See the Issues section for the actual information.
-
If you have a multidiplay workstation, the
start
command might open a new powershell window outside of the screen in some cases. -
A failed task does not cancel other tasks running in parallel. In fact, this behavior may be preferable because you don't have to restart all the tasks.
-
Try to determine which parallelizable task is the most long-running. If possible, leave it in a main powershell instance, so other parallel task(s) will finish faster even with Cake script build step.
-
If task dependencies tree is way too complex you can invoke parallel tasks from another parallel tasks. But don't forget about Cake script build process duration. Sometimes it's better to run small tasks sequentially.