/* */ #include "ServerStat.h" #include #include #include "array_fun.h" #include "Logger.h" #include "LogFactory.h" #include "fmt.h" #include "a2functional.h" #include "util.h" namespace aria2 { const std::string ServerStat::STATUS_STRING[] = { "OK", "ERROR" }; ServerStat::ServerStat(const std::string& hostname, const std::string& protocol) : hostname_(hostname), protocol_(protocol), downloadSpeed_(0), singleConnectionAvgSpeed_(0), multiConnectionAvgSpeed_(0), counter_(0), status_(OK) {} ServerStat::~ServerStat() {} void ServerStat::setLastUpdated(const Time& time) { lastUpdated_ = time; } void ServerStat::setDownloadSpeed(int downloadSpeed) { downloadSpeed_ = downloadSpeed; } void ServerStat::updateDownloadSpeed(int downloadSpeed) { downloadSpeed_ = downloadSpeed; if(downloadSpeed > 0) { status_ = OK; } lastUpdated_.reset(); } void ServerStat::setSingleConnectionAvgSpeed(int singleConnectionAvgSpeed) { singleConnectionAvgSpeed_ = singleConnectionAvgSpeed; } void ServerStat::updateSingleConnectionAvgSpeed(int downloadSpeed) { float avgDownloadSpeed; if(counter_ == 0) return; if(counter_ < 5) { avgDownloadSpeed = ((((float)counter_-1)/(float)counter_)*(float)singleConnectionAvgSpeed_)+ ((1.0/(float)counter_)*(float)downloadSpeed); } else { avgDownloadSpeed = ((4.0/5.0)*(float)singleConnectionAvgSpeed_) + ((1.0/5.0)*(float)downloadSpeed); } if(avgDownloadSpeed < (int)(0.80*singleConnectionAvgSpeed_)) { A2_LOG_DEBUG(fmt("ServerStat:%s: resetting counter since single connection" " speed dropped", getHostname().c_str())); counter_ = 0; } A2_LOG_DEBUG(fmt("ServerStat:%s: singleConnectionAvgSpeed_ old:%.2fKB/s" " new:%.2fKB/s last:%.2fKB/s", getHostname().c_str(), (float) singleConnectionAvgSpeed_/1024, (float) avgDownloadSpeed/1024, (float) downloadSpeed / 1024)); singleConnectionAvgSpeed_ = (int)avgDownloadSpeed; } void ServerStat::setMultiConnectionAvgSpeed(int multiConnectionAvgSpeed) { multiConnectionAvgSpeed_ = multiConnectionAvgSpeed; } void ServerStat::updateMultiConnectionAvgSpeed(int downloadSpeed) { float avgDownloadSpeed; if(counter_ == 0) return; if(counter_ < 5) { avgDownloadSpeed = ((((float)counter_-1)/(float)counter_)*(float)multiConnectionAvgSpeed_) + ((1.0/(float)counter_)*(float)downloadSpeed); } else { avgDownloadSpeed = ((4.0/5.0)*(float)multiConnectionAvgSpeed_) + ((1.0/5.0)*(float)downloadSpeed); } A2_LOG_DEBUG(fmt("ServerStat:%s: multiConnectionAvgSpeed_ old:%.2fKB/s" " new:%.2fKB/s last:%.2fKB/s", getHostname().c_str(), (float) multiConnectionAvgSpeed_/1024, (float) avgDownloadSpeed/1024, (float) downloadSpeed / 1024)); multiConnectionAvgSpeed_ = (int)avgDownloadSpeed; } void ServerStat::increaseCounter() { ++counter_; } void ServerStat::setCounter(int value) { counter_ = value; } void ServerStat::setStatus(STATUS status) { status_ = status; } void ServerStat::setStatus(const std::string& status) { const std::string* p = std::find(vbegin(STATUS_STRING), vend(STATUS_STRING), status); if(p != vend(STATUS_STRING)) { status_ = static_cast(ServerStat::OK+ std::distance(vbegin(STATUS_STRING), p)); } } void ServerStat::setStatusInternal(STATUS status) { A2_LOG_DEBUG(fmt("ServerStat: set status %s for %s (%s)", STATUS_STRING[status].c_str(), hostname_.c_str(), protocol_.c_str())); status_ = status; lastUpdated_.reset(); } void ServerStat::setOK() { setStatusInternal(OK); } void ServerStat::setError() { setStatusInternal(A2_ERROR); } bool ServerStat::operator<(const ServerStat& serverStat) const { int c = hostname_.compare(serverStat.hostname_); if(c == 0) { return protocol_ < serverStat.protocol_; } else { return c < 0; } } bool ServerStat::operator==(const ServerStat& serverStat) const { return hostname_ == serverStat.hostname_ && protocol_ == serverStat.protocol_; } std::string ServerStat::toString() const { return fmt("host=%s, protocol=%s, dl_speed=%d, sc_avg_speed=%d," " mc_avg_speed=%d, last_updated=%ld, counter=%d, status=%s", getHostname().c_str(), getProtocol().c_str(), getDownloadSpeed(), getSingleConnectionAvgSpeed(), getMultiConnectionAvgSpeed(), getLastUpdated().getTime(), getCounter(), ServerStat::STATUS_STRING[getStatus()].c_str()); } } // namespace aria2