2016-06-10 21:26:35 +03:00
|
|
|
/*
|
2019-06-20 02:58:25 +03:00
|
|
|
* Copyright (c) Facebook, Inc. and its affiliates.
|
2016-06-10 21:26:35 +03:00
|
|
|
*
|
2019-06-20 02:58:25 +03:00
|
|
|
* This software may be used and distributed according to the terms of the
|
|
|
|
* GNU General Public License version 2.
|
2016-06-10 21:26:35 +03:00
|
|
|
*/
|
2019-04-02 03:37:54 +03:00
|
|
|
#include "eden/fs/tracing/EdenStats.h"
|
2016-06-10 21:26:35 +03:00
|
|
|
|
2017-10-29 13:33:10 +03:00
|
|
|
#include <folly/container/Array.h>
|
2016-06-10 21:26:35 +03:00
|
|
|
#include <chrono>
|
2019-04-30 01:44:18 +03:00
|
|
|
#include <memory>
|
2016-06-10 21:26:35 +03:00
|
|
|
|
2019-04-11 05:55:31 +03:00
|
|
|
#include "eden/fs/eden-config.h"
|
|
|
|
|
2016-06-10 21:26:35 +03:00
|
|
|
using namespace folly;
|
|
|
|
using namespace std::chrono;
|
|
|
|
|
|
|
|
namespace {
|
|
|
|
constexpr std::chrono::microseconds kMinValue{0};
|
|
|
|
constexpr std::chrono::microseconds kMaxValue{10000};
|
|
|
|
constexpr std::chrono::microseconds kBucketSize{1000};
|
2017-11-04 01:58:04 +03:00
|
|
|
} // namespace
|
2016-06-10 21:26:35 +03:00
|
|
|
|
|
|
|
namespace facebook {
|
|
|
|
namespace eden {
|
|
|
|
|
2019-05-30 04:08:03 +03:00
|
|
|
FuseThreadStats& EdenStats::getFuseStatsForCurrentThread() {
|
|
|
|
return *threadLocalFuseStats_.get();
|
|
|
|
}
|
|
|
|
|
2019-07-01 22:46:52 +03:00
|
|
|
ObjectStoreThreadStats& EdenStats::getObjectStoreStatsForCurrentThread() {
|
|
|
|
return *threadLocalObjectStoreStats_.get();
|
|
|
|
}
|
|
|
|
|
2019-05-30 04:08:03 +03:00
|
|
|
HgBackingStoreThreadStats& EdenStats::getHgBackingStoreStatsForCurrentThread() {
|
|
|
|
return *threadLocalHgBackingStoreStats_.get();
|
|
|
|
}
|
|
|
|
|
|
|
|
HgImporterThreadStats& EdenStats::getHgImporterStatsForCurrentThread() {
|
|
|
|
return *threadLocalHgImporterStats_.get();
|
2019-04-15 06:42:26 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
void EdenStats::aggregate() {
|
2019-05-30 04:08:03 +03:00
|
|
|
for (auto& stats : threadLocalFuseStats_.accessAllThreads()) {
|
|
|
|
stats.aggregate();
|
|
|
|
}
|
2019-07-01 22:46:52 +03:00
|
|
|
for (auto& stats : threadLocalObjectStoreStats_.accessAllThreads()) {
|
|
|
|
stats.aggregate();
|
|
|
|
}
|
2019-05-30 04:08:03 +03:00
|
|
|
for (auto& stats : threadLocalHgBackingStoreStats_.accessAllThreads()) {
|
|
|
|
stats.aggregate();
|
|
|
|
}
|
|
|
|
for (auto& stats : threadLocalHgImporterStats_.accessAllThreads()) {
|
2019-04-15 06:42:26 +03:00
|
|
|
stats.aggregate();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-05-30 04:08:03 +03:00
|
|
|
std::shared_ptr<HgImporterThreadStats> getSharedHgImporterStatsForCurrentThread(
|
2019-04-30 01:44:18 +03:00
|
|
|
std::shared_ptr<EdenStats> stats) {
|
2019-05-30 04:08:03 +03:00
|
|
|
return std::shared_ptr<HgImporterThreadStats>(
|
|
|
|
stats, &stats->getHgImporterStatsForCurrentThread());
|
2019-04-30 01:44:18 +03:00
|
|
|
}
|
|
|
|
|
2019-05-30 04:08:03 +03:00
|
|
|
EdenThreadStatsBase::EdenThreadStatsBase() {}
|
2016-06-10 21:26:35 +03:00
|
|
|
|
2019-05-30 04:08:03 +03:00
|
|
|
EdenThreadStatsBase::Histogram EdenThreadStatsBase::createHistogram(
|
2019-04-15 06:42:25 +03:00
|
|
|
const std::string& name) {
|
2017-03-31 21:23:02 +03:00
|
|
|
return Histogram{this,
|
|
|
|
name,
|
2019-07-25 07:04:08 +03:00
|
|
|
static_cast<int64_t>(kBucketSize.count()),
|
2017-03-31 21:23:02 +03:00
|
|
|
kMinValue.count(),
|
|
|
|
kMaxValue.count(),
|
2019-07-25 07:04:08 +03:00
|
|
|
fb303::COUNT,
|
2017-03-31 21:23:02 +03:00
|
|
|
50,
|
|
|
|
90,
|
|
|
|
99};
|
|
|
|
}
|
|
|
|
|
2019-05-30 04:08:03 +03:00
|
|
|
EdenThreadStatsBase::Timeseries EdenThreadStatsBase::createTimeseries(
|
2019-04-15 06:42:25 +03:00
|
|
|
const std::string& name) {
|
2019-04-11 05:55:31 +03:00
|
|
|
auto timeseries = Timeseries{this, name};
|
2019-07-25 07:04:08 +03:00
|
|
|
timeseries.exportStat(fb303::COUNT);
|
|
|
|
timeseries.exportStat(fb303::PERCENT);
|
2019-04-11 05:55:31 +03:00
|
|
|
return timeseries;
|
|
|
|
}
|
|
|
|
|
2019-05-30 04:08:03 +03:00
|
|
|
void FuseThreadStats::recordLatency(
|
2017-03-31 21:23:02 +03:00
|
|
|
HistogramPtr item,
|
|
|
|
std::chrono::microseconds elapsed,
|
|
|
|
std::chrono::seconds now) {
|
|
|
|
(void)now; // we don't use it in this code path
|
|
|
|
(this->*item).addValue(elapsed.count());
|
|
|
|
}
|
2018-03-20 03:01:15 +03:00
|
|
|
|
2017-11-04 01:58:04 +03:00
|
|
|
} // namespace eden
|
|
|
|
} // namespace facebook
|