Skip to content

Commit

Permalink
Apply-load benchmark updates:
Browse files Browse the repository at this point in the history
- Use the new function that doesn't access storage, but does emit events
- Generate synthetic bucket list with configurable number of entries/ledgers
- Tighten the resources estimation
- Wait for merges in-between benchmark runs
  • Loading branch information
dmkozh committed Dec 10, 2024
1 parent 0241e79 commit 25b2e9c
Show file tree
Hide file tree
Showing 18 changed files with 834 additions and 363 deletions.
27 changes: 19 additions & 8 deletions Builds/VisualStudio/stellar-core.vcxproj
Original file line number Diff line number Diff line change
Expand Up @@ -481,20 +481,26 @@ exit /b 0
<ClCompile Include="..\..\lib\spdlog.cpp" />
<ClCompile Include="..\..\lib\tracy\public\TracyClient.cpp" />
<ClCompile Include="..\..\lib\util\siphash.cpp" />
<ClCompile Include="..\..\src\bucket\Bucket.cpp" />
<ClCompile Include="..\..\src\bucket\BucketApplicator.cpp" />
<ClCompile Include="..\..\src\bucket\BucketBase.cpp" />
<ClCompile Include="..\..\src\bucket\BucketIndexImpl.cpp" />
<ClCompile Include="..\..\src\bucket\BucketInputIterator.cpp" />
<ClCompile Include="..\..\src\bucket\BucketList.cpp" />
<ClCompile Include="..\..\src\bucket\BucketListSnapshot.cpp" />
<ClCompile Include="..\..\src\bucket\BucketManagerImpl.cpp" />
<ClCompile Include="..\..\src\bucket\BucketListBase.cpp" />
<ClCompile Include="..\..\src\bucket\BucketListSnapshotBase.cpp" />
<ClCompile Include="..\..\src\bucket\BucketManager.cpp" />
<ClCompile Include="..\..\src\bucket\BucketMergeMap.cpp" />
<ClCompile Include="..\..\src\bucket\BucketOutputIterator.cpp" />
<ClCompile Include="..\..\src\bucket\BucketSnapshot.cpp" />
<ClCompile Include="..\..\src\bucket\BucketSnapshotManager.cpp" />
<ClCompile Include="..\..\src\bucket\BucketUtils.cpp" />
<ClCompile Include="..\..\src\bucket\FutureBucket.cpp" />
<ClCompile Include="..\..\src\bucket\HotArchiveBucket.cpp" />
<ClCompile Include="..\..\src\bucket\HotArchiveBucketList.cpp" />
<ClCompile Include="..\..\src\bucket\LiveBucket.cpp" />
<ClCompile Include="..\..\src\bucket\LiveBucketList.cpp" />
<ClCompile Include="..\..\src\bucket\MergeKey.cpp" />
<ClCompile Include="..\..\src\bucket\PublishQueueBuckets.cpp" />
<ClCompile Include="..\..\src\bucket\SearchableBucketList.cpp" />
<ClCompile Include="..\..\src\bucket\test\BucketIndexTests.cpp" />
<ClCompile Include="..\..\src\bucket\test\BucketListTests.cpp" />
<ClCompile Include="..\..\src\bucket\test\BucketManagerTests.cpp" />
Expand Down Expand Up @@ -942,23 +948,28 @@ exit /b 0
<ClInclude Include="..\..\lib\fmt\include\fmt\format.h" />
<ClInclude Include="..\..\lib\util\siphash.h" />
<ClInclude Include="..\..\lib\util\stdrandom.h" />
<ClInclude Include="..\..\src\bucket\Bucket.h" />
<ClInclude Include="..\..\src\bucket\BucketApplicator.h" />
<ClInclude Include="..\..\src\bucket\BucketBase.h" />
<ClInclude Include="..\..\src\bucket\BucketIndex.h" />
<ClInclude Include="..\..\src\bucket\BucketIndexImpl.h" />
<ClInclude Include="..\..\src\bucket\BucketInputIterator.h" />
<ClInclude Include="..\..\src\bucket\BucketList.h" />
<ClInclude Include="..\..\src\bucket\BucketListSnapshot.h" />
<ClInclude Include="..\..\src\bucket\BucketListBase.h" />
<ClInclude Include="..\..\src\bucket\BucketListSnapshotBase.h" />
<ClInclude Include="..\..\src\bucket\BucketManager.h" />
<ClInclude Include="..\..\src\bucket\BucketManagerImpl.h" />
<ClInclude Include="..\..\src\bucket\BucketMergeMap.h" />
<ClInclude Include="..\..\src\bucket\BucketOutputIterator.h" />
<ClInclude Include="..\..\src\bucket\BucketSnapshot.h" />
<ClInclude Include="..\..\src\bucket\BucketSnapshotManager.h" />
<ClInclude Include="..\..\src\bucket\BucketUtils.h" />
<ClInclude Include="..\..\src\bucket\FutureBucket.h" />
<ClInclude Include="..\..\src\bucket\HotArchiveBucket.h" />
<ClInclude Include="..\..\src\bucket\HotArchiveBucketList.h" />
<ClInclude Include="..\..\src\bucket\LedgerCmp.h" />
<ClInclude Include="..\..\src\bucket\LiveBucket.h" />
<ClInclude Include="..\..\src\bucket\LiveBucketList.h" />
<ClInclude Include="..\..\src\bucket\MergeKey.h" />
<ClInclude Include="..\..\src\bucket\PublishQueueBuckets.h" />
<ClInclude Include="..\..\src\bucket\SearchableBucketList.h" />
<ClInclude Include="..\..\src\bucket\test\BucketTestUtils.h" />
<ClInclude Include="..\..\src\catchup\ApplyBucketsWork.h" />
<ClInclude Include="..\..\src\catchup\ApplyBufferedLedgersWork.h" />
Expand Down
81 changes: 57 additions & 24 deletions Builds/VisualStudio/stellar-core.vcxproj.filters
Original file line number Diff line number Diff line change
Expand Up @@ -576,9 +576,6 @@
<ClCompile Include="..\..\src\bucket\test\BucketTestUtils.cpp">
<Filter>bucket\tests</Filter>
</ClCompile>
<ClCompile Include="..\..\src\bucket\Bucket.cpp">
<Filter>bucket</Filter>
</ClCompile>
<ClCompile Include="..\..\src\bucket\BucketApplicator.cpp">
<Filter>bucket</Filter>
</ClCompile>
Expand All @@ -588,12 +585,6 @@
<ClCompile Include="..\..\src\bucket\BucketInputIterator.cpp">
<Filter>bucket</Filter>
</ClCompile>
<ClCompile Include="..\..\src\bucket\BucketList.cpp">
<Filter>bucket</Filter>
</ClCompile>
<ClCompile Include="..\..\src\bucket\BucketManagerImpl.cpp">
<Filter>bucket</Filter>
</ClCompile>
<ClCompile Include="..\..\src\bucket\BucketMergeMap.cpp">
<Filter>bucket</Filter>
</ClCompile>
Expand Down Expand Up @@ -1323,9 +1314,6 @@
<ClCompile Include="..\..\src\main\SettingsUpgradeUtils.cpp">
<Filter>main</Filter>
</ClCompile>
<ClCompile Include="..\..\src\bucket\BucketListSnapshot.cpp">
<Filter>bucket</Filter>
</ClCompile>
<ClCompile Include="..\..\src\bucket\BucketSnapshot.cpp">
<Filter>bucket</Filter>
</ClCompile>
Expand Down Expand Up @@ -1383,6 +1371,36 @@
<ClCompile Include="..\..\src\history\CheckpointBuilder.cpp">
<Filter>history</Filter>
</ClCompile>
<ClCompile Include="..\..\src\bucket\BucketBase.cpp">
<Filter>bucket</Filter>
</ClCompile>
<ClCompile Include="..\..\src\bucket\BucketListBase.cpp">
<Filter>bucket</Filter>
</ClCompile>
<ClCompile Include="..\..\src\bucket\BucketListSnapshotBase.cpp">
<Filter>bucket</Filter>
</ClCompile>
<ClCompile Include="..\..\src\bucket\HotArchiveBucket.cpp">
<Filter>bucket</Filter>
</ClCompile>
<ClCompile Include="..\..\src\bucket\HotArchiveBucketList.cpp">
<Filter>bucket</Filter>
</ClCompile>
<ClCompile Include="..\..\src\bucket\LiveBucket.cpp">
<Filter>bucket</Filter>
</ClCompile>
<ClCompile Include="..\..\src\bucket\LiveBucketList.cpp">
<Filter>bucket</Filter>
</ClCompile>
<ClCompile Include="..\..\src\bucket\SearchableBucketList.cpp">
<Filter>bucket</Filter>
</ClCompile>
<ClCompile Include="..\..\src\bucket\BucketManager.cpp">
<Filter>bucket</Filter>
</ClCompile>
<ClCompile Include="..\..\src\bucket\BucketUtils.cpp">
<Filter>bucket</Filter>
</ClCompile>
</ItemGroup>
<ItemGroup>
<ClInclude Include="..\..\lib\util\cpptoml.h">
Expand Down Expand Up @@ -1796,9 +1814,6 @@
<ClInclude Include="..\..\src\bucket\test\BucketTestUtils.h">
<Filter>bucket\tests</Filter>
</ClInclude>
<ClInclude Include="..\..\src\bucket\Bucket.h">
<Filter>bucket</Filter>
</ClInclude>
<ClInclude Include="..\..\src\bucket\BucketApplicator.h">
<Filter>bucket</Filter>
</ClInclude>
Expand All @@ -1811,15 +1826,9 @@
<ClInclude Include="..\..\src\bucket\BucketInputIterator.h">
<Filter>bucket</Filter>
</ClInclude>
<ClInclude Include="..\..\src\bucket\BucketList.h">
<Filter>bucket</Filter>
</ClInclude>
<ClInclude Include="..\..\src\bucket\BucketManager.h">
<Filter>bucket</Filter>
</ClInclude>
<ClInclude Include="..\..\src\bucket\BucketManagerImpl.h">
<Filter>bucket</Filter>
</ClInclude>
<ClInclude Include="..\..\src\bucket\BucketMergeMap.h">
<Filter>bucket</Filter>
</ClInclude>
Expand Down Expand Up @@ -2357,9 +2366,6 @@
<ClInclude Include="..\..\src\main\SettingsUpgradeUtils.h">
<Filter>main</Filter>
</ClInclude>
<ClInclude Include="..\..\src\bucket\BucketListSnapshot.h">
<Filter>bucket</Filter>
</ClInclude>
<ClInclude Include="..\..\src\bucket\BucketSnapshot.h">
<Filter>bucket</Filter>
</ClInclude>
Expand Down Expand Up @@ -2416,6 +2422,33 @@
<ClInclude Include="..\..\src\history\CheckpointBuilder.h">
<Filter>history</Filter>
</ClInclude>
<ClInclude Include="..\..\src\bucket\BucketBase.h">
<Filter>bucket</Filter>
</ClInclude>
<ClInclude Include="..\..\src\bucket\BucketListBase.h">
<Filter>bucket</Filter>
</ClInclude>
<ClInclude Include="..\..\src\bucket\BucketListSnapshotBase.h">
<Filter>bucket</Filter>
</ClInclude>
<ClInclude Include="..\..\src\bucket\HotArchiveBucket.h">
<Filter>bucket</Filter>
</ClInclude>
<ClInclude Include="..\..\src\bucket\HotArchiveBucketList.h">
<Filter>bucket</Filter>
</ClInclude>
<ClInclude Include="..\..\src\bucket\LiveBucket.h">
<Filter>bucket</Filter>
</ClInclude>
<ClInclude Include="..\..\src\bucket\LiveBucketList.h">
<Filter>bucket</Filter>
</ClInclude>
<ClInclude Include="..\..\src\bucket\SearchableBucketList.h">
<Filter>bucket</Filter>
</ClInclude>
<ClInclude Include="..\..\src\bucket\BucketUtils.h">
<Filter>bucket</Filter>
</ClInclude>
</ItemGroup>
<ItemGroup>
<None Include="..\..\AUTHORS" />
Expand Down
11 changes: 6 additions & 5 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion src/bucket/BucketIndexImpl.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -272,7 +272,7 @@ BucketIndexImpl<BucketIndex::RangeIndex>::saveToDisk(

{
OutputFileStream out(ctx, !bm.getConfig().DISABLE_XDR_FSYNC);
out.open(tmpFilename);
out.open(tmpFilename.string());
cereal::BufferedAsioOutputArchive ar(out);
ar(mData);
}
Expand Down
14 changes: 7 additions & 7 deletions src/bucket/BucketListBase.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -184,7 +184,7 @@ BucketLevel<BucketT>::prepare(
auto curr =
BucketListBase<BucketT>::shouldMergeWithEmptyCurr(currLedger, mLevel)
? std::make_shared<BucketT>()
: mCurr;
: mCurr;

auto shadowsBasedOnProtocol =
protocolVersionStartsFrom(snap->getBucketVersion(),
Expand All @@ -193,7 +193,7 @@ BucketLevel<BucketT>::prepare(
: shadows;
mNextCurr =
FutureBucket<BucketT>(app, curr, snap, shadowsBasedOnProtocol,
currLedgerProtocol, countMergeEvents, mLevel);
currLedgerProtocol, countMergeEvents, mLevel);
releaseAssert(mNextCurr.isMerging());
}

Expand Down Expand Up @@ -546,7 +546,7 @@ BucketListBase<BucketT>::getSize() const
for (auto const& lev : mLevels)
{
std::array<std::shared_ptr<BucketT>, 2> buckets = {lev.getCurr(),
lev.getSnap()};
lev.getSnap()};
for (auto const& b : buckets)
{
if (b)
Expand All @@ -563,7 +563,7 @@ template <typename BucketT>
template <typename... VectorT>
void
BucketListBase<BucketT>::addBatchInternal(Application& app, uint32_t currLedger,
uint32_t currLedgerProtocol,
uint32_t currLedgerProtocol,
VectorT const&... inputVectors)
{
ZoneScoped;
Expand Down Expand Up @@ -662,8 +662,8 @@ BucketListBase<BucketT>::addBatchInternal(Application& app, uint32_t currLedger,
mLevels[0].prepare(app, currLedger, currLedgerProtocol,
BucketT::fresh(app.getBucketManager(),
currLedgerProtocol, inputVectors...,
countMergeEvents,
app.getClock().getIOContext(), doFsync),
countMergeEvents,
app.getClock().getIOContext(), doFsync),
shadows, countMergeEvents);
mLevels[0].commit();

Expand All @@ -685,7 +685,7 @@ template <typename BucketT>
void
BucketListBase<BucketT>::restartMerges(Application& app,
uint32_t maxProtocolVersion,
uint32_t ledger)
uint32_t ledger)
{
ZoneScoped;
for (uint32_t i = 0; i < static_cast<uint32>(mLevels.size()); i++)
Expand Down
14 changes: 7 additions & 7 deletions src/history/HistoryManagerImpl.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -560,13 +560,13 @@ HistoryManagerImpl::getPublishQueueStates()
{
ZoneScoped;
std::vector<HistoryArchiveState> states;
forEveryQueuedCheckpoint(publishQueuePath(mApp.getConfig()).string(),
[&](uint32_t seq, std::string const& f) {
HistoryArchiveState has;
auto fullPath =
publishQueuePath(mApp.getConfig()) / f;
states.push_back(loadCheckpointHAS(fullPath));
});
forEveryQueuedCheckpoint(
publishQueuePath(mApp.getConfig()).string(),
[&](uint32_t seq, std::string const& f) {
HistoryArchiveState has;
auto fullPath = publishQueuePath(mApp.getConfig()) / f;
states.push_back(loadCheckpointHAS(fullPath.string()));
});
return states;
}

Expand Down
1 change: 1 addition & 0 deletions src/ledger/LedgerManager.h
Original file line number Diff line number Diff line change
Expand Up @@ -135,6 +135,7 @@ class LedgerManager
virtual SorobanNetworkConfig& getMutableSorobanNetworkConfig() = 0;
virtual std::vector<TransactionMetaFrame> const&
getLastClosedLedgerTxMeta() = 0;
virtual void storeCurrentLedgerForTest(LedgerHeader const& header) = 0;
#endif

// Return the (changing) number of seconds since the LCL closed.
Expand Down
6 changes: 6 additions & 0 deletions src/ledger/LedgerManagerImpl.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -580,6 +580,12 @@ LedgerManagerImpl::getLastClosedLedgerTxMeta()
{
return mLastLedgerTxMeta;
}

void
LedgerManagerImpl::storeCurrentLedgerForTest(LedgerHeader const& header)
{
storeCurrentLedger(header, true, true);
}
#endif

SorobanMetrics&
Expand Down
1 change: 1 addition & 0 deletions src/ledger/LedgerManagerImpl.h
Original file line number Diff line number Diff line change
Expand Up @@ -166,6 +166,7 @@ class LedgerManagerImpl : public LedgerManager
std::vector<TransactionMetaFrame> const&
getLastClosedLedgerTxMeta() override;
TransactionResultSet mLatestTxResultSet{};
void storeCurrentLedgerForTest(LedgerHeader const& header) override;
#endif

uint64_t secondsSinceLastLedgerClose() const override;
Expand Down
Loading

0 comments on commit 25b2e9c

Please sign in to comment.