Commit 9846b8e
authored
Introduce single prefix byte TSID layout (elastic#143955)
The current TSID layout:
```
byte 0 = hash(dimension_names)
bytes 1–4 = hash(value_0) … hash(value_3)
bytes 5–20 = 128-bit hash (uniqueness)
```
The first 5 bytes are derived from dimension names and a subset of
values. Since these are often static for a given metric, partitioning by
prefix typically yields only a single partition.
This change introduces a 16-byte TSID layout with a single prefix byte
to better partition time-series of a single metric:
```
byte 0 = hash(metric_name) for OTel,
hash(labels.__name__) for Prometheus,
hash(all dimension names and values) for generic TSDB
bytes 1–15 = 15-byte hash (uniqueness + within-metric ordering)
---
Total: 16 bytes (2 longs)
```
The new layout groups time-series by metric, enabling partitioned rate
aggregations across at least 256 partitions.1 parent 26e62f9 commit 9846b8e
File tree
12 files changed
+302
-74
lines changed- server/src
- main/java/org/elasticsearch
- cluster/routing
- index
- test/java/org/elasticsearch
- cluster/routing
- index
- codec/tsdb
- engine
- x-pack/plugin/otel-data/src
- main/java/org/elasticsearch/xpack/oteldata/otlp
- docbuilder
- test/java/org/elasticsearch/xpack/oteldata/otlp
- docbuilder
12 files changed
+302
-74
lines changedLines changed: 1 addition & 1 deletion
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
581 | 581 | | |
582 | 582 | | |
583 | 583 | | |
584 | | - | |
| 584 | + | |
585 | 585 | | |
586 | 586 | | |
587 | 587 | | |
| |||
Lines changed: 73 additions & 6 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
13 | 13 | | |
14 | 14 | | |
15 | 15 | | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
16 | 19 | | |
17 | 20 | | |
18 | 21 | | |
| |||
31 | 34 | | |
32 | 35 | | |
33 | 36 | | |
| 37 | + | |
| 38 | + | |
34 | 39 | | |
35 | 40 | | |
36 | 41 | | |
37 | 42 | | |
38 | 43 | | |
39 | 44 | | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
40 | 48 | | |
41 | 49 | | |
42 | 50 | | |
| |||
215 | 223 | | |
216 | 224 | | |
217 | 225 | | |
| 226 | + | |
| 227 | + | |
| 228 | + | |
| 229 | + | |
| 230 | + | |
| 231 | + | |
| 232 | + | |
| 233 | + | |
| 234 | + | |
| 235 | + | |
| 236 | + | |
| 237 | + | |
218 | 238 | | |
219 | 239 | | |
220 | 240 | | |
| |||
233 | 253 | | |
234 | 254 | | |
235 | 255 | | |
236 | | - | |
237 | | - | |
238 | | - | |
| 256 | + | |
239 | 257 | | |
240 | | - | |
| 258 | + | |
241 | 259 | | |
| 260 | + | |
| 261 | + | |
242 | 262 | | |
243 | 263 | | |
244 | 264 | | |
245 | 265 | | |
246 | | - | |
247 | | - | |
248 | 266 | | |
249 | 267 | | |
250 | 268 | | |
| |||
280 | 298 | | |
281 | 299 | | |
282 | 300 | | |
| 301 | + | |
| 302 | + | |
| 303 | + | |
| 304 | + | |
| 305 | + | |
| 306 | + | |
| 307 | + | |
| 308 | + | |
| 309 | + | |
| 310 | + | |
| 311 | + | |
| 312 | + | |
| 313 | + | |
| 314 | + | |
| 315 | + | |
| 316 | + | |
| 317 | + | |
| 318 | + | |
| 319 | + | |
| 320 | + | |
| 321 | + | |
| 322 | + | |
| 323 | + | |
| 324 | + | |
| 325 | + | |
| 326 | + | |
| 327 | + | |
| 328 | + | |
| 329 | + | |
| 330 | + | |
| 331 | + | |
| 332 | + | |
| 333 | + | |
| 334 | + | |
| 335 | + | |
| 336 | + | |
| 337 | + | |
| 338 | + | |
| 339 | + | |
| 340 | + | |
| 341 | + | |
| 342 | + | |
| 343 | + | |
| 344 | + | |
| 345 | + | |
| 346 | + | |
| 347 | + | |
| 348 | + | |
| 349 | + | |
283 | 350 | | |
284 | 351 | | |
285 | 352 | | |
| |||
Lines changed: 1 addition & 1 deletion
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
238 | 238 | | |
239 | 239 | | |
240 | 240 | | |
241 | | - | |
| 241 | + | |
242 | 242 | | |
243 | 243 | | |
244 | 244 | | |
| |||
Lines changed: 31 additions & 4 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
28 | 28 | | |
29 | 29 | | |
30 | 30 | | |
| 31 | + | |
31 | 32 | | |
32 | 33 | | |
33 | 34 | | |
| |||
686 | 687 | | |
687 | 688 | | |
688 | 689 | | |
689 | | - | |
| 690 | + | |
| 691 | + | |
| 692 | + | |
| 693 | + | |
690 | 694 | | |
691 | 695 | | |
692 | 696 | | |
693 | 697 | | |
| 698 | + | |
694 | 699 | | |
695 | 700 | | |
696 | 701 | | |
| |||
712 | 717 | | |
713 | 718 | | |
714 | 719 | | |
| 720 | + | |
| 721 | + | |
| 722 | + | |
| 723 | + | |
| 724 | + | |
| 725 | + | |
| 726 | + | |
| 727 | + | |
| 728 | + | |
| 729 | + | |
| 730 | + | |
| 731 | + | |
| 732 | + | |
| 733 | + | |
| 734 | + | |
| 735 | + | |
| 736 | + | |
| 737 | + | |
| 738 | + | |
| 739 | + | |
| 740 | + | |
| 741 | + | |
715 | 742 | | |
716 | 743 | | |
717 | 744 | | |
| |||
1236 | 1263 | | |
1237 | 1264 | | |
1238 | 1265 | | |
1239 | | - | |
| 1266 | + | |
1240 | 1267 | | |
1241 | 1268 | | |
1242 | 1269 | | |
| |||
1252 | 1279 | | |
1253 | 1280 | | |
1254 | 1281 | | |
1255 | | - | |
| 1282 | + | |
1256 | 1283 | | |
1257 | 1284 | | |
1258 | 1285 | | |
| |||
1271 | 1298 | | |
1272 | 1299 | | |
1273 | 1300 | | |
1274 | | - | |
| 1301 | + | |
1275 | 1302 | | |
1276 | 1303 | | |
0 commit comments