《Java Performance》笔记1——性能分析基础 2

4.内存使用率:

内存使用率的相关属性包括页面调度或页面交换、加锁、线程迁移中的让步式和抢占式上下文切换。

当应用运行所需的内存超过可用物理内存时,就会发生内存页面交换,系统在进行页面交换或使用虚拟内存时,应用会表现出明显的性能问题。为了应对这种可能出现的情况,通常要为系统配置swap空间,swap空间一般会在一个独立的磁盘分区上,当应用耗尽物理内存时,操作系统会将应用中最少运行的部分置换到磁盘上的swap空间,当访问应用被置换出去的数据时,就必须将它从磁盘置换进物理内存,而这种置换活动会对性能产生很大的影响,尤其是应用的响应性和吞吐量。

让步式上下文切换是指执行线程主动释放CPU,抢占式上下文切换是指线程因为分配的时间片用尽而被迫放弃CPU或被其他优先级更高的线程所抢占。

Java5之后的JVM增加了自旋锁优化机制,即线程通过忙循环自旋尝试获得锁,如果若干次忙循环自旋之后仍然没有成功,则挂起该线程,等待被唤醒再次尝试获取该锁。挂起和唤醒线程会导致操作系统的让步式上下文切换,因此锁竞争激烈的应用会表现出大量的让步式上下文切换,让步式上下文切换耗费的CPU时钟周期代价非常高(通常高达大约80000个时钟周期)。锁竞争监控一般性原则是,如果让步式上下文切换占去5%或更多可用时钟周期时,说明它遇到了锁竞争。

线程迁移是指待运行的线程在处理器之间迁移,大多数操作系统的CPU调度程序会将待运行线程分配给上次它运行的虚拟处理器,如果这个虚拟处理器忙,则调度程序就会将待运行线程迁移到其他可用虚拟处理器。线程迁移会因为新的虚拟处理器缓存中可能没有待运行线程所需的数据或状态信息而导致应用性能下降。多核系统上运行应用可能会发生大量的线程迁移,减少迁移的策略是创建处理器组并将应用分配给这些处理器组。

(1).Windows 内存使用率监控:

typeperf可以监控内存使用率,下面命令每隔5秒钟输出可用内存和页面调度:

typeperf -si 5 “\Memory\Available Mbytes” “\Memory\Pages/sec”

Windows内置的工具难以监控锁竞争,Windows的性能计数器可用监控上下文切换,但无法区分让步式和抢占式上下文切换,因此需要外部工具,如Intel VTune或AMD CodeAnalyst。

(2).Linux内存使用率监控:

Linux中可以使用vmstat命令监控内存使用率,vmstat输出的si表示内存页面换入量,so表示内存页面换出量,free表示可用的空闲内存。

Linux中可以使用sysstat包中的pidstat命令监控锁竞争,使用如下命令可以监控所有虚拟处理器的让步式上下文锁竞争:

pidstat -w

pidstat -w命令输出的cswch/s是让步式上下文切换。

若处理器为3.0GHz的CPU,通过pidstat -w命令监控发现共发生了1750次让步式上下文切换,则让步式上下文切换所浪费的时钟周期比例=1750*80000/3000000000=4.7%.

5.网络I/O使用率:

分布式应用的性能和扩展性受限于网络带宽或网络的I/O,例如若发送到系统网络接口硬件的消息量超过了它的处理能力,消息就会进入操作系统的缓冲区,从而导致应用延迟等。

(1).Linux网络I/O监控:

A.netstat或sysstat:

可以提供每秒发送和接收的包数,包括错误和冲突的包,但是不能提供网络使用率。

B.nicstat:

源码可以从http://sourceforge.net/projects/nicstat/files/下载,使用前需要编译。命令格式如下:

nicstat [-hnsz] [-i interface[,.....]] | [interval] [count]

其中-h是显示帮助信息,-n仅显示非本地接口,-s显示概要信息,-z跳过0值,-i interface是网络接口设备名,interval是报告输出的频率,count是报告的采样数。输出的%Util列就是网络使用率。

(2).Windows网络I/O监控:

Windows上监控网络I/O需要知道被监控网络接口的带宽和网络接口传递的数据量。

网络接口每秒传递的字节数可以通过typeperf -si 5 “\Network Interface(*)\Bytes Total/sec” 获得,单位是bytes/s。

网络带宽可以通过typeperf -si 5 “\Network Interface(*)\Current Bandwidth” 获得,单位是bit/s。

网络使用率=Bytes Total/sec/(Current Bandwidth / 8) * 100

网络使用率=(Bytes Total/sec * 8)/Current Bandwidth * 100

网络使用率提高的策略是使用非阻塞的网络I/O代替阻塞的网络I/O,对于非阻塞网络I/O在读请求时尽可能地多读取数据,在写请求时尽可能地多写入数据。

6.磁盘I/O使用率

对于频繁进行磁盘I/O的应用,如数据库、日志等,磁盘I/O对性能有着至关重要的影响。

Linux磁盘I/O监控:

Linux上安装sysstat包之后可以使用iostat命令监控磁盘,命令为:iostat -xm,输出的%util列就是磁盘I/O使用率。

改善磁盘I/O使用率策略:

(1).使用更快的存储设备。

(2).文件系统扩展到多个磁盘。

(3).使用操作系统缓存,开启磁盘缓存。

时间: 2024-12-23 21:41:38

《Java Performance》笔记1——性能分析基础 2的相关文章

老李分享:《Java Performance》笔记1——性能分析基础 1

老李分享:<Java Performance>笔记1——性能分析基础 1.性能分析两种方法: (1).自顶向下: 应用开发人员通过着眼于软件栈顶层的应用,从上往下寻找性能优化的机会. (2).自底向上: 性能专家从软件栈底层的CPU统计数据(例如CPU高速缓存未命中率.CPU指令效率)开始,逐渐上升到应用自身的结构或应用常见的使用方式. 2.CPU使用率: 大多数操作系统的CPU使用率分为用户态CPU使用率和系统态CPU使用率. 用户态CPU使用率:执行应用程序代码的时间占总CPU时间的百分比

java学习笔记14--多线程编程基础1

本文地址:http://www.cnblogs.com/archimedes/p/java-study-note14.html,转载请注明源地址. 多线程编程基础 多进程 一个独立程序的每一次运行称为一个进程,例如:用字处理软件编辑文稿时,同时打开mp3播放程序听音乐,这两个独立的程序在同时运行,称为两个进程 进程要占用相当一部分处理器时间和内存资源 进程具有独立的内存空间 通信很不方便,编程模型比较复杂 多线程 一个程序中多段代码同时并发执行,称为多线程,线程比进程开销小,协作和数据交换容易

LR之性能分析基础

1.判断测试结果有效性 2.分析要点提示 3.Analysis主要提供的6大类分析图 4.分析流程

java学习笔记15--多线程编程基础2

本文地址:http://www.cnblogs.com/archimedes/p/java-study-note15.html,转载请注明源地址. 线程的生命周期 1.线程的生命周期 线程从产生到消亡的过程 一个线程在任何时刻都处于某种线程状态(thread state) 线程生命周期状态图 诞生状态 线程刚刚被创建 就绪状态 线程的 start 方法已被执行 线程已准备好运行 运行状态 处理机分配给了线程,线程正在运行 阻塞状态(Blocked) 在线程发出输入/输出请求且必须等待其返回 遇到

java学习笔记(二)基础语法(上)

Java 作为一门编程语言,与其它语言一样,有字符集,标识符和关键字,变量,常量,语句等编程语言的基本要素. 关键字:abstract抽象的,boolean布尔型,break跳出循环,continue中止本次循环,byte字节型,case,catch,char,class,const,default,do,double,else,extends,assert,final,finally,float ,for,if,implements,import,instandceof,int,interfa

深入理解JAVA虚拟机之JVM性能篇---基础知识点

一.堆与栈 堆和栈是程序运行的关键,其间的关系有必要理清楚,两者如下图所示: 1. 堆: 所有线程共享,堆中只负责存储对象信息. 2. 栈: 在Java中每个线程都会有一个相应的线程栈与之对应(因为不同的线程执行逻辑有所不同,因此需要一个独立的线程栈),栈是运行单位,因此里面存储的信息都是跟当前线程(或程序)相关的信息,包括局部变量.程序运行状态.方法返回值等; 3. 总结: 栈是运行时的单位,而堆是存储的单位. 二.JAVA对象的大小 在Java中,一个空Object对象的大小是8byte,这

java学习笔记_内存分析

程序执行时内存一般被分为4部分 代码区(code segment):存放代码 数据区(data segment):静态变量和字符串常量 栈(stack): 存放局部变量 堆(heap):动态生成内存(new出来的东西) 代码如下: public class Person{ int id; int age; Person(int _id,int _age){ id = _id; age = _age; } public static void main(String[] args){ Person

Java几款性能分析工具的对比

在给客户的应用程序维护的过程中,我注意到在高负载下的一些性能问题.理论上,增加对应用程序的负载会使性能等比率的下降.然而,我认为性能下降的比率远远高于负载的增加.我也发现,性能可以通过改变应用程序的逻辑来提升,甚至达到极限.为了更详细的了解这一点,我们需要做一些性能分析... 在给客户进行应用程序维护的过程中,我注意到一些关于高负载条件下的性能问题.理论上,增加对应用程序的负载会使性能有所下降,但是我认为性能下降的比率远远高于负载的增加,同时我也发现,性能可以通过改变应用程序的逻辑来提升.为了更

java学习笔记16--I/O流和文件

本文地址:http://www.cnblogs.com/archimedes/p/java-study-note16.html,转载请注明源地址. IO(Input  Output)流 IO流用来处理设备之间的数据传输,对数据的操作是通过流的方式,Java用于操作流的对象都在IO包中 输入/输出流可以从以下几个方面进行分类 从流的方向划分: 输入流.输出流 从流的分工划分: 节点流.处理流 从流的内容划分: 面向字符的流.面向字节的流 字符流和字节流 字符流的由来: 因为数据编码的不同,而有了对