2015-09-29 19:21:02 +00:00
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
|
|
#include <Poco/ErrorHandler.h>
|
|
|
|
|
#include <common/logger_useful.h>
|
2016-01-14 03:17:11 +00:00
|
|
|
|
#include <DB/Common/Exception.h>
|
2015-09-29 19:21:02 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/** ErrorHandler для потоков, который в случае неперехваченного исключения,
|
|
|
|
|
* выводит ошибку в лог и завершает демон.
|
|
|
|
|
*/
|
|
|
|
|
class KillingErrorHandler : public Poco::ErrorHandler
|
|
|
|
|
{
|
|
|
|
|
public:
|
|
|
|
|
void exception(const Poco::Exception & e) { std::terminate(); }
|
|
|
|
|
void exception(const std::exception & e) { std::terminate(); }
|
|
|
|
|
void exception() { std::terminate(); }
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
2016-01-14 03:17:11 +00:00
|
|
|
|
/** Выводит информацию об исключении в лог.
|
2015-09-29 19:21:02 +00:00
|
|
|
|
*/
|
2016-01-14 03:17:11 +00:00
|
|
|
|
class ServerErrorHandler : public Poco::ErrorHandler
|
2015-09-29 19:21:02 +00:00
|
|
|
|
{
|
|
|
|
|
public:
|
2016-01-14 03:17:11 +00:00
|
|
|
|
void exception(const Poco::Exception & e) { logException(); }
|
|
|
|
|
void exception(const std::exception & e) { logException(); }
|
|
|
|
|
void exception() { logException(); }
|
2015-09-29 19:21:02 +00:00
|
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
Logger * log = &Logger::get("ServerErrorHandler");
|
2016-01-14 03:17:11 +00:00
|
|
|
|
|
|
|
|
|
void logException()
|
|
|
|
|
{
|
|
|
|
|
DB::tryLogCurrentException(log);
|
|
|
|
|
}
|
2015-09-29 19:21:02 +00:00
|
|
|
|
};
|