Commit 8f0228b
perf(pubsub): trim per-message allocations in publish hot path (#8374)
Three per-message allocations that compound on a typical batch:
1. `bindStart` called `String(messageCount)` and
`String(Math.floor(batchSpan._startTime))` on every iteration
despite both being loop-invariant — on a 100-message batch
that's 200 redundant string allocations per send. Hoist both
above the loop.
2. The per-message `Object.assign({...})` over seven attribute
fields rebuilt a fresh object every iteration. Assign per-key so
V8 keeps `msg.attributes` on its existing hidden class.
3. The parent-from-message-0 span-link extraction
(`messages.slice(1).map(...).filter(Boolean)`) allocated three
intermediate arrays per call. Replace with a single `for` loop.1 parent 0c71281 commit 8f0228b
1 file changed
Lines changed: 27 additions & 18 deletions
Lines changed: 27 additions & 18 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
54 | 54 | | |
55 | 55 | | |
56 | 56 | | |
57 | | - | |
58 | | - | |
59 | | - | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
60 | 64 | | |
61 | 65 | | |
62 | 66 | | |
| |||
107 | 111 | | |
108 | 112 | | |
109 | 113 | | |
110 | | - | |
| 114 | + | |
| 115 | + | |
| 116 | + | |
| 117 | + | |
| 118 | + | |
111 | 119 | | |
112 | | - | |
| 120 | + | |
113 | 121 | | |
114 | 122 | | |
115 | | - | |
| 123 | + | |
116 | 124 | | |
117 | 125 | | |
118 | | - | |
119 | | - | |
120 | | - | |
121 | | - | |
122 | | - | |
123 | | - | |
124 | | - | |
125 | | - | |
126 | | - | |
| 126 | + | |
| 127 | + | |
| 128 | + | |
| 129 | + | |
| 130 | + | |
| 131 | + | |
| 132 | + | |
| 133 | + | |
| 134 | + | |
| 135 | + | |
127 | 136 | | |
128 | 137 | | |
129 | | - | |
| 138 | + | |
130 | 139 | | |
131 | 140 | | |
132 | | - | |
| 141 | + | |
133 | 142 | | |
134 | 143 | | |
135 | 144 | | |
136 | 145 | | |
137 | 146 | | |
138 | | - | |
| 147 | + | |
139 | 148 | | |
140 | 149 | | |
141 | 150 | | |
| |||
0 commit comments