0
0
Fork 0
mirror of https://github.com/matrix-construct/construct synced 2025-01-14 16:46:50 +01:00

ircd::db: Add error report state w/ interface w/ console cmd.

This commit is contained in:
Jason Volk 2018-10-31 15:29:00 -07:00
parent 0f7e17a519
commit 5dcc7cd93b
3 changed files with 88 additions and 7 deletions

View file

@ -19,6 +19,7 @@ namespace ircd::db
const std::string &name(const database &); const std::string &name(const database &);
const std::string &uuid(const database &); const std::string &uuid(const database &);
uint64_t sequence(const database &); // Latest sequence number uint64_t sequence(const database &); // Latest sequence number
const std::vector<std::string> &errors(const database &);
std::vector<std::string> files(const database &, uint64_t &msz); std::vector<std::string> files(const database &, uint64_t &msz);
std::vector<std::string> files(const database &); std::vector<std::string> files(const database &);
size_t file_count(const database &); size_t file_count(const database &);
@ -100,6 +101,7 @@ struct ircd::db::database
std::list<std::shared_ptr<column>> columns; // active only std::list<std::shared_ptr<column>> columns; // active only
std::string uuid; std::string uuid;
std::unique_ptr<rocksdb::Checkpoint> checkpointer; std::unique_ptr<rocksdb::Checkpoint> checkpointer;
std::vector<std::string> errors;
operator std::shared_ptr<database>() { return shared_from_this(); } operator std::shared_ptr<database>() { return shared_from_this(); }
operator const rocksdb::DB &() const { return *d; } operator const rocksdb::DB &() const { return *d; }

View file

@ -379,10 +379,16 @@ ircd::db::resume(database &d)
assert(d.d); assert(d.d);
const ctx::uninterruptible::nothrow ui; const ctx::uninterruptible::nothrow ui;
const std::lock_guard<decltype(write_mutex)> lock{write_mutex}; const std::lock_guard<decltype(write_mutex)> lock{write_mutex};
const auto errors
{
db::errors(d)
};
log::debug log::debug
{ {
log, "'%s': Attempting to resume @%lu", log, "'%s': Attempting to resume from %zu errors @%lu",
name(d), name(d),
errors.size(),
sequence(d) sequence(d)
}; };
@ -391,11 +397,14 @@ ircd::db::resume(database &d)
d.d->Resume() d.d->Resume()
}; };
d.errors.clear();
log::info log::info
{ {
log, "'%s': Resumed normal operation at sequence number %lu.", log, "'%s': Resumed normal operation at sequence number %lu; cleared %zu errors",
name(d), name(d),
sequence(d) sequence(d),
errors.size()
}; };
} }
@ -537,6 +546,12 @@ ircd::db::files(const database &cd,
return ret; return ret;
} }
const std::vector<std::string> &
ircd::db::errors(const database &d)
{
return d.errors;
}
uint64_t uint64_t
ircd::db::sequence(const database &cd) ircd::db::sequence(const database &cd)
{ {
@ -2371,15 +2386,17 @@ ircd::db::database::events::OnBackgroundError(rocksdb::BackgroundErrorReason rea
rocksdb::Status *const status) rocksdb::Status *const status)
noexcept noexcept
{ {
assert(d);
assert(status); assert(status);
log::error
thread_local char buf[1024];
const string_view str{fmt::sprintf
{ {
rog, "'%s' background %s error in %s :%s", buf, "%s error in %s :%s",
d->name,
reflect(status->severity()), reflect(status->severity()),
reflect(reason), reflect(reason),
status->ToString() status->ToString()
}; }};
// This is a legitimate when we want to use it. If the error is not // This is a legitimate when we want to use it. If the error is not
// suppressed the DB will enter read-only mode and will require a // suppressed the DB will enter read-only mode and will require a
@ -2389,8 +2406,25 @@ noexcept
false false
}; };
const log::facility fac
{
ignore?
log::facility::DERROR:
log::facility::ERROR
};
log::logf
{
log, fac, "'%s': %s", d->name, str
};
if(ignore) if(ignore)
{
*status = rocksdb::Status::OK(); *status = rocksdb::Status::OK();
return;
}
d->errors.emplace_back(str);
} }
void void

View file

@ -1352,6 +1352,42 @@ catch(const std::out_of_range &e)
return true; return true;
} }
bool
console_cmd__db__errors(opt &out, const string_view &line)
try
{
const params param{line, " ",
{
"dbname",
}};
const auto dbname
{
param.at("dbname")
};
auto &database
{
db::database::get(dbname)
};
const auto &errors
{
db::errors(database)
};
size_t i(0);
for(const auto &error : errors)
out << std::setw(2) << std::left << (i++) << ':' << error << std::endl;
return true;
}
catch(const std::out_of_range &e)
{
out << "No open database by that name" << std::endl;
return true;
}
bool bool
console_cmd__db__ticker(opt &out, const string_view &line) console_cmd__db__ticker(opt &out, const string_view &line)
try try
@ -2930,6 +2966,15 @@ try
} }
} }
if(!c && !errors(d).empty())
{
size_t i(0);
out << std::endl;
out << "ERRORS (" << errors(d).size() << "): " << std::endl;
for(const auto &error : errors(d))
out << std::setw(2) << (i++) << ':' << error << std::endl;
}
return true; return true;
} }
catch(const std::out_of_range &e) catch(const std::out_of_range &e)