@lodestar/beacon-node 1.34.0-dev.8d743ffafc → 1.34.0-dev.91df6658d5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (43) hide show
  1. package/lib/api/impl/beacon/blocks/index.js +2 -2
  2. package/lib/api/impl/beacon/blocks/index.js.map +1 -1
  3. package/lib/api/impl/debug/index.js +2 -2
  4. package/lib/api/impl/debug/index.js.map +1 -1
  5. package/lib/chain/archiveStore/utils/archiveBlocks.js +19 -20
  6. package/lib/chain/archiveStore/utils/archiveBlocks.js.map +1 -1
  7. package/lib/chain/blocks/writeBlockInputToDb.js +7 -34
  8. package/lib/chain/blocks/writeBlockInputToDb.js.map +1 -1
  9. package/lib/db/beacon.d.ts +3 -3
  10. package/lib/db/beacon.js +3 -3
  11. package/lib/db/beacon.js.map +1 -1
  12. package/lib/db/interface.d.ts +3 -3
  13. package/lib/db/repositories/dataColumnSidecar.d.ts +26 -0
  14. package/lib/db/repositories/dataColumnSidecar.js +39 -0
  15. package/lib/db/repositories/dataColumnSidecar.js.map +1 -0
  16. package/lib/db/repositories/dataColumnSidecarArchive.d.ts +24 -0
  17. package/lib/db/repositories/dataColumnSidecarArchive.js +39 -0
  18. package/lib/db/repositories/dataColumnSidecarArchive.js.map +1 -0
  19. package/lib/db/repositories/index.d.ts +2 -2
  20. package/lib/db/repositories/index.js +2 -2
  21. package/lib/db/repositories/index.js.map +1 -1
  22. package/lib/metrics/metrics/lodestar.d.ts +5 -0
  23. package/lib/metrics/metrics/lodestar.js +14 -0
  24. package/lib/metrics/metrics/lodestar.js.map +1 -1
  25. package/lib/network/gossip/topic.d.ts +16 -16
  26. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRoot.d.ts +4 -0
  27. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRoot.js +4 -4
  28. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRoot.js.map +1 -1
  29. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.d.ts +1 -2
  30. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.js +23 -42
  31. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.js.map +1 -1
  32. package/lib/network/reqresp/handlers/dataColumnSidecarsByRoot.js +7 -21
  33. package/lib/network/reqresp/handlers/dataColumnSidecarsByRoot.js.map +1 -1
  34. package/lib/sync/unknownBlock.d.ts +44 -3
  35. package/lib/sync/unknownBlock.js +275 -193
  36. package/lib/sync/unknownBlock.js.map +1 -1
  37. package/package.json +14 -14
  38. package/lib/db/repositories/dataColumnSidecars.d.ts +0 -47
  39. package/lib/db/repositories/dataColumnSidecars.js +0 -40
  40. package/lib/db/repositories/dataColumnSidecars.js.map +0 -1
  41. package/lib/db/repositories/dataColumnSidecarsArchive.d.ts +0 -15
  42. package/lib/db/repositories/dataColumnSidecarsArchive.js +0 -23
  43. package/lib/db/repositories/dataColumnSidecarsArchive.js.map +0 -1
@@ -1,9 +1,6 @@
1
- import { NUMBER_OF_COLUMNS } from "@lodestar/params";
2
1
  import { RespStatus, ResponseError } from "@lodestar/reqresp";
3
2
  import { computeEpochAtSlot } from "@lodestar/state-transition";
4
- import { ssz } from "@lodestar/types";
5
3
  import { fromHex, toHex } from "@lodestar/utils";
6
- import { COLUMN_SIZE_IN_WRAPPER_INDEX, CUSTODY_COLUMNS_IN_IN_WRAPPER_INDEX, DATA_COLUMN_SIDECARS_IN_WRAPPER_INDEX, NUM_COLUMNS_IN_WRAPPER_INDEX, } from "../../../db/repositories/dataColumnSidecars.js";
7
4
  export async function* onDataColumnSidecarsByRoot(requestBody, chain, db) {
8
5
  // SPEC: minimum_request_epoch = max(finalized_epoch, current_epoch - MIN_EPOCHS_FOR_DATA_COLUMN_SIDECARS_REQUESTS, FULU_FORK_EPOCH)
9
6
  const finalizedEpoch = chain.forkChoice.getFinalizedCheckpoint().epoch;
@@ -21,27 +18,16 @@ export async function* onDataColumnSidecarsByRoot(requestBody, chain, db) {
21
18
  if (!block || computeEpochAtSlot(block.slot) < minimumRequestEpoch) {
22
19
  continue;
23
20
  }
24
- const dataColumnSidecarsBytesWrapped = await db.dataColumnSidecars.getBinary(fromHex(block.blockRoot));
25
- if (!dataColumnSidecarsBytesWrapped) {
26
- // Handle the same to onBeaconBlocksByRange
27
- throw new ResponseError(RespStatus.SERVER_ERROR, `No item for root ${block.blockRoot} slot ${block.slot}`);
21
+ const dataColumns = await db.dataColumnSidecar.getManyBinary(fromHex(block.blockRoot), columns);
22
+ if (!dataColumns) {
23
+ throw new ResponseError(RespStatus.SERVER_ERROR, `No item for root=${block.blockRoot}, slot=${block.slot}`);
28
24
  }
29
- const retrivedColumnsLen = ssz.Uint8.deserialize(dataColumnSidecarsBytesWrapped.slice(NUM_COLUMNS_IN_WRAPPER_INDEX, COLUMN_SIZE_IN_WRAPPER_INDEX));
30
- const retrievedColumnsSizeBytes = dataColumnSidecarsBytesWrapped.slice(COLUMN_SIZE_IN_WRAPPER_INDEX, CUSTODY_COLUMNS_IN_IN_WRAPPER_INDEX);
31
- const columnsSize = ssz.UintNum64.deserialize(retrievedColumnsSizeBytes);
32
- const dataColumnSidecarsBytes = dataColumnSidecarsBytesWrapped.slice(DATA_COLUMN_SIDECARS_IN_WRAPPER_INDEX + 4 * retrivedColumnsLen);
33
- const dataColumnsIndex = dataColumnSidecarsBytesWrapped.slice(CUSTODY_COLUMNS_IN_IN_WRAPPER_INDEX, CUSTODY_COLUMNS_IN_IN_WRAPPER_INDEX + NUMBER_OF_COLUMNS);
34
- for (const index of columns) {
35
- const dataIndex = (dataColumnsIndex[index] ?? 0) - 1;
36
- if (dataIndex < 0) {
37
- throw new ResponseError(RespStatus.SERVER_ERROR, `dataColumnSidecar index=${index} not custodied`);
38
- }
39
- const dataColumnSidecarBytes = dataColumnSidecarsBytes.slice(dataIndex * columnsSize, (dataIndex + 1) * columnsSize);
40
- if (dataColumnSidecarBytes.length !== columnsSize) {
41
- throw Error(`Inconsistent state, dataColumnSidecar blockRoot=${blockRootHex} index=${index} dataColumnSidecarBytes=${dataColumnSidecarBytes.length} expected=${columnsSize}`);
25
+ for (const [index, dataColumnBytes] of dataColumns.entries()) {
26
+ if (!dataColumnBytes) {
27
+ throw new ResponseError(RespStatus.SERVER_ERROR, `dataColumnSidecar index=${columns[index]} not custodied`);
42
28
  }
43
29
  yield {
44
- data: dataColumnSidecarBytes,
30
+ data: dataColumnBytes,
45
31
  boundary: chain.config.getForkBoundaryAtEpoch(computeEpochAtSlot(block.slot)),
46
32
  };
47
33
  }
@@ -1 +1 @@
1
- {"version":3,"file":"dataColumnSidecarsByRoot.js","sourceRoot":"","sources":["../../../../src/network/reqresp/handlers/dataColumnSidecarsByRoot.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"dataColumnSidecarsByRoot.js","sourceRoot":"","sources":["../../../../src/network/reqresp/handlers/dataColumnSidecarsByRoot.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,UAAU,EAAE,aAAa,EAAmB,MAAM,mBAAmB,CAAC;AAC9E,OAAO,EAAC,kBAAkB,EAAC,MAAM,4BAA4B,CAAC;AAE9D,OAAO,EAAC,OAAO,EAAE,KAAK,EAAC,MAAM,iBAAiB,CAAC;AAI/C,MAAM,CAAC,KAAK,SAAS,CAAC,CAAC,0BAA0B,CAC/C,WAAiD,EACjD,KAAmB,EACnB,EAAa;IAEb,oIAAoI;IACpI,MAAM,cAAc,GAAG,KAAK,CAAC,UAAU,CAAC,sBAAsB,EAAE,CAAC,KAAK,CAAC;IACvE,MAAM,YAAY,GAAG,KAAK,CAAC,KAAK,CAAC,YAAY,CAAC;IAC9C,MAAM,mBAAmB,GAAG,IAAI,CAAC,GAAG,CAClC,cAAc,EACd,YAAY,GAAG,KAAK,CAAC,MAAM,CAAC,4CAA4C,EACxE,KAAK,CAAC,MAAM,CAAC,eAAe,CAC7B,CAAC;IAEF,KAAK,MAAM,2BAA2B,IAAI,WAAW,EAAE,CAAC;QACtD,MAAM,EAAC,SAAS,EAAE,OAAO,EAAC,GAAG,2BAA2B,CAAC;QACzD,MAAM,YAAY,GAAG,KAAK,CAAC,SAAS,CAAC,CAAC;QACtC,MAAM,KAAK,GAAG,KAAK,CAAC,UAAU,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC;QAEzD,2CAA2C;QAC3C,8EAA8E;QAC9E,mHAAmH;QACnH,4FAA4F;QAC5F,oJAAoJ;QACpJ,IAAI,CAAC,KAAK,IAAI,kBAAkB,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,mBAAmB,EAAE,CAAC;YACnE,SAAS;QACX,CAAC;QAED,MAAM,WAAW,GAAG,MAAM,EAAE,CAAC,iBAAiB,CAAC,aAAa,CAAC,OAAO,CAAC,KAAK,CAAC,SAAS,CAAC,EAAE,OAAO,CAAC,CAAC;QAChG,IAAI,CAAC,WAAW,EAAE,CAAC;YACjB,MAAM,IAAI,aAAa,CAAC,UAAU,CAAC,YAAY,EAAE,oBAAoB,KAAK,CAAC,SAAS,UAAU,KAAK,CAAC,IAAI,EAAE,CAAC,CAAC;QAC9G,CAAC;QAED,KAAK,MAAM,CAAC,KAAK,EAAE,eAAe,CAAC,IAAI,WAAW,CAAC,OAAO,EAAE,EAAE,CAAC;YAC7D,IAAI,CAAC,eAAe,EAAE,CAAC;gBACrB,MAAM,IAAI,aAAa,CAAC,UAAU,CAAC,YAAY,EAAE,2BAA2B,OAAO,CAAC,KAAK,CAAC,gBAAgB,CAAC,CAAC;YAC9G,CAAC;YAED,MAAM;gBACJ,IAAI,EAAE,eAAe;gBACrB,QAAQ,EAAE,KAAK,CAAC,MAAM,CAAC,sBAAsB,CAAC,kBAAkB,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;aAC9E,CAAC;QACJ,CAAC;IACH,CAAC;AACH,CAAC"}
@@ -1,8 +1,12 @@
1
1
  import { ChainForkConfig } from "@lodestar/config";
2
2
  import { Logger } from "@lodestar/utils";
3
+ import { BlockInput, NullBlockInput } from "../chain/blocks/types.js";
3
4
  import { IBeaconChain } from "../chain/index.js";
4
5
  import { Metrics } from "../metrics/index.js";
5
6
  import { INetwork } from "../network/index.js";
7
+ import { PeerSyncMeta } from "../network/peers/peersData.js";
8
+ import { CustodyConfig } from "../util/dataColumns.js";
9
+ import { PeerIdStr } from "../util/peerId.js";
6
10
  import { SyncOptions } from "./options.js";
7
11
  export declare class UnknownBlockSync {
8
12
  private readonly config;
@@ -21,6 +25,7 @@ export declare class UnknownBlockSync {
21
25
  private subscribedToNetworkEvents;
22
26
  private engineGetBlobsCache;
23
27
  private blockInputsRetryTrackerCache;
28
+ private peerBalancer;
24
29
  constructor(config: ChainForkConfig, network: INetwork, chain: IBeaconChain, logger: Logger, metrics: Metrics | null, opts?: SyncOptions | undefined);
25
30
  subscribeToNetwork(): void;
26
31
  unsubscribeFromNetwork(): void;
@@ -47,6 +52,8 @@ export declare class UnknownBlockSync {
47
52
  */
48
53
  private addUnknownParent;
49
54
  private addUnknownBlock;
55
+ private onPeerConnected;
56
+ private onPeerDisconnected;
50
57
  /**
51
58
  * Gather tip parent blocks with unknown parent and do a search for all of them
52
59
  */
@@ -64,7 +71,7 @@ export declare class UnknownBlockSync {
64
71
  * - from deneb, fetch all missing blobs
65
72
  * - from peerDAS, fetch sampled colmns
66
73
  * TODO: this means we only have block root, and nothing else. Consider to reflect this in the function name
67
- * Will attempt a max of `MAX_ATTEMPTS_PER_BLOCK` on different peers if connectPeers.length > MAX_ATTEMPTS_PER_BLOCK.
74
+ * prefulu, will attempt a max of `MAX_ATTEMPTS_PER_BLOCK` on different peers, postfulu we may attempt more as defined in `getMaxDownloadAttempts()` function
68
75
  * Also verifies the received block root + returns the peer that provided the block for future downscoring.
69
76
  */
70
77
  private fetchUnknownBlockRoot;
@@ -72,8 +79,7 @@ export declare class UnknownBlockSync {
72
79
  * We have partial block input:
73
80
  * - we have block but not have all blobs (deneb) or needed columns (fulu)
74
81
  * - we don't have block and have some blobs (deneb) or some columns (fulu)
75
- * Fetches missing blobs for the blockinput, in future can also pull block is thats also missing
76
- * along with the blobs (i.e. only some blobs are available)
82
+ * Fetches missing block/data columns/block for the blockinput. This function returns either preData or availableData BlockInput.
77
83
  */
78
84
  private fetchUnavailableBlockInput;
79
85
  /**
@@ -84,5 +90,40 @@ export declare class UnknownBlockSync {
84
90
  */
85
91
  private removeAndDownscoreAllDescendants;
86
92
  private removeAllDescendants;
93
+ private getMaxDownloadAttempts;
94
+ }
95
+ /**
96
+ * Class to track active byRoots requests and balance them across eligible peers.
97
+ */
98
+ export declare class UnknownBlockPeerBalancer {
99
+ readonly peersMeta: Map<PeerIdStr, PeerSyncMeta>;
100
+ readonly activeRequests: Map<PeerIdStr, number>;
101
+ private readonly custodyConfig;
102
+ constructor(custodyConfig: CustodyConfig);
103
+ /** Trigger on each peer re-status */
104
+ onPeerConnected(peerId: PeerIdStr, syncMeta: PeerSyncMeta): void;
105
+ onPeerDisconnected(peerId: PeerIdStr): void;
106
+ /**
107
+ * called from fetchUnknownBlockRoot() where we only have block root and nothing else
108
+ * excludedPeers are the peers that we requested already so we don't want to try again
109
+ * pendingColumns is empty for prefulu, or the 1st time we we download a block by root
110
+ */
111
+ bestPeerForPendingColumns(pendingColumns: Set<number> | null, excludedPeers: Set<PeerIdStr>): PeerSyncMeta | null;
112
+ /**
113
+ * called from fetchUnavailableBlockInput() where we have either BlockInput or NullBlockInput
114
+ * excludedPeers are the peers that we requested already so we don't want to try again
115
+ */
116
+ bestPeerForBlockInput(unavailableBlockInput: BlockInput | NullBlockInput, excludedPeers: Set<PeerIdStr>): PeerSyncMeta | null;
117
+ /**
118
+ * Consumers don't need to call this method directly, it is called internally by bestPeer*() methods
119
+ * make this public for testing
120
+ */
121
+ onRequest(peerId: PeerIdStr): void;
122
+ /**
123
+ * Consumers should call this method when a request is completed for a peer.
124
+ */
125
+ onRequestCompleted(peerId: PeerIdStr): void;
126
+ getTotalActiveRequests(): number;
127
+ private filterPeers;
87
128
  }
88
129
  //# sourceMappingURL=unknownBlock.d.ts.map