【Java代码分析和CPU高的方法分析】

一、top之负载高

top -H -p pid  首先看load average   数值若小于0.7*CPU个数,则系统工作正常,如果超过这个值,甚至达到cpu核数的四五倍,则系统的负载就说明偏高且存在进一步升高的趋势,就需要进一步定位具体原因。通过vmstat命令查看cpu的上下文切换次数,

上下文切换次数发生的场景主要有如下几种:
1、时间切片用完,cpu正常调度下一个任务
2、被其他优先级更高的任务抢占
3、执行任务碰到I/O阻塞,挂起当前任务,切换到下一个任务
4、用户代码主动挂起当前任务让出CPU
5、多任务抢占资源,由于没有抢到被挂起
6、硬件中断

进程(proc):
R:运行队列中进程数量,这个值也可以判断是否需要增加cpu(长期大于1)
B:等待io进程数量

Memory(内存)
swpd:使用虚拟内存大小, 如果swpd的值不为0,但SI,SO的值长期为0,这种情况不会影响性能
free:空闲物理内存大小
buff:用作缓存的内存大小
cache:用作缓存的内存大小,如果cache值大的时候,说明cache处的文件数多,如果频繁访问到的文件都能被cache处,那么磁盘的IO bi会非常小

swap
Si  : 每秒从交换区写到内存的大小,由磁盘调入内存
SO:每秒写入交换区的内存大小,由内存调入磁盘
注意:内存够用的时候,这2个值都是0,如果这两个值长期大于0时,系统性能会受到影响,磁盘IO和CPU资源都会被消耗。有些朋友看到空闲内存free很少的或者接近于0时,就认为内存不够用了,不能光看这一点,还要结合SI SO,如果free很少,但是SI和SO也很少(大多数时候是0),那么不用担心,系统性能这时不会受到影响的。因为linux总是先把内存用光

IO
bi :每秒读取的块数
bo:每秒写入的块数
注意:随机磁盘读写的时候,这2个值越大(如超过1024k),能看到CPU在IO等待的值也会越大

system(系统)
in:每秒中断数,包括时钟中断
cs:每秒上下文切换数
注意:上面2个值越大,会看到由内存消耗的CPU时间会越大

CPU(以百分比表示)
us:用户进程执行时间百分比(user time)的值比较高时,说明用户进程消耗的CPU时间多,那么我们就该考虑优化程序算法或者加速
sy:内存系统进程执行时间百分比(system time)sy的值越高时,说明系统内核消耗的CPU资源多,这并不是良性表现,我们应该检查原因
wa:IO等待时间百分比wa的值高时,说明IO等待比较严重,这可能由于磁盘大量做随机访问造成,也有可能磁盘出现瓶颈(块操作)
id:空闲时间百分比
二、JVM的方法

jstack命令配合top使用,top -H -p pid   —> jstack -l pid  ,一般需要打印三次,top -H -p pid 的pid需要转换成16进制(可以用计算器计算/printf “%x\n” pid),
然后在线程堆栈里面找到对应的nid,就可以找到对应问题线程栈

jstat命令可打印GC详细信息,Young GC 和Full GC次数,堆信息等。其命令格式为:jstat -gcutil  -t  pid <interval><count> (jstat -gcutil -t 8610 2000 100)

Jmap打印java进程堆信息 jmap -head pid  通过jmap -dump:file = xxx pid 可dump堆到文件,然后通过其他工具进一步分析其堆使用情况

jvm图形化页面dump可以通过mat工具进行查看

三、数据库调优一般从以下几个方面出发:
1、sql语句层面进行优化,慢sql分析,索引分析和调优,事务拆分等
2、在数据库配置层面进行优化,比如字段设计,调整缓存大小,磁盘I/O的等数据库参数优化,数据碎片整理等
3、从数据库层面进行优化,考虑数据库的垂直拆分和水平拆分等
4、选择合适的数据库引擎或者类型适应不同场景,比如考虑加入NoSQL等

原文地址:https://www.cnblogs.com/frankruby/p/11395964.html

时间: 2024-08-08 05:30:39

【Java代码分析和CPU高的方法分析】的相关文章

MySQL SYS CPU高的案例分析(一)

原文:MySQL SYS CPU高的案例分析(一) [现象] 最近关注MySQL CPU告警的问题时,发现有一种场景,有一些服务器最近都较频繁的出现CPU告警,其中的现象是 SYS CPU占比较高. 下面的截图来源于“MySQL CPU报警”采集的文件 [问题分析] 可以分析出这服务器CPU升高的原因是由于表的高并发写入引起.优化方案通常是通知开发停止写入或降低写入频率. 究竟是什么原因导致高并发写入时CPU sys的占比这么高. 从采集的[Perf Stat]指标看到CPU有大量消耗是集中ke

找出java代码中占用cpu过多问题

当有java进程占用过多CPU时,可能是逻辑出现的问题.如何排查问题所在呢? 1. 使用top工具列出所有进程,shitf + p 列出CPU占用率较高进程 2. 找到问题进程号,使用top -H -p pid列出进程的所有线程 3. 然后shift + p 按照CPU使用率排序 4. 找出问题进程号,使用python打印出其16进制值,print("0x" % ppid),比如是:76a3 5. jstack pid > t.dat 记录线程堆栈,vi 打开找到76a3的线程号

改善JAVA代码01:考虑静态工厂方法代替构造器

前言 系列文章:[传送门]   每次开始新的一本书,我都会很开心.新书新心情. 正文 静态工厂方法代替构造器 说起这个,好多可以念叨的.做了一年多的项目,慢慢也有感触. 说起构造器 大家很明白,构造器可以让我们在何处何地获取自身或者他人一个实例.我们是无忌惮的使用着 new 却从来没考虑过人家的感受.其实new ,new一个对象,就是开辟一块内存空间给这个对象.如果何处何地,都new的话,漫山遍野... 五颜六色的new ,本质却一样 一句话:构造器虽是万能,但是要珍惜. 再谈谈 静态工厂方法

java 程序消耗 cpu 100% 查找方法

问题原因:由于HashMap是非线程安全的,在多线程访问时,造成死循环. 查找问题方法: 1. Java代码   top 找出最耗费cpu的进程号 如:27377 2. Java代码   top -p 27377 -H 找出此进程下的所有线程,然后找出最耗cpu线程号 如:27433 3. Java代码   python  hex(27433) 将十进制数转为16进制 如:0x6b29 4. Java代码   jstack 27377 >cpu.log 将此进程号的Java堆栈信息打印到文件中

Android NDK开发(五)--C代码回调Java代码【转】

转载请注明出处:http://blog.csdn.net/allen315410/article/details/41862479 在上篇博客里了解了Java层是怎样传递数据到C层代码,并且熟悉了大部分的实际开发知识,基本上掌握这些就可以做一个基本的NDK开发了,但是光是了解Java回调C层的数据是不是还不够啊,考虑问题要考虑可逆性,Java能回调C,那么C能否反过来回调Java呢?答案是肯定可以的,这篇博客就介绍一个C语言如何调用Java层的代码.以下是一些问题场景,我们带着这个问题场景来分析

java代码调用C代码 JNI

1 定义一个c方法的接口   相当于在java代码中定义了一个接口 接口的实现方法是C语言实现的 public native int login(String password); 2 实现C代码 在android工程的目录的src下,可以使用命令: (javah  -jni  全类名 )来生成对应C语言函数的头文件 #include <stdio.h>#include "com_qushaohui_aliwangwang_MainActivity.h" int login

通过 thread dump 分析找到高CPU耗用与内存溢出的Java代码

http://heylinux.com/archives/1085.html通过 thread dump 分析找到高CPU耗用与内存溢出的Java代码 首先,要感谢我的好朋友 钊花 的经验分享. 相信大家在实际的工作当中,肯定会遇到由代码所导致的高CPU耗用以及内存溢出的情况. 通常这种情况发生时,我们会认为这些问题理所当然的该由开发人员自己去解决,因为操作系统环境是没有任何问题的. 但实际上,我们是可以帮助他们的,效果好的话还可以定位到具体出问题的代码行数,思路如下: 1.通过对CPU与内存的

java进程CPU高分析

https://blog.csdn.net/moranzi1/article/details/89341480 JVM导致系统CPU高的常见场景内存不足,JVM gc频繁,一般会伴随OOMJVM某个线程死循环或者递归调用 定位和解决1.内存不足,gc频繁可参考我的这遍文章解决.https://blog.csdn.net/moranzi1/article/details/886702042.JVM某个线程死循环或者递归调用.这种情况关键是找到导致CPU高的线程.然后根据具体线程具体分析为什么该线程

CPU高获取其线程ID然后分析

以我们最近出现的一个实际故障为例,介绍怎么定位和解决这类问题. clip_image002 根据top命令,发现PID为28555的Java进程占用CPU高达200%,出现故障. 通过ps aux | grep PID命令,可以进一步确定是tomcat进程出现了问题.但是,怎么定位到具体线程或者代码呢? 首先显示线程列表: ps -mp pid -o THREAD,tid,time 找到了耗时最高的线程28802,占用CPU时间快两个小时了! 其次将需要的线程ID转换为16进制格式: print