Add more chat list loading logging.
This commit is contained in:
parent
f8d1134ca2
commit
f925aca76e
@ -11479,6 +11479,7 @@ void MessagesManager::repair_server_dialog_total_count(DialogListId dialog_list_
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
LOG(INFO) << "Repair total chat count in " << dialog_list_id;
|
||||||
send_closure(td_->create_net_actor<GetDialogListActor>(Promise<Unit>()), &GetDialogListActor::send,
|
send_closure(td_->create_net_actor<GetDialogListActor>(Promise<Unit>()), &GetDialogListActor::send,
|
||||||
dialog_list_id.get_folder_id(), 2147483647, ServerMessageId(), DialogId(), 1,
|
dialog_list_id.get_folder_id(), 2147483647, ServerMessageId(), DialogId(), 1,
|
||||||
get_sequence_dispatcher_id(DialogId(), MessageContentType::None));
|
get_sequence_dispatcher_id(DialogId(), MessageContentType::None));
|
||||||
@ -14315,7 +14316,11 @@ void MessagesManager::on_get_dialogs(FolderId folder_id, vector<tl_object_ptr<te
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
LOG(INFO) << "Receive " << dialogs.size() << " chats out of " << total_count << " in " << folder_id;
|
if (from_get_dialog) {
|
||||||
|
LOG(INFO) << "Process " << dialogs.size() << " chats";
|
||||||
|
} else {
|
||||||
|
LOG(INFO) << "Process " << dialogs.size() << " chats out of " << total_count << " in " << folder_id;
|
||||||
|
}
|
||||||
std::unordered_map<FullMessageId, DialogDate, FullMessageIdHash> full_message_id_to_dialog_date;
|
std::unordered_map<FullMessageId, DialogDate, FullMessageIdHash> full_message_id_to_dialog_date;
|
||||||
std::unordered_map<FullMessageId, tl_object_ptr<telegram_api::Message>, FullMessageIdHash> full_message_id_to_message;
|
std::unordered_map<FullMessageId, tl_object_ptr<telegram_api::Message>, FullMessageIdHash> full_message_id_to_message;
|
||||||
for (auto &message : messages) {
|
for (auto &message : messages) {
|
||||||
@ -14621,7 +14626,7 @@ void MessagesManager::on_get_dialogs(FolderId folder_id, vector<tl_object_ptr<te
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (need_new_get_dialog_list) {
|
if (need_new_get_dialog_list) {
|
||||||
LOG(INFO) << "Schedule chats list load in " << folder_id;
|
LOG(INFO) << "Schedule chat list load in " << folder_id;
|
||||||
auto &multipromise = folder->load_folder_dialog_list_multipromise_;
|
auto &multipromise = folder->load_folder_dialog_list_multipromise_;
|
||||||
multipromise.add_promise(PromiseCreator::lambda([actor_id = actor_id(this), folder_id](Result<Unit> result) {
|
multipromise.add_promise(PromiseCreator::lambda([actor_id = actor_id(this), folder_id](Result<Unit> result) {
|
||||||
if (result.is_ok()) {
|
if (result.is_ok()) {
|
||||||
@ -14697,6 +14702,7 @@ void MessagesManager::on_get_dialogs(FolderId folder_id, vector<tl_object_ptr<te
|
|||||||
promise.set_value(Unit());
|
promise.set_value(Unit());
|
||||||
|
|
||||||
if (need_recalc_unread_count) {
|
if (need_recalc_unread_count) {
|
||||||
|
CHECK(from_dialog_list || from_pinned_dialog_list);
|
||||||
recalc_unread_count(DialogListId(folder_id));
|
recalc_unread_count(DialogListId(folder_id));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -15699,6 +15705,9 @@ vector<DialogId> MessagesManager::get_dialogs(DialogListId dialog_list_id, Dialo
|
|||||||
promise.set_value(Unit());
|
promise.set_value(Unit());
|
||||||
return result;
|
return result;
|
||||||
} else {
|
} else {
|
||||||
|
if (!result.empty()) {
|
||||||
|
LOG(INFO) << "Have only " << result.size() << " chats, but " << limit << " chats more are needed";
|
||||||
|
}
|
||||||
load_dialog_list(list, limit, std::move(promise));
|
load_dialog_list(list, limit, std::move(promise));
|
||||||
return {};
|
return {};
|
||||||
}
|
}
|
||||||
@ -15744,15 +15753,17 @@ void MessagesManager::load_folder_dialog_list(FolderId folder_id, int32 limit, b
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
LOG(INFO) << "Load dialog list in " << folder_id << " with limit " << limit;
|
|
||||||
auto &multipromise = folder.load_folder_dialog_list_multipromise_;
|
auto &multipromise = folder.load_folder_dialog_list_multipromise_;
|
||||||
if (multipromise.promise_count() != 0) {
|
if (multipromise.promise_count() != 0) {
|
||||||
// queries have already been sent, just wait for the result
|
// queries have already been sent, just wait for the result
|
||||||
|
LOG(INFO) << "Skip loading of dialog list in " << folder_id << " with limit " << limit
|
||||||
|
<< ", because it is already being loaded";
|
||||||
if (use_database && folder.load_dialog_list_limit_max_ != 0) {
|
if (use_database && folder.load_dialog_list_limit_max_ != 0) {
|
||||||
folder.load_dialog_list_limit_max_ = max(folder.load_dialog_list_limit_max_, limit);
|
folder.load_dialog_list_limit_max_ = max(folder.load_dialog_list_limit_max_, limit);
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
LOG(INFO) << "Load dialog list in " << folder_id << " with limit " << limit;
|
||||||
multipromise.add_promise(PromiseCreator::lambda([actor_id = actor_id(this), folder_id](Result<Unit> result) {
|
multipromise.add_promise(PromiseCreator::lambda([actor_id = actor_id(this), folder_id](Result<Unit> result) {
|
||||||
if (result.is_error()) {
|
if (result.is_error()) {
|
||||||
send_closure(actor_id, &MessagesManager::on_load_folder_dialog_list_fail, folder_id, result.move_as_error());
|
send_closure(actor_id, &MessagesManager::on_load_folder_dialog_list_fail, folder_id, result.move_as_error());
|
||||||
@ -15956,7 +15967,8 @@ void MessagesManager::get_dialogs_from_list_impl(int64 task_id) {
|
|||||||
auto dialog_ids = get_dialogs(task.dialog_list_id, MIN_DIALOG_DATE, task.limit, true, false, std::move(promise));
|
auto dialog_ids = get_dialogs(task.dialog_list_id, MIN_DIALOG_DATE, task.limit, true, false, std::move(promise));
|
||||||
auto &list = *get_dialog_list(task.dialog_list_id);
|
auto &list = *get_dialog_list(task.dialog_list_id);
|
||||||
auto total_count = get_dialog_total_count(list);
|
auto total_count = get_dialog_total_count(list);
|
||||||
LOG(INFO) << "Receive " << dialog_ids.size() << " chats out of " << total_count << "/" << task.limit;
|
LOG(INFO) << "Receive " << dialog_ids.size() << " chats out of " << total_count << "/" << task.limit << " in "
|
||||||
|
<< task.dialog_list_id;
|
||||||
CHECK(dialog_ids.size() <= static_cast<size_t>(total_count));
|
CHECK(dialog_ids.size() <= static_cast<size_t>(total_count));
|
||||||
CHECK(dialog_ids.size() <= static_cast<size_t>(task.limit));
|
CHECK(dialog_ids.size() <= static_cast<size_t>(task.limit));
|
||||||
if (dialog_ids.size() == static_cast<size_t>(min(total_count, task.limit)) ||
|
if (dialog_ids.size() == static_cast<size_t>(min(total_count, task.limit)) ||
|
||||||
@ -15974,11 +15986,13 @@ void MessagesManager::get_dialogs_from_list_impl(int64 task_id) {
|
|||||||
void MessagesManager::on_get_dialogs_from_list(int64 task_id, Result<Unit> &&result) {
|
void MessagesManager::on_get_dialogs_from_list(int64 task_id, Result<Unit> &&result) {
|
||||||
auto task_it = get_dialogs_tasks_.find(task_id);
|
auto task_it = get_dialogs_tasks_.find(task_id);
|
||||||
if (task_it == get_dialogs_tasks_.end()) {
|
if (task_it == get_dialogs_tasks_.end()) {
|
||||||
// the task has already been completed successfully
|
// the task has already been completed
|
||||||
|
LOG(INFO) << "Chat list load task " << task_id << " has already been completed";
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
auto &task = task_it->second;
|
auto &task = task_it->second;
|
||||||
if (result.is_error()) {
|
if (result.is_error()) {
|
||||||
|
LOG(INFO) << "Chat list load task " << task_id << " failed with the error " << result.error();
|
||||||
auto task_promise = std::move(task.promise);
|
auto task_promise = std::move(task.promise);
|
||||||
get_dialogs_tasks_.erase(task_it);
|
get_dialogs_tasks_.erase(task_it);
|
||||||
return task_promise.set_error(result.move_as_error());
|
return task_promise.set_error(result.move_as_error());
|
||||||
|
@ -125,7 +125,7 @@ void StorageManager::run_gc(FileGcParameters parameters, bool return_deleted_fil
|
|||||||
std::move(file_stats));
|
std::move(file_stats));
|
||||||
}));
|
}));
|
||||||
|
|
||||||
//NB: get_storage_stats will cancel all gc queries, so promise needs to be added after the call
|
//NB: get_storage_stats will cancel all garbage collection queries, so promise needs to be added after the call
|
||||||
pending_run_gc_[return_deleted_file_statistics].push_back(std::move(promise));
|
pending_run_gc_[return_deleted_file_statistics].push_back(std::move(promise));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -331,7 +331,7 @@ void StorageManager::schedule_next_gc() {
|
|||||||
!G()->parameters().enable_storage_optimizer) {
|
!G()->parameters().enable_storage_optimizer) {
|
||||||
next_gc_at_ = 0;
|
next_gc_at_ = 0;
|
||||||
cancel_timeout();
|
cancel_timeout();
|
||||||
LOG(INFO) << "No next file gc is scheduled";
|
LOG(INFO) << "No next file clean up is scheduled";
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
auto sys_time = static_cast<uint32>(Clocks::system());
|
auto sys_time = static_cast<uint32>(Clocks::system());
|
||||||
@ -347,7 +347,7 @@ void StorageManager::schedule_next_gc() {
|
|||||||
CHECK(next_gc_at >= sys_time);
|
CHECK(next_gc_at >= sys_time);
|
||||||
auto next_gc_in = next_gc_at - sys_time;
|
auto next_gc_in = next_gc_at - sys_time;
|
||||||
|
|
||||||
LOG(INFO) << "Schedule next file gc in " << next_gc_in;
|
LOG(INFO) << "Schedule next file clean up in " << next_gc_in;
|
||||||
next_gc_at_ = Time::now() + next_gc_in;
|
next_gc_at_ = Time::now() + next_gc_in;
|
||||||
set_timeout_at(next_gc_at_);
|
set_timeout_at(next_gc_at_);
|
||||||
}
|
}
|
||||||
@ -363,7 +363,7 @@ void StorageManager::timeout_expired() {
|
|||||||
next_gc_at_ = 0;
|
next_gc_at_ = 0;
|
||||||
run_gc({}, false, PromiseCreator::lambda([actor_id = actor_id(this)](Result<FileStats> r_stats) {
|
run_gc({}, false, PromiseCreator::lambda([actor_id = actor_id(this)](Result<FileStats> r_stats) {
|
||||||
if (!r_stats.is_error() || r_stats.error().code() != 500) {
|
if (!r_stats.is_error() || r_stats.error().code() != 500) {
|
||||||
// do not save gc timestamp if request was canceled
|
// do not save garbage collection timestamp if request was canceled
|
||||||
send_closure(actor_id, &StorageManager::save_last_gc_timestamp);
|
send_closure(actor_id, &StorageManager::save_last_gc_timestamp);
|
||||||
}
|
}
|
||||||
send_closure(actor_id, &StorageManager::schedule_next_gc);
|
send_closure(actor_id, &StorageManager::schedule_next_gc);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user