mirror of
https://github.com/tdlight-team/tdlight-telegram-bot-api.git
synced 2024-12-19 17:17:48 +01:00
Add watchdog for ClientManager's thread.
This commit is contained in:
parent
04825c4b70
commit
337b657f9c
@ -352,6 +352,11 @@ void ClientManager::start_up() {
|
|||||||
auto query = get_webhook_restore_query(key_value.first, key_value.second, parameters_->shared_data_);
|
auto query = get_webhook_restore_query(key_value.first, key_value.second, parameters_->shared_data_);
|
||||||
send_closure_later(actor_id(this), &ClientManager::send, std::move(query));
|
send_closure_later(actor_id(this), &ClientManager::send, std::move(query));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// launch watchdog
|
||||||
|
watchdog_id_ = td::create_actor_on_scheduler<Watchdog>(
|
||||||
|
"ManagerWatchdog", td::Scheduler::instance()->sched_count() - 3, td::this_thread::get_id(), WATCHDOG_TIMEOUT);
|
||||||
|
set_timeout_in(600.0);
|
||||||
}
|
}
|
||||||
|
|
||||||
PromisedQueryPtr ClientManager::get_webhook_restore_query(td::Slice token, td::Slice webhook_info,
|
PromisedQueryPtr ClientManager::get_webhook_restore_query(td::Slice token, td::Slice webhook_info,
|
||||||
@ -429,6 +434,11 @@ void ClientManager::raw_event(const td::Event::Raw &event) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void ClientManager::timeout_expired() {
|
||||||
|
send_closure(watchdog_id_, &Watchdog::kick);
|
||||||
|
set_timeout_in(WATCHDOG_TIMEOUT / 2);
|
||||||
|
}
|
||||||
|
|
||||||
void ClientManager::hangup_shared() {
|
void ClientManager::hangup_shared() {
|
||||||
auto id = get_link_token();
|
auto id = get_link_token();
|
||||||
auto *info = clients_.get(id);
|
auto *info = clients_.get(id);
|
||||||
@ -458,6 +468,7 @@ void ClientManager::close_db() {
|
|||||||
|
|
||||||
void ClientManager::finish_close() {
|
void ClientManager::finish_close() {
|
||||||
LOG(WARNING) << "Stop ClientManager";
|
LOG(WARNING) << "Stop ClientManager";
|
||||||
|
watchdog_id_.reset();
|
||||||
auto promises = std::move(close_promises_);
|
auto promises = std::move(close_promises_);
|
||||||
for (auto &promise : promises) {
|
for (auto &promise : promises) {
|
||||||
promise.set_value(td::Unit());
|
promise.set_value(td::Unit());
|
||||||
@ -465,4 +476,6 @@ void ClientManager::finish_close() {
|
|||||||
stop();
|
stop();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
constexpr double ClientManager::WATCHDOG_TIMEOUT;
|
||||||
|
|
||||||
} // namespace telegram_bot_api
|
} // namespace telegram_bot_api
|
||||||
|
@ -9,6 +9,7 @@
|
|||||||
#include "telegram-bot-api/Client.h"
|
#include "telegram-bot-api/Client.h"
|
||||||
#include "telegram-bot-api/Query.h"
|
#include "telegram-bot-api/Query.h"
|
||||||
#include "telegram-bot-api/Stats.h"
|
#include "telegram-bot-api/Stats.h"
|
||||||
|
#include "telegram-bot-api/Watchdog.h"
|
||||||
|
|
||||||
#include "td/actor/actor.h"
|
#include "td/actor/actor.h"
|
||||||
|
|
||||||
@ -68,6 +69,10 @@ class ClientManager final : public td::Actor {
|
|||||||
bool close_flag_ = false;
|
bool close_flag_ = false;
|
||||||
td::vector<td::Promise<td::Unit>> close_promises_;
|
td::vector<td::Promise<td::Unit>> close_promises_;
|
||||||
|
|
||||||
|
td::ActorOwn<Watchdog> watchdog_id_;
|
||||||
|
|
||||||
|
static constexpr double WATCHDOG_TIMEOUT = 0.5;
|
||||||
|
|
||||||
static td::int64 get_tqueue_id(td::int64 user_id, bool is_test_dc);
|
static td::int64 get_tqueue_id(td::int64 user_id, bool is_test_dc);
|
||||||
|
|
||||||
static PromisedQueryPtr get_webhook_restore_query(td::Slice token, td::Slice webhook_info,
|
static PromisedQueryPtr get_webhook_restore_query(td::Slice token, td::Slice webhook_info,
|
||||||
@ -75,6 +80,7 @@ class ClientManager final : public td::Actor {
|
|||||||
|
|
||||||
void start_up() final;
|
void start_up() final;
|
||||||
void raw_event(const td::Event::Raw &event) final;
|
void raw_event(const td::Event::Raw &event) final;
|
||||||
|
void timeout_expired() final;
|
||||||
void hangup_shared() final;
|
void hangup_shared() final;
|
||||||
void close_db();
|
void close_db();
|
||||||
void finish_close();
|
void finish_close();
|
||||||
|
@ -13,7 +13,7 @@ namespace telegram_bot_api {
|
|||||||
void Watchdog::kick() {
|
void Watchdog::kick() {
|
||||||
auto now = td::Time::now();
|
auto now = td::Time::now();
|
||||||
if (now >= last_kick_time_ + timeout_ && last_kick_time_ > 0) {
|
if (now >= last_kick_time_ + timeout_ && last_kick_time_ > 0) {
|
||||||
LOG(ERROR) << "Watchdog timeout expired after " << now - last_kick_time_ << " seconds";
|
LOG(ERROR) << get_name() << " timeout expired after " << now - last_kick_time_ << " seconds";
|
||||||
td::thread::send_real_time_signal(main_thread_id_, 2);
|
td::thread::send_real_time_signal(main_thread_id_, 2);
|
||||||
}
|
}
|
||||||
last_kick_time_ = now;
|
last_kick_time_ = now;
|
||||||
|
@ -506,7 +506,7 @@ int main(int argc, char *argv[]) {
|
|||||||
|
|
||||||
// +3 threads for Td
|
// +3 threads for Td
|
||||||
// one thread for ClientManager and all Clients
|
// one thread for ClientManager and all Clients
|
||||||
// one thread for watchdog
|
// one thread for watchdogs
|
||||||
// one thread for slow HTTP connections
|
// one thread for slow HTTP connections
|
||||||
// one thread for DNS resolving
|
// one thread for DNS resolving
|
||||||
const int thread_count = 7;
|
const int thread_count = 7;
|
||||||
|
Loading…
Reference in New Issue
Block a user