2#pragma clang diagnostic push
3#pragma clang diagnostic ignored "-Wdeprecated"
6#include <xrpld/core/Config.h>
7#include <xrpld/core/DatabaseCon.h>
8#include <xrpld/core/SociDB.h>
10#include <xrpl/basics/ByteUtilities.h>
11#include <xrpl/basics/contract.h>
13#include <boost/filesystem.hpp>
15#include <soci/sqlite3/soci-sqlite3.h>
30 Throw<std::runtime_error>(
"Sqlite databases must specify a dir and a name. Name: " + name +
" Dir: " + dir);
32 boost::filesystem::path file(dir);
33 if (is_directory(file))
41 auto const& section = config.
section(
"sqdb");
42 auto const backendName =
get(section,
"backend",
"sqlite");
44 if (backendName !=
"sqlite")
45 Throw<std::runtime_error>(
"Unsupported soci backend: " + backendName);
47 auto const path = config.
legacy(
"database_path");
48 auto const ext = dbName ==
"validators" || dbName ==
"peerfinder" ?
".sqlite" :
".db";
83 if (beName ==
"sqlite")
84 s.open(soci::sqlite3, connectionString);
86 Throw<std::runtime_error>(
"Unsupported soci backend: " + beName);
89static sqlite_api::sqlite3*
92 sqlite_api::sqlite3* result =
nullptr;
93 auto be = s.get_backend();
94 if (
auto b =
dynamic_cast<soci::sqlite3_session_backend*
>(be))
98 Throw<std::logic_error>(
"Didn't get a database connection.");
107 Throw<std::logic_error>(
"No connection found.");
108 return static_cast<size_t>(sqlite_api::sqlite3_memory_used() /
kilobytes(1));
117 int cur = 0, hiw = 0;
118 sqlite_api::sqlite3_db_status(conn, SQLITE_DBSTATUS_CACHE_USED, &cur, &hiw, 0);
121 Throw<std::logic_error>(
"");
128 to.
resize(from.get_len());
131 from.read(0,
reinterpret_cast<char*
>(&to[0]), from.get_len());
146 to.write(0,
reinterpret_cast<char const*
>(&from[0]), from.
size());
155 to.write(0, from.
data(), from.
size());
171class WALCheckpointer :
public Checkpointer
175 : id_(id), session_(
std::move(session)), jobQueue_(q), j_(logs.journal(
"WALCheckpointer"))
180 sqlite_api::sqlite3_wal_hook(conn, &sqliteWALHook,
reinterpret_cast<void*
>(id_));
187 if (
auto p = session_.lock())
200 ~WALCheckpointer()
override =
default;
213 if (!jobQueue_.addJob(
222 if (auto self = wp.lock())
232 checkpoint()
override
239 int log = 0, ckpt = 0;
240 int ret = sqlite3_wal_checkpoint_v2(conn,
nullptr, SQLITE_CHECKPOINT_PASSIVE, &log, &ckpt);
242 auto fname = sqlite3_db_filename(conn,
"main");
243 if (ret != SQLITE_OK)
245 auto jm = (ret == SQLITE_LOCKED) ? j_.trace() : j_.warn();
246 JLOG(jm) <<
"WAL(" << fname <<
"): error " << ret;
250 JLOG(j_.trace()) <<
"WAL(" << fname <<
"): frames=" <<
log <<
", written=" << ckpt;
266 bool running_ =
false;
270 sqliteWALHook(
void* cpId, sqlite_api::sqlite3* conn,
char const* dbName,
int walSize)
276 checkpointer->schedule();
280 sqlite_api::sqlite3_wal_hook(conn,
nullptr,
nullptr);
297#if defined(__clang__)
298#pragma clang diagnostic pop
A generic endpoint for log messages.
Holds unparsed configuration information.
void legacy(std::string const §ion, std::string value)
Set a value that is not a key/value pair.
Section & section(std::string const &name)
Returns the section with the given name.
DBConfig is used when a client wants to delay opening a soci::session after parsing the config parame...
void open(soci::session &s) const
std::string connectionString() const
std::string connectionString_
DBConfig(std::string const &dbPath)
A pool of threads to perform work.
Manages partitions for logging.
std::string getSociSqliteInit(std::string const &name, std::string const &dir, std::string const &ext)
std::string getSociInit(BasicConfig const &config, std::string const &dbName)
Use hash_* containers for keys that do not need a cryptographically secure hashing algorithm.
static auto checkpointPageCount
T get(Section const §ion, std::string const &name, T const &defaultValue=T{})
Retrieve a key/value pair from a section.
std::uint32_t getKBUsedDB(soci::session &s)
static sqlite_api::sqlite3 * getConnection(soci::session &s)
std::uint32_t getKBUsedAll(soci::session &s)
@ open
We haven't closed our ledger yet, but others might have.
std::shared_ptr< Checkpointer > makeCheckpointer(std::uintptr_t id, std::weak_ptr< soci::session > session, JobQueue &queue, Logs &logs)
Returns a new checkpointer which makes checkpoints of a soci database every checkpointPageCount pages...
constexpr auto kilobytes(T value) noexcept
void convert(soci::blob &from, std::vector< std::uint8_t > &to)
std::shared_ptr< Checkpointer > checkpointerFromId(std::uintptr_t id)