Clio develop
The XRP Ledger API server.
Loading...
Searching...
No Matches
CacheLoader.hpp
1//------------------------------------------------------------------------------
2/*
3 This file is part of clio: https://github.com/XRPLF/clio
4 Copyright (c) 2024, the clio developers.
5
6 Permission to use, copy, modify, and distribute this software for any
7 purpose with or without fee is hereby granted, provided that the above
8 copyright notice and this permission notice appear in all copies.
9
10 THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
11 WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
12 MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
13 ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
14 WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
15 ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
16 OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
17*/
18//==============================================================================
19
20#pragma once
21
22#include "data/BackendInterface.hpp"
23#include "data/LedgerCacheInterface.hpp"
24#include "etl/CacheLoaderSettings.hpp"
25#include "etl/impl/CacheLoader.hpp"
26#include "etl/impl/CursorFromAccountProvider.hpp"
27#include "etl/impl/CursorFromDiffProvider.hpp"
28#include "etl/impl/CursorFromFixDiffNumProvider.hpp"
29#include "etlng/CacheLoaderInterface.hpp"
30#include "util/Assert.hpp"
31#include "util/async/context/BasicExecutionContext.hpp"
32#include "util/log/Logger.hpp"
33
34#include <cstdint>
35#include <functional>
36#include <memory>
37#include <utility>
38
39namespace etl {
40
50template <typename ExecutionContextType = util::async::CoroExecutionContext>
53
54 util::Logger log_{"ETL"};
55 std::shared_ptr<BackendInterface> backend_;
56 std::reference_wrapper<data::LedgerCacheInterface> cache_;
57
58 CacheLoaderSettings settings_;
59 ExecutionContextType ctx_;
60 std::unique_ptr<CacheLoaderType> loader_;
61
62public:
72 std::shared_ptr<BackendInterface> backend,
74 )
75 : backend_{std::move(backend)}
76 , cache_{cache}
77 , settings_{makeCacheLoaderSettings(config)}
78 , ctx_{settings_.numThreads}
79 {
80 }
81
90 void
91 load(uint32_t const seq) override
92 {
93 ASSERT(not cache_.get().isFull(), "Cache must not be full. seq = {}", seq);
94
95 if (settings_.isDisabled()) {
96 cache_.get().setDisabled();
97 LOG(log_.warn()) << "Cache is disabled. Not loading";
98 return;
99 }
100
101 std::shared_ptr<impl::BaseCursorProvider> provider;
102 if (settings_.numCacheCursorsFromDiff != 0) {
103 LOG(log_.info()) << "Loading cache with cursor from num_cursors_from_diff="
104 << settings_.numCacheCursorsFromDiff;
105 provider = std::make_shared<impl::CursorFromDiffProvider>(backend_, settings_.numCacheCursorsFromDiff);
106 } else if (settings_.numCacheCursorsFromAccount != 0) {
107 LOG(log_.info()) << "Loading cache with cursor from num_cursors_from_account="
108 << settings_.numCacheCursorsFromAccount;
109 provider = std::make_shared<impl::CursorFromAccountProvider>(
110 backend_, settings_.numCacheCursorsFromAccount, settings_.cachePageFetchSize
111 );
112 } else {
113 LOG(log_.info()) << "Loading cache with cursor from num_diffs=" << settings_.numCacheDiffs;
114 provider = std::make_shared<impl::CursorFromFixDiffNumProvider>(backend_, settings_.numCacheDiffs);
115 }
116
117 loader_ = std::make_unique<CacheLoaderType>(
118 ctx_,
119 backend_,
120 cache_,
121 seq,
122 settings_.numCacheMarkers,
123 settings_.cachePageFetchSize,
124 provider->getCursors(seq)
125 );
126
127 if (settings_.isSync()) {
128 loader_->wait();
129 ASSERT(cache_.get().isFull(), "Cache must be full after sync load. seq = {}", seq);
130 }
131 }
132
136 void
137 stop() noexcept override
138 {
139 if (loader_ != nullptr)
140 loader_->stop();
141 }
142
146 void
147 wait() noexcept override
148 {
149 if (loader_ != nullptr)
150 loader_->wait();
151 }
152};
153
154} // namespace etl
Cache for an entire ledger.
Definition LedgerCacheInterface.hpp:38
Cache loading interface.
Definition CacheLoader.hpp:51
void load(uint32_t const seq) override
Load the cache for the given sequence number.
Definition CacheLoader.hpp:91
void stop() noexcept override
Requests the loader to stop asap.
Definition CacheLoader.hpp:137
void wait() noexcept override
Waits for the loader to finish background work.
Definition CacheLoader.hpp:147
CacheLoader(util::config::ClioConfigDefinition const &config, std::shared_ptr< BackendInterface > backend, data::LedgerCacheInterface &cache)
Construct a new Cache Loader object.
Definition CacheLoader.hpp:70
Definition CacheLoader.hpp:49
A simple thread-safe logger for the channel specified in the constructor.
Definition Logger.hpp:111
Pump warn(SourceLocationType const &loc=CURRENT_SRC_LOCATION) const
Interface for logging at Severity::WRN severity.
Definition Logger.cpp:224
Pump info(SourceLocationType const &loc=CURRENT_SRC_LOCATION) const
Interface for logging at Severity::NFO severity.
Definition Logger.cpp:219
All the config data will be stored and extracted from this class.
Definition ConfigDefinition.hpp:54
This namespace contains everything to do with the ETL and ETL sources.
Definition CacheLoader.hpp:39
CacheLoaderSettings makeCacheLoaderSettings(util::config::ClioConfigDefinition const &config)
Create a CacheLoaderSettings object from a Config object.
Definition CacheLoaderSettings.cpp:51
Settings for the cache loader.
Definition CacheLoaderSettings.hpp:31
bool isDisabled() const
Definition CacheLoaderSettings.cpp:45
bool isSync() const
Definition CacheLoaderSettings.cpp:33
size_t numCacheMarkers
Definition CacheLoaderSettings.hpp:36
size_t numCacheCursorsFromAccount
Definition CacheLoaderSettings.hpp:40
size_t cachePageFetchSize
Definition CacheLoaderSettings.hpp:37
size_t numCacheDiffs
Definition CacheLoaderSettings.hpp:35
size_t numCacheCursorsFromDiff
Definition CacheLoaderSettings.hpp:39
An interface for the Cache Loader.
Definition CacheLoaderInterface.hpp:29