Send download queries with a small delay (turned off)
GitOrigin-RevId: 91932bb550176ee7d9ff22621e86a42ac6be9317
This commit is contained in:
parent
d96aab7aeb
commit
43fc3a21df
@ -328,6 +328,7 @@ set(TDLIB_SOURCE
|
|||||||
td/telegram/ConfigShared.cpp
|
td/telegram/ConfigShared.cpp
|
||||||
td/telegram/Contact.cpp
|
td/telegram/Contact.cpp
|
||||||
td/telegram/ContactsManager.cpp
|
td/telegram/ContactsManager.cpp
|
||||||
|
td/telegram/DelayDispatcher.cpp
|
||||||
td/telegram/DeviceTokenManager.cpp
|
td/telegram/DeviceTokenManager.cpp
|
||||||
td/telegram/DhCache.cpp
|
td/telegram/DhCache.cpp
|
||||||
td/telegram/DialogDb.cpp
|
td/telegram/DialogDb.cpp
|
||||||
@ -431,6 +432,7 @@ set(TDLIB_SOURCE
|
|||||||
td/telegram/ConfigShared.h
|
td/telegram/ConfigShared.h
|
||||||
td/telegram/Contact.h
|
td/telegram/Contact.h
|
||||||
td/telegram/ContactsManager.h
|
td/telegram/ContactsManager.h
|
||||||
|
td/telegram/DelayDispatcher.h
|
||||||
td/telegram/DeviceTokenManager.h
|
td/telegram/DeviceTokenManager.h
|
||||||
td/telegram/DhCache.h
|
td/telegram/DhCache.h
|
||||||
td/telegram/DhConfig.h
|
td/telegram/DhConfig.h
|
||||||
|
40
td/telegram/DelayDispatcher.cpp
Normal file
40
td/telegram/DelayDispatcher.cpp
Normal file
@ -0,0 +1,40 @@
|
|||||||
|
//
|
||||||
|
// Copyright Aliaksei Levin (levlam@telegram.org), Arseny Smirnov (arseny30@gmail.com) 2014-2018
|
||||||
|
//
|
||||||
|
// Distributed under the Boost Software License, Version 1.0. (See accompanying
|
||||||
|
// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
||||||
|
//
|
||||||
|
#include "td/telegram/DelayDispatcher.h"
|
||||||
|
|
||||||
|
#include "td/telegram/Global.h"
|
||||||
|
#include "td/telegram/net/NetQueryDispatcher.h"
|
||||||
|
|
||||||
|
namespace td {
|
||||||
|
void DelayDispatcher::send_with_callback(NetQueryPtr query, ActorShared<NetQueryCallback> callback) {
|
||||||
|
queue_.push({std::move(query), std::move(callback)});
|
||||||
|
loop();
|
||||||
|
}
|
||||||
|
|
||||||
|
void DelayDispatcher::loop() {
|
||||||
|
if (!wakeup_at_.is_in_past()) {
|
||||||
|
set_timeout_at(wakeup_at_.at());
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (queue_.empty()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
auto query = std::move(queue_.front());
|
||||||
|
queue_.pop();
|
||||||
|
G()->net_query_dispatcher().dispatch_with_callback(std::move(query.net_query), std::move(query.callback));
|
||||||
|
|
||||||
|
wakeup_at_ = Timestamp::in(DELAY);
|
||||||
|
|
||||||
|
if (queue_.empty()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
set_timeout_at(wakeup_at_.at());
|
||||||
|
}
|
||||||
|
} // namespace td
|
31
td/telegram/DelayDispatcher.h
Normal file
31
td/telegram/DelayDispatcher.h
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
//
|
||||||
|
// Copyright Aliaksei Levin (levlam@telegram.org), Arseny Smirnov (arseny30@gmail.com) 2014-2018
|
||||||
|
//
|
||||||
|
// Distributed under the Boost Software License, Version 1.0. (See accompanying
|
||||||
|
// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
||||||
|
//
|
||||||
|
#pragma once
|
||||||
|
#include "td/telegram/net/NetQuery.h"
|
||||||
|
|
||||||
|
#include "td/actor/actor.h"
|
||||||
|
#include "td/utils/Time.h"
|
||||||
|
|
||||||
|
#include <queue>
|
||||||
|
|
||||||
|
namespace td {
|
||||||
|
class DelayDispatcher : public Actor {
|
||||||
|
public:
|
||||||
|
void send_with_callback(NetQueryPtr query, ActorShared<NetQueryCallback> callback);
|
||||||
|
|
||||||
|
private:
|
||||||
|
struct Query {
|
||||||
|
NetQueryPtr net_query;
|
||||||
|
ActorShared<NetQueryCallback> callback;
|
||||||
|
};
|
||||||
|
std::queue<Query> queue_;
|
||||||
|
Timestamp wakeup_at_;
|
||||||
|
static constexpr double DELAY = 0.000;
|
||||||
|
|
||||||
|
void loop() override;
|
||||||
|
};
|
||||||
|
} // namespace td
|
@ -93,7 +93,8 @@ Result<FileLoader::FileInfo> FileDownloader::init() {
|
|||||||
res.part_size = part_size;
|
res.part_size = part_size;
|
||||||
res.ready_parts = std::move(parts);
|
res.ready_parts = std::move(parts);
|
||||||
res.use_part_count_limit = false;
|
res.use_part_count_limit = false;
|
||||||
res.only_check_ = only_check_;
|
res.only_check = only_check_;
|
||||||
|
res.need_delay = !is_small_;
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
Status FileDownloader::on_ok(int64 size) {
|
Status FileDownloader::on_ok(int64 size) {
|
||||||
|
@ -78,7 +78,7 @@ void FileLoader::start_up() {
|
|||||||
auto &ready_parts = file_info.ready_parts;
|
auto &ready_parts = file_info.ready_parts;
|
||||||
auto use_part_count_limit = file_info.use_part_count_limit;
|
auto use_part_count_limit = file_info.use_part_count_limit;
|
||||||
auto status = parts_manager_.init(size, expected_size, is_size_final, part_size, ready_parts, use_part_count_limit);
|
auto status = parts_manager_.init(size, expected_size, is_size_final, part_size, ready_parts, use_part_count_limit);
|
||||||
if (file_info.only_check_) {
|
if (file_info.only_check) {
|
||||||
parts_manager_.set_checked_prefix_size(0);
|
parts_manager_.set_checked_prefix_size(0);
|
||||||
}
|
}
|
||||||
if (status.is_error()) {
|
if (status.is_error()) {
|
||||||
@ -89,6 +89,9 @@ void FileLoader::start_up() {
|
|||||||
if (ordered_flag_) {
|
if (ordered_flag_) {
|
||||||
ordered_parts_ = OrderedEventsProcessor<std::pair<Part, NetQueryPtr>>(parts_manager_.get_ready_prefix_count());
|
ordered_parts_ = OrderedEventsProcessor<std::pair<Part, NetQueryPtr>>(parts_manager_.get_ready_prefix_count());
|
||||||
}
|
}
|
||||||
|
if (file_info.need_delay && false) {
|
||||||
|
delay_dispatcher_ = create_actor<DelayDispatcher>("DelayDispatcher");
|
||||||
|
}
|
||||||
resource_state_.set_unit_size(parts_manager_.get_part_size());
|
resource_state_.set_unit_size(parts_manager_.get_part_size());
|
||||||
update_estimated_limit();
|
update_estimated_limit();
|
||||||
on_progress_impl(narrow_cast<size_t>(parts_manager_.get_ready_size()));
|
on_progress_impl(narrow_cast<size_t>(parts_manager_.get_ready_size()));
|
||||||
@ -128,6 +131,8 @@ Status FileLoader::do_loop() {
|
|||||||
if (parts_manager_.ready()) {
|
if (parts_manager_.ready()) {
|
||||||
TRY_STATUS(parts_manager_.finish());
|
TRY_STATUS(parts_manager_.finish());
|
||||||
TRY_STATUS(on_ok(parts_manager_.get_size()));
|
TRY_STATUS(on_ok(parts_manager_.get_size()));
|
||||||
|
LOG(INFO) << "Bad download order rate: " << (100.0 * debug_bad_part_order_ / debug_total_parts_) << "% "
|
||||||
|
<< debug_bad_part_order_ << "/" << debug_total_parts_;
|
||||||
stop_flag_ = true;
|
stop_flag_ = true;
|
||||||
return Status::OK();
|
return Status::OK();
|
||||||
}
|
}
|
||||||
@ -162,15 +167,20 @@ Status FileLoader::do_loop() {
|
|||||||
}
|
}
|
||||||
part_map_[id] = std::make_pair(part, query->cancel_slot_.get_signal_new());
|
part_map_[id] = std::make_pair(part, query->cancel_slot_.get_signal_new());
|
||||||
// part_map_[id] = std::make_pair(part, query.get_weak());
|
// part_map_[id] = std::make_pair(part, query.get_weak());
|
||||||
G()->net_query_dispatcher().dispatch_with_callback(std::move(query), actor_shared(this, id));
|
|
||||||
|
auto callback = actor_shared(this, id);
|
||||||
|
if (delay_dispatcher_.empty()) {
|
||||||
|
G()->net_query_dispatcher().dispatch_with_callback(std::move(query), std::move(callback));
|
||||||
|
} else {
|
||||||
|
send_closure(delay_dispatcher_, &DelayDispatcher::send_with_callback, std::move(query), std::move(callback));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return Status::OK();
|
return Status::OK();
|
||||||
}
|
}
|
||||||
|
|
||||||
void FileLoader::tear_down() {
|
void FileLoader::tear_down() {
|
||||||
for (auto &it : part_map_) {
|
for (auto &it : part_map_) {
|
||||||
it.second.second.reset();
|
it.second.second.reset(); // cancel_query(it.second.second);
|
||||||
// cancel_query(it.second.second);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
void FileLoader::update_estimated_limit() {
|
void FileLoader::update_estimated_limit() {
|
||||||
@ -259,7 +269,13 @@ Status FileLoader::try_on_part_query(Part part, NetQueryPtr query) {
|
|||||||
TRY_RESULT(size, process_part(part, std::move(query)));
|
TRY_RESULT(size, process_part(part, std::move(query)));
|
||||||
VLOG(files) << "Ok part " << tag("id", part.id) << tag("size", part.size);
|
VLOG(files) << "Ok part " << tag("id", part.id) << tag("size", part.size);
|
||||||
resource_state_.stop_use(static_cast<int64>(part.size));
|
resource_state_.stop_use(static_cast<int64>(part.size));
|
||||||
|
auto old_ready_prefix_count = parts_manager_.get_ready_prefix_count();
|
||||||
TRY_STATUS(parts_manager_.on_part_ok(part.id, part.size, size));
|
TRY_STATUS(parts_manager_.on_part_ok(part.id, part.size, size));
|
||||||
|
auto new_ready_prefix_count = parts_manager_.get_ready_prefix_count();
|
||||||
|
debug_total_parts_++;
|
||||||
|
if (old_ready_prefix_count == new_ready_prefix_count) {
|
||||||
|
debug_bad_part_order_++;
|
||||||
|
}
|
||||||
on_progress_impl(size);
|
on_progress_impl(size);
|
||||||
return Status::OK();
|
return Status::OK();
|
||||||
}
|
}
|
||||||
|
@ -16,6 +16,8 @@
|
|||||||
#include "td/telegram/files/ResourceState.h"
|
#include "td/telegram/files/ResourceState.h"
|
||||||
#include "td/telegram/net/NetQuery.h"
|
#include "td/telegram/net/NetQuery.h"
|
||||||
|
|
||||||
|
#include "td/telegram/DelayDispatcher.h"
|
||||||
|
|
||||||
#include "td/utils/OrderedEventsProcessor.h"
|
#include "td/utils/OrderedEventsProcessor.h"
|
||||||
#include "td/utils/Status.h"
|
#include "td/utils/Status.h"
|
||||||
|
|
||||||
@ -53,7 +55,8 @@ class FileLoader : public FileLoaderActor {
|
|||||||
int32 part_size;
|
int32 part_size;
|
||||||
std::vector<int> ready_parts;
|
std::vector<int> ready_parts;
|
||||||
bool use_part_count_limit = true;
|
bool use_part_count_limit = true;
|
||||||
bool only_check_ = false;
|
bool only_check = false;
|
||||||
|
bool need_delay = false;
|
||||||
};
|
};
|
||||||
virtual Result<FileInfo> init() TD_WARN_UNUSED_RESULT = 0;
|
virtual Result<FileInfo> init() TD_WARN_UNUSED_RESULT = 0;
|
||||||
virtual Status on_ok(int64 size) TD_WARN_UNUSED_RESULT = 0;
|
virtual Status on_ok(int64 size) TD_WARN_UNUSED_RESULT = 0;
|
||||||
@ -102,6 +105,10 @@ class FileLoader : public FileLoaderActor {
|
|||||||
// std::map<uint64, std::pair<Part, NetQueryRef>> part_map_;
|
// std::map<uint64, std::pair<Part, NetQueryRef>> part_map_;
|
||||||
bool ordered_flag_ = false;
|
bool ordered_flag_ = false;
|
||||||
OrderedEventsProcessor<std::pair<Part, NetQueryPtr>> ordered_parts_;
|
OrderedEventsProcessor<std::pair<Part, NetQueryPtr>> ordered_parts_;
|
||||||
|
ActorOwn<DelayDispatcher> delay_dispatcher_;
|
||||||
|
|
||||||
|
uint32 debug_total_parts_ = 0;
|
||||||
|
uint32 debug_bad_part_order_ = 0;
|
||||||
|
|
||||||
void start_up() override;
|
void start_up() override;
|
||||||
void loop() override;
|
void loop() override;
|
||||||
|
Reference in New Issue
Block a user