Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Update libp2p to ESM version #4114

Merged
merged 51 commits into from
Sep 27, 2022
Merged

Update libp2p to ESM version #4114

merged 51 commits into from
Sep 27, 2022

Conversation

wemeetagain
Copy link
Member

@wemeetagain wemeetagain commented Jun 3, 2022

Motivation

We want to get the latest libp2p, gossipsub, etc updates.

Description

TODO:

Closes #4140
Closes #4043

@BigLep
Copy link

BigLep commented Jun 28, 2022

@wemeetagain : is there an estimate on when this will be completed? I'm asking because am hoping Lodestar can use the "canary" version of js-libp2p to provide feedback on the resource protection mechanisms that have recently been introduced.

@wemeetagain wemeetagain force-pushed the cayman/update-libp2p branch from 687b0ae to 764ecad Compare June 29, 2022 19:32
@github-actions
Copy link
Contributor

github-actions bot commented Jun 29, 2022

Performance Report

✔️ no performance regression detected

Full benchmark results
Benchmark suite Current: 2706281 Previous: 1beeb2b Ratio
getPubkeys - index2pubkey - req 1000 vs - 250000 vc 3.0490 ms/op 2.2950 ms/op 1.33
getPubkeys - validatorsArr - req 1000 vs - 250000 vc 96.803 us/op 74.553 us/op 1.30
BLS verify - blst-native 2.4159 ms/op 1.8533 ms/op 1.30
BLS verifyMultipleSignatures 3 - blst-native 4.8576 ms/op 3.7984 ms/op 1.28
BLS verifyMultipleSignatures 8 - blst-native 10.583 ms/op 8.1662 ms/op 1.30
BLS verifyMultipleSignatures 32 - blst-native 39.519 ms/op 29.656 ms/op 1.33
BLS aggregatePubkeys 32 - blst-native 52.465 us/op 39.155 us/op 1.34
BLS aggregatePubkeys 128 - blst-native 202.31 us/op 152.87 us/op 1.32
getAttestationsForBlock 126.50 ms/op 85.728 ms/op 1.48
isKnown best case - 1 super set check 584.00 ns/op 421.00 ns/op 1.39
isKnown normal case - 2 super set checks 555.00 ns/op 413.00 ns/op 1.34
isKnown worse case - 16 super set checks 553.00 ns/op 410.00 ns/op 1.35
CheckpointStateCache - add get delete 12.007 us/op 8.7520 us/op 1.37
validate gossip signedAggregateAndProof - struct 5.8516 ms/op 4.2644 ms/op 1.37
validate gossip attestation - struct 2.6393 ms/op 2.0377 ms/op 1.30
pickEth1Vote - no votes 2.7208 ms/op 2.1636 ms/op 1.26
pickEth1Vote - max votes 25.624 ms/op 19.963 ms/op 1.28
pickEth1Vote - Eth1Data hashTreeRoot value x2048 15.346 ms/op 11.365 ms/op 1.35
pickEth1Vote - Eth1Data hashTreeRoot tree x2048 26.404 ms/op 20.873 ms/op 1.26
pickEth1Vote - Eth1Data fastSerialize value x2048 1.9266 ms/op 1.4984 ms/op 1.29
pickEth1Vote - Eth1Data fastSerialize tree x2048 16.742 ms/op 13.271 ms/op 1.26
bytes32 toHexString 1.3290 us/op 1.0160 us/op 1.31
bytes32 Buffer.toString(hex) 797.00 ns/op 740.00 ns/op 1.08
bytes32 Buffer.toString(hex) from Uint8Array 1.2040 us/op 1.0110 us/op 1.19
bytes32 Buffer.toString(hex) + 0x 833.00 ns/op 737.00 ns/op 1.13
Object access 1 prop 0.49200 ns/op 0.36700 ns/op 1.34
Map access 1 prop 0.36200 ns/op 0.29700 ns/op 1.22
Object get x1000 17.814 ns/op 18.194 ns/op 0.98
Map get x1000 1.0130 ns/op 1.0350 ns/op 0.98
Object set x1000 127.57 ns/op 117.68 ns/op 1.08
Map set x1000 80.423 ns/op 68.539 ns/op 1.17
Return object 10000 times 0.40130 ns/op 0.37780 ns/op 1.06
Throw Error 10000 times 8.3322 us/op 5.9567 us/op 1.40
enrSubnets - fastDeserialize 64 bits 3.3560 us/op 2.6100 us/op 1.29
enrSubnets - ssz BitVector 64 bits 808.00 ns/op 748.00 ns/op 1.08
enrSubnets - fastDeserialize 4 bits 435.00 ns/op 381.00 ns/op 1.14
enrSubnets - ssz BitVector 4 bits 833.00 ns/op 764.00 ns/op 1.09
prioritizePeers score -10:0 att 32-0.1 sync 2-0 116.00 us/op 95.978 us/op 1.21
prioritizePeers score 0:0 att 32-0.25 sync 2-0.25 156.63 us/op 124.82 us/op 1.25
prioritizePeers score 0:0 att 32-0.5 sync 2-0.5 291.37 us/op 213.17 us/op 1.37
prioritizePeers score 0:0 att 64-0.75 sync 4-0.75 668.00 us/op 467.01 us/op 1.43
prioritizePeers score 0:0 att 64-1 sync 4-1 608.12 us/op 464.00 us/op 1.31
RateTracker 1000000 limit, 1 obj count per request 229.73 ns/op 198.88 ns/op 1.16
RateTracker 1000000 limit, 2 obj count per request 161.02 ns/op 153.91 ns/op 1.05
RateTracker 1000000 limit, 4 obj count per request 140.08 ns/op 129.29 ns/op 1.08
RateTracker 1000000 limit, 8 obj count per request 128.65 ns/op 117.24 ns/op 1.10
RateTracker with prune 5.4210 us/op 4.3870 us/op 1.24
array of 16000 items push then shift 5.7012 us/op 3.1716 us/op 1.80
LinkedList of 16000 items push then shift 23.408 ns/op 18.411 ns/op 1.27
array of 16000 items push then pop 287.55 ns/op 240.67 ns/op 1.19
LinkedList of 16000 items push then pop 19.055 ns/op 17.484 ns/op 1.09
array of 24000 items push then shift 8.4241 us/op 4.5562 us/op 1.85
LinkedList of 24000 items push then shift 22.135 ns/op 22.420 ns/op 0.99
array of 24000 items push then pop 261.41 ns/op 212.00 ns/op 1.23
LinkedList of 24000 items push then pop 21.404 ns/op 19.634 ns/op 1.09
intersect bitArray bitLen 8 15.382 ns/op 11.762 ns/op 1.31
intersect array and set length 8 231.81 ns/op 161.62 ns/op 1.43
intersect bitArray bitLen 128 84.892 ns/op 61.951 ns/op 1.37
intersect array and set length 128 2.8094 us/op 2.2117 us/op 1.27
Buffer.concat 32 items 2.7360 ns/op 1.9180 ns/op 1.43
pass gossip attestations to forkchoice per slot 7.5348 ms/op 4.0512 ms/op 1.86
computeDeltas 6.0913 ms/op 6.3272 ms/op 0.96
computeProposerBoostScoreFromBalances 915.75 us/op 907.80 us/op 1.01
altair processAttestation - 250000 vs - 7PWei normalcase 5.6117 ms/op 3.9559 ms/op 1.42
altair processAttestation - 250000 vs - 7PWei worstcase 8.1975 ms/op 5.7794 ms/op 1.42
altair processAttestation - setStatus - 1/6 committees join 288.96 us/op 216.77 us/op 1.33
altair processAttestation - setStatus - 1/3 committees join 543.17 us/op 416.59 us/op 1.30
altair processAttestation - setStatus - 1/2 committees join 849.38 us/op 583.20 us/op 1.46
altair processAttestation - setStatus - 2/3 committees join 1.0761 ms/op 747.93 us/op 1.44
altair processAttestation - setStatus - 4/5 committees join 1.4851 ms/op 1.0349 ms/op 1.44
altair processAttestation - setStatus - 100% committees join 1.8126 ms/op 1.2305 ms/op 1.47
altair processBlock - 250000 vs - 7PWei normalcase 33.919 ms/op 29.260 ms/op 1.16
altair processBlock - 250000 vs - 7PWei normalcase hashState 47.411 ms/op 40.503 ms/op 1.17
altair processBlock - 250000 vs - 7PWei worstcase 120.89 ms/op 83.742 ms/op 1.44
altair processBlock - 250000 vs - 7PWei worstcase hashState 125.70 ms/op 108.82 ms/op 1.16
phase0 processBlock - 250000 vs - 7PWei normalcase 5.1877 ms/op 4.3816 ms/op 1.18
phase0 processBlock - 250000 vs - 7PWei worstcase 60.410 ms/op 49.045 ms/op 1.23
altair processEth1Data - 250000 vs - 7PWei normalcase 1.1887 ms/op 814.30 us/op 1.46
Tree 40 250000 create 1.0853 s/op 830.11 ms/op 1.31
Tree 40 250000 get(125000) 341.21 ns/op 288.04 ns/op 1.18
Tree 40 250000 set(125000) 2.8838 us/op 2.9523 us/op 0.98
Tree 40 250000 toArray() 38.926 ms/op 33.907 ms/op 1.15
Tree 40 250000 iterate all - toArray() + loop 39.657 ms/op 34.791 ms/op 1.14
Tree 40 250000 iterate all - get(i) 145.47 ms/op 114.74 ms/op 1.27
MutableVector 250000 create 16.893 ms/op 18.215 ms/op 0.93
MutableVector 250000 get(125000) 14.166 ns/op 14.802 ns/op 0.96
MutableVector 250000 set(125000) 843.06 ns/op 717.62 ns/op 1.17
MutableVector 250000 toArray() 7.4086 ms/op 7.8917 ms/op 0.94
MutableVector 250000 iterate all - toArray() + loop 7.9347 ms/op 7.9987 ms/op 0.99
MutableVector 250000 iterate all - get(i) 3.5385 ms/op 3.4406 ms/op 1.03
Array 250000 create 7.0889 ms/op 7.3742 ms/op 0.96
Array 250000 clone - spread 3.8526 ms/op 4.2339 ms/op 0.91
Array 250000 get(125000) 1.6610 ns/op 1.7150 ns/op 0.97
Array 250000 set(125000) 1.7860 ns/op 1.7020 ns/op 1.05
Array 250000 iterate all - loop 153.20 us/op 167.87 us/op 0.91
effectiveBalanceIncrements clone Uint8Array 300000 356.97 us/op 85.549 us/op 4.17
effectiveBalanceIncrements clone MutableVector 300000 803.00 ns/op 630.00 ns/op 1.27
effectiveBalanceIncrements rw all Uint8Array 300000 314.02 us/op 252.73 us/op 1.24
effectiveBalanceIncrements rw all MutableVector 300000 227.69 ms/op 169.24 ms/op 1.35
phase0 afterProcessEpoch - 250000 vs - 7PWei 224.87 ms/op 201.31 ms/op 1.12
phase0 beforeProcessEpoch - 250000 vs - 7PWei 84.716 ms/op 80.299 ms/op 1.06
altair processEpoch - mainnet_e81889 677.45 ms/op 602.13 ms/op 1.13
mainnet_e81889 - altair beforeProcessEpoch 191.61 ms/op 156.50 ms/op 1.22
mainnet_e81889 - altair processJustificationAndFinalization 74.695 us/op 28.365 us/op 2.63
mainnet_e81889 - altair processInactivityUpdates 11.347 ms/op 11.819 ms/op 0.96
mainnet_e81889 - altair processRewardsAndPenalties 105.32 ms/op 96.361 ms/op 1.09
mainnet_e81889 - altair processRegistryUpdates 15.393 us/op 4.0670 us/op 3.78
mainnet_e81889 - altair processSlashings 4.6940 us/op 972.00 ns/op 4.83
mainnet_e81889 - altair processEth1DataReset 4.1230 us/op 898.00 ns/op 4.59
mainnet_e81889 - altair processEffectiveBalanceUpdates 2.6356 ms/op 2.4184 ms/op 1.09
mainnet_e81889 - altair processSlashingsReset 25.014 us/op 9.2450 us/op 2.71
mainnet_e81889 - altair processRandaoMixesReset 25.251 us/op 6.9030 us/op 3.66
mainnet_e81889 - altair processHistoricalRootsUpdate 3.9270 us/op 1.1710 us/op 3.35
mainnet_e81889 - altair processParticipationFlagUpdates 14.944 us/op 4.5380 us/op 3.29
mainnet_e81889 - altair processSyncCommitteeUpdates 3.6410 us/op 764.00 ns/op 4.77
mainnet_e81889 - altair afterProcessEpoch 221.67 ms/op 198.28 ms/op 1.12
phase0 processEpoch - mainnet_e58758 616.17 ms/op 545.99 ms/op 1.13
mainnet_e58758 - phase0 beforeProcessEpoch 327.02 ms/op 245.62 ms/op 1.33
mainnet_e58758 - phase0 processJustificationAndFinalization 67.292 us/op 24.110 us/op 2.79
mainnet_e58758 - phase0 processRewardsAndPenalties 91.132 ms/op 132.24 ms/op 0.69
mainnet_e58758 - phase0 processRegistryUpdates 34.264 us/op 12.119 us/op 2.83
mainnet_e58758 - phase0 processSlashings 3.9410 us/op 982.00 ns/op 4.01
mainnet_e58758 - phase0 processEth1DataReset 4.0030 us/op 1.0220 us/op 3.92
mainnet_e58758 - phase0 processEffectiveBalanceUpdates 2.0074 ms/op 2.3950 ms/op 0.84
mainnet_e58758 - phase0 processSlashingsReset 17.223 us/op 4.6280 us/op 3.72
mainnet_e58758 - phase0 processRandaoMixesReset 27.886 us/op 5.0820 us/op 5.49
mainnet_e58758 - phase0 processHistoricalRootsUpdate 4.7070 us/op 888.00 ns/op 5.30
mainnet_e58758 - phase0 processParticipationRecordUpdates 25.906 us/op 5.0020 us/op 5.18
mainnet_e58758 - phase0 afterProcessEpoch 168.22 ms/op 173.60 ms/op 0.97
phase0 processEffectiveBalanceUpdates - 250000 normalcase 2.4557 ms/op 2.6266 ms/op 0.93
phase0 processEffectiveBalanceUpdates - 250000 worstcase 0.5 2.7366 ms/op 3.4871 ms/op 0.78
altair processInactivityUpdates - 250000 normalcase 67.569 ms/op 41.647 ms/op 1.62
altair processInactivityUpdates - 250000 worstcase 55.950 ms/op 51.814 ms/op 1.08
phase0 processRegistryUpdates - 250000 normalcase 27.994 us/op 8.4310 us/op 3.32
phase0 processRegistryUpdates - 250000 badcase_full_deposits 540.09 us/op 455.39 us/op 1.19
phase0 processRegistryUpdates - 250000 worstcase 0.5 279.11 ms/op 218.11 ms/op 1.28
altair processRewardsAndPenalties - 250000 normalcase 111.94 ms/op 132.83 ms/op 0.84
altair processRewardsAndPenalties - 250000 worstcase 166.70 ms/op 86.961 ms/op 1.92
phase0 getAttestationDeltas - 250000 normalcase 15.251 ms/op 13.380 ms/op 1.14
phase0 getAttestationDeltas - 250000 worstcase 14.338 ms/op 13.583 ms/op 1.06
phase0 processSlashings - 250000 worstcase 6.7549 ms/op 5.4716 ms/op 1.23
altair processSyncCommitteeUpdates - 250000 344.39 ms/op 279.04 ms/op 1.23
BeaconState.hashTreeRoot - No change 633.00 ns/op 479.00 ns/op 1.32
BeaconState.hashTreeRoot - 1 full validator 71.372 us/op 64.361 us/op 1.11
BeaconState.hashTreeRoot - 32 full validator 829.38 us/op 678.28 us/op 1.22
BeaconState.hashTreeRoot - 512 full validator 8.8300 ms/op 6.8405 ms/op 1.29
BeaconState.hashTreeRoot - 1 validator.effectiveBalance 102.53 us/op 87.513 us/op 1.17
BeaconState.hashTreeRoot - 32 validator.effectiveBalance 1.6028 ms/op 1.1719 ms/op 1.37
BeaconState.hashTreeRoot - 512 validator.effectiveBalance 19.592 ms/op 15.904 ms/op 1.23
BeaconState.hashTreeRoot - 1 balances 84.721 us/op 62.226 us/op 1.36
BeaconState.hashTreeRoot - 32 balances 714.47 us/op 615.06 us/op 1.16
BeaconState.hashTreeRoot - 512 balances 7.5394 ms/op 5.8641 ms/op 1.29
BeaconState.hashTreeRoot - 250000 balances 124.75 ms/op 94.954 ms/op 1.31
aggregationBits - 2048 els - zipIndexesInBitList 35.332 us/op 36.236 us/op 0.98
regular array get 100000 times 62.570 us/op 67.419 us/op 0.93
wrappedArray get 100000 times 61.818 us/op 67.445 us/op 0.92
arrayWithProxy get 100000 times 37.099 ms/op 28.922 ms/op 1.28
ssz.Root.equals 602.00 ns/op 533.00 ns/op 1.13
byteArrayEquals 599.00 ns/op 507.00 ns/op 1.18
shuffle list - 16384 els 13.165 ms/op 11.080 ms/op 1.19
shuffle list - 250000 els 185.06 ms/op 166.95 ms/op 1.11
processSlot - 1 slots 17.990 us/op 14.083 us/op 1.28
processSlot - 32 slots 2.4390 ms/op 1.7584 ms/op 1.39
getEffectiveBalanceIncrementsZeroInactive - 250000 vs - 7PWei 473.10 us/op 399.59 us/op 1.18
getCommitteeAssignments - req 1 vs - 250000 vc 5.5776 ms/op 5.3835 ms/op 1.04
getCommitteeAssignments - req 100 vs - 250000 vc 8.2227 ms/op 7.3234 ms/op 1.12
getCommitteeAssignments - req 1000 vs - 250000 vc 9.1009 ms/op 7.7859 ms/op 1.17
RootCache.getBlockRootAtSlot - 250000 vs - 7PWei 10.710 ns/op 10.840 ns/op 0.99
state getBlockRootAtSlot - 250000 vs - 7PWei 1.5647 us/op 1.0767 us/op 1.45
computeProposers - vc 250000 23.492 ms/op 17.763 ms/op 1.32
computeEpochShuffling - vc 250000 180.65 ms/op 169.58 ms/op 1.07
getNextSyncCommittee - vc 250000 357.28 ms/op 271.46 ms/op 1.32

by benchmarkbot/action

@wemeetagain
Copy link
Member Author

This is ready for initial review, the last remaining items to fix are related to updating stream limits per protocol.
Running this locally shows that there are many errors related to 'too many streams' per protocol.

@wemeetagain wemeetagain marked this pull request as ready for review June 30, 2022 18:45
@wemeetagain wemeetagain requested a review from a team as a code owner June 30, 2022 18:45
@wemeetagain
Copy link
Member Author

Enabled libp2p metrics and attached a new dashboard exposing the metrics
libp2p_dashboard

@BigLep
Copy link

BigLep commented Aug 23, 2022

Thanks for sharing @wemeetagain . No expectation to respond as don't want to create extra work, but if there's a place can point to, I'd be interested in knowing what the remaining work is and if there's anything needed from js-libp2p at this point.

@wemeetagain
Copy link
Member Author

I don't think there's anything remaining on js-libp2p's side that we need.

Performance is now mostly on-par or better than our unstable and stable branches. We've redeployed 67da674 across a group in our fleet (roughly 24 hrs ago) and are monitoring metrics to iron out the last remaining things.

The big thing we're working through:

"libp2p-tcp": "^0.17.2",
"multiaddr": "^10.0.1",
"peer-id": "^0.16.0",
"libp2p": "0.37.3-509e56a",
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@wemeetagain are there newer versions?

}

// create metric if undefined
if (metrics[protocol] === undefined) {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

shouldn't we just add protocol in labelNames and simplify this

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think not, bc they split out the direction. eg: would be helpful to see if we're spammed with identify requests, but not responding.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Oh, just add protocol as an additional label. Yes good idea. Lets tackle metrics cleanup in a separate PR.

Copy link
Contributor

@g11tech g11tech left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM! metrics could be refactored in followup

@wemeetagain wemeetagain merged commit c2377f2 into unstable Sep 27, 2022
@wemeetagain wemeetagain deleted the cayman/update-libp2p branch September 27, 2022 17:56
@wemeetagain
Copy link
Member Author

cc @achingbrain we finally did it buddy

This was referenced Sep 27, 2022
@twoeths
Copy link
Contributor

twoeths commented Sep 28, 2022

Some different gossipsub metrics I notice after 6h-7h (in a 12h timeframe):

  • Heartbeat is way faster

Screen Shot 2022-09-28 at 08 46 58

  • Score functions are called less

Screen Shot 2022-09-28 at 08 22 41

  • We send out way less RPC control messages

Screen Shot 2022-09-28 at 08 23 43

  • We receive more RPC PRUNE messages ===> need to investigate!

Screen Shot 2022-09-28 at 08 24 34

  • More gossip attestation messages are dropped ==> something to notice

Screen Shot 2022-09-28 at 08 27 52

  • Besides, epoch transition is faster ==> is this coincidence?

Screen Shot 2022-09-28 at 08 30 55

Screen Shot 2022-09-28 at 08 35 08

"@types/tmp": "^0.2.0",
"@types/varint": "^6.0.0",
"eventsource": "^2.0.2",
"leveldown": "^6.1.1",
Copy link
Contributor

@dapplion dapplion Sep 29, 2022

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

oh, why is leveldown required? For libp2p datastore? If so, @wemeetagain can you motivate upstream dep to move to level >= 8.0.0?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
prio-high Resolve issues as soon as possible.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

libp2p-noise handshake performance Upgrade libp2p and dependencies to ESM version
6 participants