社区
Java SE
帖子详情
如何统计一段Java业务代码的CPU执行时间和IO执行时间
catoop
优质创作者: Java技术领域
领域专家: 后端开发技术领域
2019-08-03 06:02:00
如图
:
问题
:
业务代码中,总的时间消耗包含CPU时间 和 IO 时间。
如何通过代码或者其他工具,统计任意一段业务代码的CPU时间和IO时间。
例如针对上面图中的business方法,可以获得CPU累计消耗时间109ms和剩余的IO累计时间消耗。
假设业务方法是不透明的,只能调用,那么调用方如何统计目标方法的这2个时间消耗。
(可以使用代码,或者工具)
请教各位大神!!!
...全文
1485
6
打赏
收藏
如何统计一段Java业务代码的CPU执行时间和IO执行时间
如图: 问题: 业务代码中,总的时间消耗包含CPU时间 和 IO 时间。 如何通过代码或者其他工具,统计任意一段业务代码的CPU时间和IO时间。 例如针对上面图中的business方法,可以获得CPU累计消耗时间109ms和剩余的IO累计时间消耗。 假设业务方法是不透明的,只能调用,那么调用方如何统计目标方法的这2个时间消耗。 (可以使用代码,或者工具) 请教各位大神!!!
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
6 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
catoop
2021-04-15
打赏
举报
回复
这个确实很复杂,需要精通内核底层的很多知识,如果有能有一个这样的工具就好了。
冰思雨
2021-04-07
打赏
举报
回复
计算 CPU的使用时长 是一个很复杂的过程,同理,IO时长也是相对会比较复杂,总之,越想精确一些,算法就越麻烦,你要对操作系统,进程调度之类的东西非常了解才有可能实现。
冰思雨
2021-04-07
打赏
举报
回复
楼主的这个需求,是外行人提的吗? 你现在使用的是Java程序,但是,需求,怎么看着像C/C++程序的需求啊? 统计 CPU 和 IO 的操作时长,这个是操作系统级的需求,一般由偏低级的语言才能好实现。 Java语言是运行在虚拟机之上的程序,统计 操作系统之下的 CPU 和 IO 操作(偏硬件方面),是很困难的事情。 Java 语言可以统计的,一般都是函数的执行时长(使用动态代理技术),楼主可以考虑这个方向,统计函数的调用时长吧,这个还靠谱点。 当然,函数的执行时间,很可能无法区分 CPU时长 和 IO时长。
老王就是我
2021-04-02
打赏
举报
回复
没办法统计,system.current也是需要消耗性能的,并不是无损操作
qq_28147505
2021-04-01
打赏
举报
回复
所以最终是如何处理? 不对,业务方法是不透明的,你去调用,那就只有请求总时间了。。 不透明了,你怎么还知道有io,cpu的操作。。
faith.huan
2019-08-04
打赏
举报
回复
可以考虑使用springAop,分别计算business方法耗时(IO+CPU), HttpClientUitl.get方法耗时(IO) ,至于如何将这两个如何绑定到一次处理 可以考虑使用ThreadLocal设置个数字,用于标识 business和HttpClientUtil.get属于一次处理
Java
匿名内部类实战|通用
代码
耗时
统计
工具
Java
匿名内部类 函数式接口 性能测速
IO
文件简介日常开发经常需要
统计
代码
块
执行
耗时,传统写法到处复制start/end
时间
戳,
代码
冗余、耦合严重。本文基于接口 + 匿名内部类封装通用计时工具,一套工具支持任意
业务
代码
测速,演示数值累加、文件复制两大典型耗时场景,适合
Java
初学者理解回调、接口、匿名内部类综合应用。一、传
统计
时方案痛点平时测
一段
代码
耗时,大家都会这么写:
java
运行//
业务
代码
。
用
java
的
io
做一个
代码
计数器_
Java
中的程序计数器是什么
Java
中的程序计数器是什么程序计数器是当前线程正在
执行
的字节码的地址。程序计数器是线程隔离的,每一个线程在工作的时候都有一个独立的计数器。
JAVA
虚拟机管理的内存区域图1.什么是程序计数器?程序计数器是当前线程正在
执行
的字节码的地址。程序计数器是线程隔离的,每一个线程在工作的时候都有一个独立的计数器。2.字节码的
执行
原理编译后的字节码在没有经过JIT(实时编译器)编译前,是通过字节码解释器进行解...
线上问题排查解决思路-
CPU
利用率高/飙升
不管处于应急的哪个阶段,我们首先必须想到的是恢复问题,恢复问题不一定能够定位问题,也不一定有完美的解决方案,也许是通过经验判断,也许是预设开关等,但都可能让我们达到快速恢复的目的,然后。在大多数情况下,我们都是先优先恢复服务,保留下当时的异常信息(内存dump、线程dump、gc log等等,在紧急情况下甚至可以不用保留,等到事后去复现),等到服务正常,再去复盘问题。这里为了演示,用一个最简单的死循环来模拟
CPU
飙升的场景,下面是模拟
代码
,通过第一步,找出有问题的
代码
之后,观察到线程栈之后。
Java
应用线上问题排查思路、常用工具小结
show-busy-
java
-threads# 从所有运行的
Java
进程中找出最消耗
CPU
的线程(缺省5个),打印出其线程栈# 缺省会自动从所有的
Java
进程中找出最消耗
CPU
的线程,这样用更方便# 当然你可以手动指定要分析的
Java
进程Id,以保证只会显示你关心的那个
Java
进程的信息show-busy-
java
-threads -p show-busy-
java
-threads -c arthas提供了thread -b,可以找出当前阻塞其他线程的线程。
Java SE
62,621
社区成员
307,257
社区内容
发帖
与我相关
我的任务
Java SE
Java 2 Standard Edition
复制链接
扫一扫
分享
社区描述
Java 2 Standard Edition
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章