diff options
| author | Alan Conway <aconway@apache.org> | 2009-01-20 22:11:37 +0000 |
|---|---|---|
| committer | Alan Conway <aconway@apache.org> | 2009-01-20 22:11:37 +0000 |
| commit | 066fd1ab9f1840cfe09204bc5f3d550f1e12d49b (patch) | |
| tree | 51c9961e79c811c3240710bd7b7435a73e11c2b7 /cpp/src/qpid/sys/LatencyMetric.cpp | |
| parent | 861692abf515cf136e86e70446d005e7849a0f87 (diff) | |
| download | qpid-python-066fd1ab9f1840cfe09204bc5f3d550f1e12d49b.tar.gz | |
Latency measurements, compiled out of production code.
git-svn-id: https://svn.apache.org/repos/asf/qpid/trunk/qpid@736135 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'cpp/src/qpid/sys/LatencyMetric.cpp')
| -rw-r--r-- | cpp/src/qpid/sys/LatencyMetric.cpp | 71 |
1 files changed, 71 insertions, 0 deletions
diff --git a/cpp/src/qpid/sys/LatencyMetric.cpp b/cpp/src/qpid/sys/LatencyMetric.cpp new file mode 100644 index 0000000000..93fd852d64 --- /dev/null +++ b/cpp/src/qpid/sys/LatencyMetric.cpp @@ -0,0 +1,71 @@ +/* + * + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance + * with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + * + */ + +#ifdef QPID_LATENCY_METRIC + +#include "LatencyMetric.h" +#include "Time.h" +#include <iostream> + +namespace qpid { +namespace sys { + +void LatencyMetricTimestamp::initialize(const LatencyMetricTimestamp& ts) { + const_cast<int64_t&>(ts.latency_metric_timestamp) = Duration(now()); +} + +LatencyMetric::LatencyMetric(const char* msg, int64_t skip_) : + message(msg), count(0), total(0), skipped(0), skip(skip_) +{} + +LatencyMetric::~LatencyMetric() { report(); } + +void LatencyMetric::record(const LatencyMetricTimestamp& start) { + Mutex::ScopedLock l(lock); // FIXME aconway 2009-01-20: atomics? + if (!start.latency_metric_timestamp) return; // Ignore 0 timestamps. + if (skip) { + if (++skipped < skip) return; + else skipped = 0; + } + ++count; + int64_t now_ = Duration(now()); + total += now_ - start.latency_metric_timestamp; + // Set start time for next leg of the journey + const_cast<int64_t&>(start.latency_metric_timestamp) = now_; +} + +void LatencyMetric::report() { + using namespace std; + if (count) { + cout << "LATENCY: " << message << ": " + << total / (count * TIME_USEC) << " microseconds" << endl; + } + else { + cout << "LATENCY: " << message << ": no data." << endl; + } + count = 0; + total = 0; +} + + +}} // namespace qpid::sys + +#endif |
