Skip to content

Commit

Permalink
Drop support for cursors
Browse files Browse the repository at this point in the history
  • Loading branch information
marta-lokhova committed Dec 17, 2024
1 parent 73fa340 commit 3f85df1
Show file tree
Hide file tree
Showing 15 changed files with 34 additions and 495 deletions.
13 changes: 0 additions & 13 deletions docs/quick-reference.md
Original file line number Diff line number Diff line change
Expand Up @@ -59,19 +59,6 @@ You have some control over which peers you're connected to:
* the `connect` command asks the instance to connect to a specific peer.
* the `droppeer` command asks the instance to drop the connection with a specific peer.

### Maintenance

Core keeps old meta around for Horizon and other systems. As cursors get updated, automatic
maintenance normally deletes more than enough for the node to use a constant amount of disk space.

Sometimes you need to clean up more than this (for example, if you have a large maintenance debt).
In this case running the command `maintenance?count=100000000` (integer is a large number, bigger than your max backlog) will perform the full maintenance.

Note that this may hang the instance for minutes (hours even).

After performing such maintenance, you may issue a postgres `VACUUM FULL;` that will reclaim all
disk space (note that this requires a lot of free disk space).

### Testing

The `manualclose` command allows to close a ledger, this is used when the instance is
Expand Down
27 changes: 0 additions & 27 deletions docs/software/commands.md
Original file line number Diff line number Diff line change
Expand Up @@ -244,11 +244,6 @@ Most commands return their results in JSON format.
`connect?peer=NAME&port=NNN`<br>
Triggers the instance to connect to peer NAME at port NNN.

* **dropcursor**
`dropcursor?id=ID`<br>
Deletes the tracking cursor identified by `id`. See `setcursor` for
more information.

* **droppeer**
`droppeer?node=NODE_ID[&ban=D]`<br>
Drops peer identified by NODE_ID, when D is 1 the peer is also banned.
Expand All @@ -269,11 +264,6 @@ Most commands return their results in JSON format.
* **logrotate**
Rotate log files.

* **maintenance**
`maintenance?[queue=true]`<br>
Performs maintenance tasks on the instance.
* `queue` performs deletion of queue data. See `setcursor` for more information.

* **metrics**
`metrics?[enable=PARTITION_1,PARTITION_2,...,PARTITION_N]`<br>
Returns a snapshot of the metrics registry (for monitoring and debugging
Expand Down Expand Up @@ -307,23 +297,6 @@ Most commands return their results in JSON format.
* `delayed`: participating in the latest consensus rounds, but slower than others.
* `agree`: running just fine.

* **setcursor**
`setcursor?id=ID&cursor=N`<br>
Sets or creates a cursor identified by `ID` with value `N`. ID is an
uppercase AlphaNum, N is an uint32 that represents the last ledger sequence
number that the instance ID processed. Cursors are used by dependent services
to tell stellar-core which data can be safely deleted by the instance. The
data is historical data stored in the SQL tables such as txhistory or
ledgerheaders. When all consumers processed the data for ledger sequence N
the data can be safely removed by the instance. The actual deletion is
performed by invoking the `maintenance` endpoint or on startup. See also
`dropcursor`.

* **getcursor**
`getcursor?[id=ID]`<br>
Gets the cursor identified by `ID`. If ID is not defined then all cursors
will be returned.

* **scp**
`scp?[limit=n][&fullkeys=false]`<br>
Returns a JSON object with the internal state of the SCP engine for the last
Expand Down
4 changes: 0 additions & 4 deletions docs/stellar-core_example.cfg
Original file line number Diff line number Diff line change
Expand Up @@ -304,10 +304,6 @@ KNOWN_PEERS=[
"core-testnet2.stellar.org",
"core-testnet3.stellar.org"]

# KNOWN_CURSORS (list of strings) default is empty
# Set of cursors added at each startup with value '1'.
KNOWN_CURSORS=["HORIZON"]

#######################
## SCP settings

Expand Down
5 changes: 2 additions & 3 deletions src/bucket/test/BucketManagerTests.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@
#include "lib/catch.hpp"
#include "main/Application.h"
#include "main/Config.h"
#include "main/ExternalQueue.h"
#include "main/Maintainer.h"
#include "test/TestUtils.h"
#include "test/test.h"
#include "util/GlobalChecks.h"
Expand Down Expand Up @@ -641,8 +641,7 @@ TEST_CASE_VERSIONS(
clock.crank(false);

// Trim history after publishing whenever possible.
ExternalQueue ps(*app);
ps.deleteOldEntries(50000);
app->getMaintainer().performMaintenance(50000);
}
});
}
Expand Down
7 changes: 4 additions & 3 deletions src/database/Database.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,6 @@
#include "history/HistoryManager.h"
#include "ledger/LedgerHeaderUtils.h"
#include "ledger/LedgerTxn.h"
#include "main/ExternalQueue.h"
#include "main/PersistentState.h"
#include "overlay/BanManager.h"
#include "overlay/OverlayManager.h"
Expand Down Expand Up @@ -63,7 +62,7 @@ bool Database::gDriversRegistered = false;

// smallest schema version supported
static unsigned long const MIN_SCHEMA_VERSION = 21;
static unsigned long const SCHEMA_VERSION = 23;
static unsigned long const SCHEMA_VERSION = 24;

// These should always match our compiled version precisely, since we are
// using a bundled version to get access to carray(). But in case someone
Expand Down Expand Up @@ -219,6 +218,9 @@ Database::applySchemaUpgrade(unsigned long vers)
mApp.getHistoryManager().dropSQLBasedPublish();
Upgrades::dropSupportUpgradeHistory(*this);
break;
case 24:
getSession() << "DROP TABLE IF EXISTS pubsub;";
break;
default:
throw std::runtime_error("Unknown DB schema version");
}
Expand Down Expand Up @@ -473,7 +475,6 @@ Database::initialize()
Upgrades::dropAll(*this);
OverlayManager::dropAll(*this);
PersistentState::dropAll(*this);
ExternalQueue::dropAll(*this);
LedgerHeaderUtils::dropAll(*this);
// No need to re-create txhistory, will be dropped during
// upgradeToCurrentSchema anyway
Expand Down
8 changes: 3 additions & 5 deletions src/history/test/HistoryTests.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@
#include "historywork/GzipFileWork.h"
#include "historywork/PutHistoryArchiveStateWork.h"
#include "ledger/LedgerManager.h"
#include "main/ExternalQueue.h"
#include "main/Maintainer.h"
#include "main/PersistentState.h"
#include "process/ProcessManager.h"
#include "test/TestAccount.h"
Expand Down Expand Up @@ -1375,8 +1375,7 @@ TEST_CASE("persist publish queue", "[history][publish][acceptance]")
REQUIRE(hm0.getMinLedgerQueuedToPublish() == 7);

// Trim history after publishing.
ExternalQueue ps(*app0);
ps.deleteOldEntries(50000);
app0->getMaintainer().performMaintenance(50000);
}

cfg.MAX_CONCURRENT_SUBPROCESSES = 32;
Expand All @@ -1395,8 +1394,7 @@ TEST_CASE("persist publish queue", "[history][publish][acceptance]")
clock.crank(true);

// Trim history after publishing whenever possible.
ExternalQueue ps(*app1);
ps.deleteOldEntries(50000);
app1->getMaintainer().performMaintenance(50000);
}
// We should have either an empty publish queue or a
// ledger sometime after the 5th checkpoint
Expand Down
4 changes: 0 additions & 4 deletions src/main/ApplicationImpl.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,6 @@
#include "main/AppConnector.h"
#include "main/ApplicationUtils.h"
#include "main/CommandHandler.h"
#include "main/ExternalQueue.h"
#include "main/Maintainer.h"
#include "main/StellarCoreVersion.h"
#include "medida/counter.h"
Expand Down Expand Up @@ -872,9 +871,6 @@ ApplicationImpl::startServices()
{
// restores Herder's state before starting overlay
mHerder->start();
// set known cursors before starting maintenance job
ExternalQueue ps(*this);
ps.setInitialCursors(mConfig.KNOWN_CURSORS);
mMaintainer->start();
if (mConfig.MODE_AUTO_STARTS_OVERLAY)
{
Expand Down
76 changes: 0 additions & 76 deletions src/main/CommandHandler.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -36,8 +36,6 @@
#include "xdr/Stellar-transaction.h"
#include "xdrpp/marshal.h"

#include "ExternalQueue.h"

#ifdef BUILD_TESTS
#include "simulation/LoadGenerator.h"
#include "test/TestAccount.h"
Expand Down Expand Up @@ -90,9 +88,6 @@ CommandHandler::CommandHandler(Application& app) : mApp(app)
mServer->add404(std::bind(&CommandHandler::fileNotFound, this, _1, _2));
if (mApp.getConfig().modeStoresAnyHistory())
{
addRoute("dropcursor", &CommandHandler::dropcursor);
addRoute("getcursor", &CommandHandler::getcursor);
addRoute("setcursor", &CommandHandler::setcursor);
addRoute("maintenance", &CommandHandler::maintenance);
}

Expand Down Expand Up @@ -1011,77 +1006,6 @@ CommandHandler::tx(std::string const& params, std::string& retStr)
retStr = Json::FastWriter().write(root);
}

void
CommandHandler::dropcursor(std::string const& params, std::string& retStr)
{
ZoneScoped;
std::map<std::string, std::string> map;
http::server::server::parseParams(params, map);
std::string const& id = map["id"];

if (!ExternalQueue::validateResourceID(id))
{
retStr = "Invalid resource id";
}
else
{
ExternalQueue ps(mApp);
ps.deleteCursor(id);
retStr = "Done";
}
}

void
CommandHandler::setcursor(std::string const& params, std::string& retStr)
{
ZoneScoped;
std::map<std::string, std::string> map;
http::server::server::parseParams(params, map);
std::string const& id = map["id"];

uint32 cursor = parseRequiredParam<uint32>(map, "cursor");

if (!ExternalQueue::validateResourceID(id))
{
retStr = "Invalid resource id";
}
else
{
ExternalQueue ps(mApp);
ps.setCursorForResource(id, cursor);
retStr = "Done";
}
}

void
CommandHandler::getcursor(std::string const& params, std::string& retStr)
{
ZoneScoped;
Json::Value root;
std::map<std::string, std::string> map;
http::server::server::parseParams(params, map);
std::string const& id = map["id"];

// the decision was made not to check validity here
// because there are subsequent checks for that in
// ExternalQueue and if an exception is thrown for
// validity there, the ret format is technically more
// correct for the mime type
ExternalQueue ps(mApp);
std::map<std::string, uint32> curMap;
int counter = 0;
ps.getCursorForResource(id, curMap);
root["cursors"][0];
for (auto cursor : curMap)
{
root["cursors"][counter]["id"] = cursor.first;
root["cursors"][counter]["cursor"] = cursor.second;
counter++;
}

retStr = root.toStyledString();
}

void
CommandHandler::maintenance(std::string const& params, std::string& retStr)
{
Expand Down
3 changes: 0 additions & 3 deletions src/main/CommandHandler.h
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,6 @@ class CommandHandler

void bans(std::string const& params, std::string& retStr);
void connect(std::string const& params, std::string& retStr);
void dropcursor(std::string const& params, std::string& retStr);
void dropPeer(std::string const& params, std::string& retStr);
void info(std::string const& params, std::string& retStr);
void ll(std::string const& params, std::string& retStr);
Expand All @@ -61,8 +60,6 @@ class CommandHandler
void peers(std::string const& params, std::string& retStr);
void selfCheck(std::string const&, std::string& retStr);
void quorum(std::string const& params, std::string& retStr);
void setcursor(std::string const& params, std::string& retStr);
void getcursor(std::string const& params, std::string& retStr);
void scpInfo(std::string const& params, std::string& retStr);
void tx(std::string const& params, std::string& retStr);
void unban(std::string const& params, std::string& retStr);
Expand Down
13 changes: 0 additions & 13 deletions src/main/Config.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,6 @@
#include "herder/Herder.h"
#include "history/HistoryArchive.h"
#include "ledger/LedgerManager.h"
#include "main/ExternalQueue.h"
#include "main/StellarCoreVersion.h"
#include "scp/LocalNode.h"
#include "scp/QuorumSetUtils.h"
Expand Down Expand Up @@ -1127,18 +1126,6 @@ Config::processConfig(std::shared_ptr<cpptoml::table> t)
[&]() { BUCKETLIST_DB_PERSIST_INDEX = readBool(item); }},
{"METADATA_DEBUG_LEDGERS",
[&]() { METADATA_DEBUG_LEDGERS = readInt<uint32_t>(item); }},
{"KNOWN_CURSORS",
[&]() {
KNOWN_CURSORS = readArray<std::string>(item);
for (auto const& c : KNOWN_CURSORS)
{
if (!ExternalQueue::validateResourceID(c))
{
throw std::invalid_argument(fmt::format(
FMT_STRING("invalid cursor: \"{}\""), c));
}
}
}},
{"RUN_STANDALONE", [&]() { RUN_STANDALONE = readBool(item); }},
{"CATCHUP_COMPLETE",
[&]() { CATCHUP_COMPLETE = readBool(item); }},
Expand Down
3 changes: 0 additions & 3 deletions src/main/Config.h
Original file line number Diff line number Diff line change
Expand Up @@ -554,9 +554,6 @@ class Config : public std::enable_shared_from_this<Config>
// at a premium.
uint32_t METADATA_DEBUG_LEDGERS;

// Set of cursors added at each startup with value '1'.
std::vector<std::string> KNOWN_CURSORS;

// maximum protocol version supported by the application, can be overridden
// in tests
uint32_t LEDGER_PROTOCOL_VERSION;
Expand Down
Loading

0 comments on commit 3f85df1

Please sign in to comment.