- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我使用 Dropwizard metrics衡量我的应用程序中的各种指标。它们是 JVM instrumentation 中的几个预定义记者,但奇怪的是我找不到任何报告 CPU 使用率的信息。
我可以创建自己的仪表(使用 getThreadCpuTime 或类似的),但我最好的猜测是我遗漏了一些东西。
我是否在当前实现中错过了它,或者它比我最初想象的更复杂?
最佳答案
我对 Dropwizard 了解不多,但我过去使用过 ThreadMXBean
来估计可扩展分布式计算系统中的 CPU 使用率,因此我将分享我认为与以下内容相关的内容这个问题。事情肯定比乍看起来要复杂:
ThreadMxBean 有点误导......
ThreadMxBean.getThreadCpuTime(id)
仅返回自线程启动以来特定线程在 CPU 上执行代码所花费的总时间,以纳秒为单位。它没有提供有关您的线程可能已被阻塞或等待( hibernate )多长时间的信息,因此它确实无法让您很好地了解 CPU 使用情况。您还需要测量总阻塞/等待时间,然后在程序运行期间跟踪所有这三个值以跟踪 CPU 使用率。奇怪的是,ThreadMXBean
没有直接获取阻塞/等待时间的方法,因此您可能会想放弃。
...但您可以使用它来获取 ThreadInfo
对象...
首先,要启用它,请调用这两行(如果您的 JVM 不支持,这可能会抛出异常):
ManagementFactory.getThreadMXBean().setThreadCpuTimeEnabled(true);
ManagementFactory.getThreadMXBean().setThreadContentionMonitoringEnabled(true);
现在您可以调用ThreadMXBean.getThreadInfo(threadId)
来获取与特定线程对应的ThreadInfo
实例。此信息对象有两个方法,getBlockedTime()
和 getWaitedTime()
,它们返回您的线程在这两种状态中的任何一种状态下花费的总毫秒数。没有 getCpuTime()
方法(如果你问我,这是这个对象的一个非常愚蠢的缺点),但如果你知道你的线程何时启动,你可以这样做:
//Initialized somewhere else:
ThreadMXBean bean = ...
long threadStartTime = System.currentTimeMillis();
Thread myThread = ...
//Inside your metrics-gathering code:
long now = System.currentTimeMillis();
ThreadInfo info = bean.getThreadInfo(myThread.getId());
long totalCpuTime = now - (info.getBlockedTime()+info.getWaitedTime()+threadStartTime);
现在您可以计算线程利用率的百分比。
我们快完成了,但还没有完全完成。每次我们检查上面发布的代码的最后三行时,我们只收集线程执行/阻塞/等待状态的总时间。要计算百分比,我们需要跟踪收集这些指标的时间,以便我们可以知道自上次指标更新以来线程在每个状态中花费了多少时间。所以,做这样的事情:
class ThreadUsageMetrics{
long timestamp, totalBlockedTime, totalWaitTime;
ThreadUsageMetrics(long ts, long blocked, long wait){
timestamp = ts;
totalBlockedTime = blocked;
totalWaitTime = wait;
}
double computeCpuUsageSince(ThreadUsageMetrics prev){
long time = timestamp - prev.timestamp;
long blocked = totalBlockedTime - prev.totalBlockedTime;
long waited = totalWaitTime - prev.totalWaitTime;
return (time-(blocked+waited))/(double)time;
}
}
这将为我们提供 0.0 到 1.0 范围内的 double 值,表示自上次指标更新以来 CPU 使用率占总时间的百分比。我假设您可以将此值转换为百分比,并每隔 5 秒左右将其提供给 Dropwizard 的 Gauge
实例。在我的项目中,这就是我们多年来估算 CPU 使用率的方式,对我们来说效果很好。
关于此的几点说明 - 我们实际上不需要在此对象中显式存储总 CPU 时间,因为任何未花费在阻塞或等待上的时间要么是执行时间,要么是在上下文切换期间花费的时间。我们无法知道上下文切换时间,但可以安全地假设在所有情况下 99.9% 的总上下文切换时间可以忽略不计。
请注意 - 我们并未真正测量 CPU 使用率。
如果您仔细阅读,您会注意到我说过我们正在“估计”CPU 使用率。我这样说的原因是我们正在测量特定 Java Thread
的总执行时间。 Java 不提供实际 CPU 硬件使用的概念——它只是一个线程执行所花费的总时间。超线程之类的东西进一步混淆了这一点,其中“执行”所花费的时间实际上可能意味着等待其他线程离开 ALU 或内存总线所花费的时间。我认为这可以很好地衡量代码何时在物理硬件线程上运行,但如果您想衡量实际的 CPU 使用率,则无法在纯 Java 中完成。
关于java - 使用 Dropwizard 指标报告 JVM 的 CPU 使用率,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40090757/
@After public void afterScenario() { if (ScenarioManager.getScenario().isFailed()) {
我已将 BIRT 报告集成到 Grails 中并设计了一份报告。我的 grails 应用程序中有一个名为 startPeriod (仅限月份和年份)的参数,我想将其传递给 BIRT。然后 BIRT 调
我有一些 Oracle 报告 (.rdf),正在考虑将其转换为 BIRT 报告。有没有办法将 .rdf 文件转换为 BIRT 报告设计文件? 最佳答案 完全自动化的解决方案可能是不可能的。您可以部分自
当 gcc 4.1(使用 gcov)下一行: p = 新类; 报告为 100% 分支覆盖率 为什么? 因为启用了异常处理!!! 为了解决此问题,请指定: -fno-exceptions 在 g++
真的有好 免费 BugZilla 报告工具?我发现 Web 界面上的默认搜索选项太有限了。我最大的问题是缺少 Order By 选项(一次只有 1 个字段,可供选择的字段集非常有限)。我已经做了一些谷
是否可以在 CFMX7 上运行 ColdFusion Report builder 生成的报告? 更明确地说,是否可以将 CF7 中的报告生成引擎更改为 CF8? 最佳答案 我猜这可能很难做到。我记得
根据Lucintel发布的新市场报告,智能家居市场的未来看起来很有吸引力,在家用安全、家电、娱乐、照明、HVAC、医疗保健和厨房应用中将带来许多机遇。 由于COVID-19导致的全球经济衰退,
PHPCodeSniffer 是否生成 HTML 报告? 如果不是呢?怎么办? 目前,我可以运行 PHPCodeSniffer,但它只生成 XML 文件并在终端中显示结果。 如何在 phpunit 中
我在一个包中添加了一个简单的测试。 按照手册中的建议,我尝试让 PHPUnit 加载配置: phpunit -c /app phpunit.xml 看起来像这样:
我有两个从 csv 文件加载的数据框。基本上来自不同的环境但格式/列相似,它们的行/值可能有所不同。我想找到差异并在新的数据框中创建它们。两个数据框也将具有相同的顺序。我有 100 个要比较的文件。提
我想看看是否有办法通过 javadoc 在我的 junit 报告中包含“描述性文本”。 JUnit 4 似乎不像 TestNG 那样支持 @Test 注释的“描述”属性。 到目前为止,我所研究的只有一
我正在使用操作、 Controller 、servlet struts 框架编写 Excel 报告。该报告非常拥挤,已经有大约 10 个单独的查询。由于报告发生变化,我需要再添加大约 10 个查询。有
在放弃 Syleam 的 openerp jasper 模块后,我在 Nan Tic 的 jasper_reports 模块上苦苦挣扎。 它一直给我一个错误: File "C:\Program Fil
我希望创建一个简单的日历。每天由编码器生成条目计数并以日历样式查看。如一月、二月等。或按月显示全年。 database have date_added and encoder columns 我在将它
我必须为报告创建 MySQL 查询。 我有一个表history,它记录产品订单的状态更改。我有订单生命周期(订单流程)的以下状态:新、已确认、正在处理、已发货、已交付、已取消、已退回。订单不一定遵循此
如何将多个查询合并为一个? 例如: //Successful Sales: SELECT username, count(*) as TotalSales, sum(point) as Points
MySQL 优化技术的新手。请找到下面的 mysqltuner.pl 报告,并建议我应该更改 my.cnf 中的哪些变量以优化性能。 还有一个问题- 我无法在我的 my.cnf 中找到一些变量,例如
我想知道,我想将我的 Swing Worker 的某种形式的进度报告回主线程,以便我的界面可以使用随着进度增加而变化的标签进行更新,例如 checking 1/6... checking 2/6...
我正在尝试在“报告”>“销售”下运行 Magento Paypal 结算报告,但每次我尝试运行该报告时,我都会收到消息“由于配置为空,无法获取任何内容” 我查看了“系统”>“配置”>“销售”>“付款方
我想要一个工具来帮助创建 sql 查询(对于非 IT 人员),例如 dbforge。 我希望我们的非 IT 人员(例如运营)创建他们自己的 sql 查询。 我的第二个目标是让他们能够按需执行这些查询。
我是一名优秀的程序员,十分优秀!