简介
监控内存相关的属性,例如页面调度或页面交换、加锁、线程迁移中的让步式和抢占式上下文切换。
系统在进行页面交换或使用虚拟内存时,Java应用或JVM会表现出明显的性能问题。swap磁盘置换活动会对应用的响应性和吞吐量造成很大影响。
JVM垃圾收集器在页面交换时的性能也很差,这是由于垃圾收集器为了回收不可达对象所占用的空间,需要访问大量的内存。垃圾收集是STW操作,停止所有正在运行的应用线程,如果此时系统正在进行页面交换,则会引起JVM长时间的停顿。如果垃圾收集时间变长,系统有可能正在进行页面交换,所以为了验证,需要监控系统的页面交换。
经验之谈: 应用程序可用内存/系统物理内存>70%内存充足 应用程序可用内存/系统物理内存<20%内存不足,需要增加内存 20%<应用程序可用内存/系统物理内存<70%内存基本够用
使用vmstat监控内存使用率
说明 | 内容 |
---|
swpd | 当前使用的虚拟内存量(KB)。当空闲内存达到低阈值时,更多的数据被分页到交换设备。 | free | 当前可用于正在运行的应用程序的物理内存量(以千字节为单位)。 | buff | read()和write()操作导致的缓冲区高速缓存中的物理内存量(以千字节为单位)。 | cache | 映射到进程地址空间的物理内存量,以千字节为单位。 | si | 从交换磁盘写回RAM的数据量,以千字节为单位。内存页面换入的量 | so | 写入交换磁盘的数据量,以千字节为单位。内存页面换出的量 | bi | 从文件系统或交换设备分页到RAM中的磁盘块数。 | bo | 从RAM分页到文件系统或交换设备的磁盘块数。 |
留意是否会同时出现空闲内存少和页面调度频繁的情形。 当空闲内存很少时,内存页面换入和换出的速度几乎一样快。
使用free查看内存情况
free和vmstat的数据关系
vmstat->swpd = free->Swap->used,都交换区已使用的空间大小。 vmstat->free = free->free,都表示已剩余的内存大小。 vmstat中的buff+cache = free命令的buff/cache。
使用pidstat监控单个进程的内存使用率
pidstat -p 8989 -r 2
|