forked from uwiger/jobs
-
Notifications
You must be signed in to change notification settings - Fork 3
Counter based regulation
mniec edited this page Apr 16, 2013
·
2 revisions
Jobs' counter-based regulation limits the number of jobs that can run simultaneously.
Here is an example using a shell dialogue:
- First, load the jobs application, so that we can change its environment.
- Start jobs. It will read the environment and configure our queue.
- Spawn a number of jobs, verify that they execute only one at a time.
Eshell V5.9 (abort with ^G)
1> application:load(jobs).
ok
2> application:set_env(jobs, queues, [{q, [{regulators, [{counter,[{limit,1}]}] }]}]).
ok
3> application:start(jobs).
ok
4> [spawn_link(fun() -> jobs:run(q, fun() -> io:fwrite("~p running~n", [self()]), timer:sleep(1000), io:fwrite("~p done.~n", [self()]) end) end) || _ <- lists:seq(1,5)].
[<0.58.0>,<0.59.0>,<0.60.0>,<0.61.0>,<0.62.0>]
<0.62.0> running
<0.62.0> done.
<0.58.0> running
<0.58.0> done.
<0.59.0> running
<0.59.0> done.
<0.60.0> running
<0.60.0> done.
<0.61.0> running
<0.61.0> done.
For better readability, the configuration is pretty-printed here:
application:set_env(jobs, queues,
[{q, [{regulators,
[{counter, [
{limit,1}
]
}]
}]
}]).
And the command to spawn jobs:
[spawn_link(fun() ->
jobs:run(
q, fun() ->
io:fwrite("~p running~n", [self()]),
timer:sleep(1000),
io:fwrite("~p done.~n", [self()])
end)
end) || _ <- lists:seq(1,5)].
It is perfectly possible to combine counter-based and rate-based regulation in the same queue. Jobs will calculate the number of jobs to dispatch using all available regulators, and pick the most conservative number.