Skip to content

Commit

Permalink
Revert runtime snapshot fetching (#6727)
Browse files Browse the repository at this point in the history
  • Loading branch information
eddyashton authored Jan 7, 2025
1 parent 03f6005 commit 21197eb
Show file tree
Hide file tree
Showing 24 changed files with 216 additions and 1,206 deletions.
2 changes: 1 addition & 1 deletion .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -114,7 +114,7 @@ jobs:
# Build tools
tdnf -y install build-essential clang cmake ninja-build which
# Dependencies
tdnf -y install openssl-devel libuv-devel curl-devel
tdnf -y install openssl-devel libuv-devel
# Test dependencies
tdnf -y install libarrow-devel parquet-libs-devel lldb npm jq expect
# Install CDDL via rubygems
Expand Down
12 changes: 2 additions & 10 deletions CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -254,15 +254,8 @@ elseif(COMPILE_TARGET STREQUAL "virtual")
endif()

target_link_libraries(
cchost
PRIVATE uv
${TLS_LIBRARY}
${CMAKE_DL_LIBS}
${CMAKE_THREAD_LIBS_INIT}
${LINK_LIBCXX}
ccfcrypto.host
curl
http_parser.host
cchost PRIVATE uv ${TLS_LIBRARY} ${CMAKE_DL_LIBS} ${CMAKE_THREAD_LIBS_INIT}
${LINK_LIBCXX} ccfcrypto.host
)

install(TARGETS cchost DESTINATION bin)
Expand Down Expand Up @@ -715,7 +708,6 @@ if(BUILD_TESTS)
${CMAKE_CURRENT_SOURCE_DIR}/src/ds/test/contiguous_set.cpp
${CMAKE_CURRENT_SOURCE_DIR}/src/ds/test/unit_strings.cpp
${CMAKE_CURRENT_SOURCE_DIR}/src/ds/test/dl_list.cpp
${CMAKE_CURRENT_SOURCE_DIR}/src/ds/test/nonstd.cpp
)
target_link_libraries(ds_test PRIVATE ${CMAKE_THREAD_LIBS_INIT})

Expand Down
5 changes: 0 additions & 5 deletions doc/host_config_schema/cchost_config.json
Original file line number Diff line number Diff line change
Expand Up @@ -396,11 +396,6 @@
"type": "boolean",
"default": true,
"description": "Whether to follow redirects to the primary node of the existing service to join"
},
"fetch_recent_snapshot": {
"type": "boolean",
"default": true,
"description": "Whether to ask the target for a newer snapshot before joining. The node will ask the target what their latest snapshot is, and if that is later than what the node has locally, will fetch it via RPC before launching. Should generally only be turned off for specific test cases"
}
},
"required": ["target_rpc_address"],
Expand Down
8 changes: 0 additions & 8 deletions include/ccf/ds/nonstd.h
Original file line number Diff line number Diff line change
Expand Up @@ -185,14 +185,6 @@ namespace ccf::nonstd
});
}

static inline std::string_view trim(
std::string_view s, std::string_view trim_chars = " \t\r\n")
{
const auto start = std::min(s.find_first_not_of(trim_chars), s.size());
const auto end = std::min(s.find_last_not_of(trim_chars) + 1, s.size());
return s.substr(start, end - start);
}

/// Iterate through tuple, calling functor on each element
template <size_t I = 0, typename F, typename... Ts>
static void tuple_for_each(const std::tuple<Ts...>& t, const F& f)
Expand Down
10 changes: 0 additions & 10 deletions include/ccf/node/startup_config.h
Original file line number Diff line number Diff line change
Expand Up @@ -76,16 +76,6 @@ namespace ccf
bool operator==(const Attestation&) const = default;
};
Attestation attestation = {};

struct Snapshots
{
std::string directory = "snapshots";
size_t tx_count = 10'000;
std::optional<std::string> read_only_directory = std::nullopt;

bool operator==(const Snapshots&) const = default;
};
Snapshots snapshots = {};
};

struct StartupConfig : CCFConfig
Expand Down
24 changes: 0 additions & 24 deletions python/src/ccf/ledger.py
Original file line number Diff line number Diff line change
Expand Up @@ -126,19 +126,6 @@ def range_from_filename(filename: str) -> Tuple[int, Optional[int]]:
raise ValueError(f"Could not read seqno range from ledger file {filename}")


def snapshot_index_from_filename(filename: str) -> Tuple[int, int]:
elements = (
os.path.basename(filename)
.replace(COMMITTED_FILE_SUFFIX, "")
.replace("snapshot_", "")
.split("_")
)
if len(elements) == 2:
return (int(elements[0]), int(elements[1]))
else:
raise ValueError(f"Could not read snapshot index from file name {filename}")


class GcmHeader:
view: int
seqno: int
Expand Down Expand Up @@ -864,17 +851,6 @@ def get_len(self) -> int:
return self._file_size


def latest_snapshot(snapshots_dir):
best_name, best_seqno = None, None
for s in os.listdir(snapshots_dir):
with ccf.ledger.Snapshot(os.path.join(snapshots_dir, s)) as snapshot:
snapshot_seqno = snapshot.get_public_domain().get_seqno()
if best_seqno is None or snapshot_seqno > best_seqno:
best_name = s
best_seqno = snapshot_seqno
return best_name


class LedgerChunk:
"""
Class used to parse and iterate over :py:class:`ccf.ledger.Transaction` in a CCF ledger chunk.
Expand Down
6 changes: 0 additions & 6 deletions src/common/configuration.h
Original file line number Diff line number Diff line change
Expand Up @@ -84,11 +84,6 @@ namespace ccf
snp_security_policy_file,
snp_uvm_endorsements_file);

DECLARE_JSON_TYPE_WITH_OPTIONAL_FIELDS(CCFConfig::Snapshots);
DECLARE_JSON_REQUIRED_FIELDS(CCFConfig::Snapshots);
DECLARE_JSON_OPTIONAL_FIELDS(
CCFConfig::Snapshots, directory, tx_count, read_only_directory);

DECLARE_JSON_TYPE_WITH_OPTIONAL_FIELDS(CCFConfig);
DECLARE_JSON_REQUIRED_FIELDS(CCFConfig, network);
DECLARE_JSON_OPTIONAL_FIELDS(
Expand All @@ -99,7 +94,6 @@ namespace ccf
ledger_signatures,
jwt,
attestation,
snapshots,
node_to_node_message_limit,
historical_cache_soft_limit);

Expand Down
16 changes: 0 additions & 16 deletions src/ds/test/nonstd.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -265,19 +265,3 @@ TEST_CASE("rsplit" * doctest::test_suite("nonstd"))
}
}
}

TEST_CASE("trim" * doctest::test_suite("nonstd"))
{
REQUIRE(ccf::nonstd::trim(" hello world ") == "hello world");
REQUIRE(
ccf::nonstd::trim(" \r\n\t\nhello world\n\n\r\t\t\n\t \n\t") ==
"hello world");
REQUIRE(ccf::nonstd::trim("..hello..") == "..hello..");
REQUIRE(ccf::nonstd::trim("..hello..", ".") == "hello");

REQUIRE(ccf::nonstd::trim("hello") == "hello");
REQUIRE(ccf::nonstd::trim(" h") == "h");
REQUIRE(ccf::nonstd::trim("h ") == "h");
REQUIRE(ccf::nonstd::trim(" ") == "");
REQUIRE(ccf::nonstd::trim("") == "");
}
21 changes: 16 additions & 5 deletions src/host/configuration.h
Original file line number Diff line number Diff line change
Expand Up @@ -103,6 +103,16 @@ namespace host
};
Ledger ledger = {};

struct Snapshots
{
std::string directory = "snapshots";
size_t tx_count = 10'000;
std::optional<std::string> read_only_directory = std::nullopt;

bool operator==(const Snapshots&) const = default;
};
Snapshots snapshots = {};

struct Logging
{
ccf::LoggerLevel host_level = ccf::LoggerLevel::INFO;
Expand Down Expand Up @@ -145,7 +155,6 @@ namespace host
ccf::NodeInfoNetwork::NetAddress target_rpc_address;
ccf::ds::TimeString retry_timeout = {"1000ms"};
bool follow_redirect = true;
bool fetch_recent_snapshot = true;

bool operator==(const Join&) const = default;
};
Expand Down Expand Up @@ -180,6 +189,11 @@ namespace host
DECLARE_JSON_OPTIONAL_FIELDS(
CCHostConfig::Ledger, directory, read_only_directories, chunk_size);

DECLARE_JSON_TYPE_WITH_OPTIONAL_FIELDS(CCHostConfig::Snapshots);
DECLARE_JSON_REQUIRED_FIELDS(CCHostConfig::Snapshots);
DECLARE_JSON_OPTIONAL_FIELDS(
CCHostConfig::Snapshots, directory, tx_count, read_only_directory);

DECLARE_JSON_TYPE_WITH_OPTIONAL_FIELDS(CCHostConfig::Logging);
DECLARE_JSON_REQUIRED_FIELDS(CCHostConfig::Logging);
DECLARE_JSON_OPTIONAL_FIELDS(CCHostConfig::Logging, host_level, format);
Expand All @@ -202,10 +216,7 @@ namespace host
DECLARE_JSON_TYPE_WITH_OPTIONAL_FIELDS(CCHostConfig::Command::Join);
DECLARE_JSON_REQUIRED_FIELDS(CCHostConfig::Command::Join, target_rpc_address);
DECLARE_JSON_OPTIONAL_FIELDS(
CCHostConfig::Command::Join,
retry_timeout,
follow_redirect,
fetch_recent_snapshot);
CCHostConfig::Command::Join, retry_timeout, follow_redirect);

DECLARE_JSON_TYPE_WITH_OPTIONAL_FIELDS(CCHostConfig::Command::Recover);
DECLARE_JSON_REQUIRED_FIELDS(CCHostConfig::Command::Recover);
Expand Down
73 changes: 17 additions & 56 deletions src/host/main.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -24,8 +24,7 @@
#include "process_launcher.h"
#include "rpc_connections.h"
#include "sig_term.h"
#include "snapshots/fetch.h"
#include "snapshots/snapshot_manager.h"
#include "snapshots.h"
#include "ticker.h"
#include "time_updater.h"

Expand Down Expand Up @@ -377,7 +376,7 @@ int main(int argc, char** argv)
config.ledger.read_only_directories);
ledger.register_message_handlers(bp.get_dispatcher());

snapshots::SnapshotManager snapshots(
asynchost::SnapshotManager snapshots(
config.snapshots.directory,
writer_factory,
config.snapshots.read_only_directory);
Expand Down Expand Up @@ -508,6 +507,8 @@ int main(int argc, char** argv)

ccf::StartupConfig startup_config(config);

startup_config.snapshot_tx_interval = config.snapshots.tx_count;

if (startup_config.attestation.snp_security_policy_file.has_value())
{
auto security_policy_file =
Expand Down Expand Up @@ -689,62 +690,22 @@ int main(int argc, char** argv)
config.command.type == StartType::Join ||
config.command.type == StartType::Recover)
{
auto latest_local_snapshot = snapshots.find_latest_committed_snapshot();

if (
config.command.type == StartType::Join &&
config.command.join.fetch_recent_snapshot)
auto latest_committed_snapshot =
snapshots.find_latest_committed_snapshot();
if (latest_committed_snapshot.has_value())
{
// Try to fetch a recent snapshot from peer
const size_t latest_local_idx = latest_local_snapshot.has_value() ?
snapshots::get_snapshot_idx_from_file_name(
latest_local_snapshot->second) :
0;
auto latest_peer_snapshot = snapshots::fetch_from_peer(
config.command.join.target_rpc_address,
config.command.service_certificate_file,
latest_local_idx);

if (latest_peer_snapshot.has_value())
{
LOG_INFO_FMT(
"Received snapshot {} from peer (size: {}) - writing this to disk "
"and using for join startup",
latest_peer_snapshot->snapshot_name,
latest_peer_snapshot->snapshot_data.size());

const auto dst_path = fs::path(config.snapshots.directory) /
fs::path(latest_peer_snapshot->snapshot_name);
if (files::exists(dst_path))
{
LOG_FATAL_FMT(
"Unable to write peer snapshot - already have a file at {}. "
"Exiting.",
dst_path);
return static_cast<int>(CLI::ExitCodes::FileError);
}
files::dump(latest_peer_snapshot->snapshot_data, dst_path);
startup_snapshot = latest_peer_snapshot->snapshot_data;
}
}
auto& [snapshot_dir, snapshot_file] = latest_committed_snapshot.value();
startup_snapshot = files::slurp(snapshot_dir / snapshot_file);

if (startup_snapshot.empty())
LOG_INFO_FMT(
"Found latest snapshot file: {} (size: {})",
snapshot_dir / snapshot_file,
startup_snapshot.size());
}
else
{
if (latest_local_snapshot.has_value())
{
auto& [snapshot_dir, snapshot_file] = latest_local_snapshot.value();
startup_snapshot = files::slurp(snapshot_dir / snapshot_file);

LOG_INFO_FMT(
"Found latest local snapshot file: {} (size: {})",
snapshot_dir / snapshot_file,
startup_snapshot.size());
}
else
{
LOG_INFO_FMT(
"No snapshot found: Node will replay all historical transactions");
}
LOG_INFO_FMT(
"No snapshot found: Node will replay all historical transactions");
}
}

Expand Down
Loading

0 comments on commit 21197eb

Please sign in to comment.