Commit 3ededbb
committed
feat(cluster): Allow multiple worker processes with cluster module
This adds the ability for the API to use multiple worker processes with
Node.js's builtin [`cluster`](https://nodejs.org/api/cluster.html)
module.
Historically, I've been opposed to adding this functionality, preferring
that Pelias users manage parallelism on their own such as with
Kubernetes or something else.
But there are enough use cases where that sort of orchestration isn't
worth the complexity, and you want more than one CPU's worth of API
requests.
This implementation is essentially lifted from the one in Placeholder,
with mostly cosmetic changes only.
The biggest difference is the default. For backwards compatibility,
without specifing the new `CPUS` environment variable, the API will
_not_ use the cluster module and operate as a single process just like
before.
_With_ the `CPUS` variable set to a number, that many worker processes
will be launched, up to the number of CPUs detected on the machine.1 parent 1f921d5 commit 3ededbb
2 files changed
Lines changed: 73 additions & 9 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
220 | 220 | | |
221 | 221 | | |
222 | 222 | | |
| 223 | + | |
223 | 224 | | |
224 | 225 | | |
225 | 226 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
1 | 4 | | |
2 | 5 | | |
3 | 6 | | |
4 | 7 | | |
5 | 8 | | |
6 | 9 | | |
7 | 10 | | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
8 | 17 | | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
9 | 41 | | |
10 | | - | |
11 | | - | |
12 | | - | |
13 | | - | |
14 | | - | |
15 | | - | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
16 | 45 | | |
17 | | - | |
18 | 46 | | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
19 | 55 | | |
20 | | - | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
21 | 65 | | |
22 | | - | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
| 82 | + | |
| 83 | + | |
| 84 | + | |
| 85 | + | |
23 | 86 | | |
24 | 87 | | |
25 | 88 | | |
| |||
0 commit comments