监控本地机器(IdeaIJ)
一.在本地下载jprofiler9.2的Windows包
二.安装jprofile9.2(搭配IdeaIJ15.1,如果是8则最高支持IdeaIJ13)
三.在IdeaIJ中下载jprofiler插件
Setting-plugins-下载jprofiler,下载完需要重启IdeaIJ
如果出现jprofiler的图标表示成功
四.启动IdeaIJ(首次启动需要选择本地jprofiler的安装位置)
Run-profiler或者直接点击IdeaIJ上的profile图标
监控远程机器
本地和远程机器安装jprofiler9.2版本
一.远程安装jprofiler9.2, tomcat1.7, jdk1.7
下载Linux tar包,解压到/usr/local/
二.本地安装(同上监控本地机器)
三.上传jar包到tomcat/webapps中
四.打开本地jprofiler且进行配置(以远程为例)
1.an application server,locally or remotely
2. 选择tomcat
3.选择监控本机还是远程(远程是)
4. 选择远程机器
5. 选择jvm信息(mode默认)
6. 选择启动jprofiler的方式(快速启动)
7. 输入远程机器的IP地址
8. 输入远程机器jprofier的安装路径
9. 选择如何同步jprofiler配置
10. 利用startup.sh启动(选择本地的startup.sh)
a) 下载tomcat/bin中startup.sh到本地,同时生成一个startup_jprofiler.sh(相比startup.sh多了catalina_opts路径,catalina.sh是tomcat的配置文件)
b)将其上传到tomcat的bin目录下
c)更改startup_jprofiler.sh的权限且启动监听 chmod +x startup_jprofiler.sh
11.设置端口(默认8849即可,不建议用80或者是8080)
12. 完成本地的jprofiler启动
五.Jprofiler的介绍
1. Telemetries
A)overview
B)memory
C)recorded objects记录对象
D)recorded throughput
E)gc activity
2. Live memory(内存)
A)all objects(类、包、组件)
B)recorded objects(活动对象、垃圾回收对象、活动的和垃圾回收对象)
C)Allocation call tree分配调用树
D)Allocation hot spots分配热点视图(所选类的对象被分配在哪的方法列表)
E)class tracker类跟踪
1.Heap walker堆遍历(查看对象的引用关系,查找内存泄漏)
2. Cpu views
3. Threads(所有线程的运行状态)
A) Thread history
绿色表示线程正在运行
橙色睡眠
红色阻塞
蓝色线程等待Java库的网络操作完成,在线监听socket链接或者等待读写数据到socket中
B)Thread monitor所有线程的运行列表
C)Thread dumps所有线程的堆栈跟踪
4. Monitors&locks(所有线程持有锁的情况及锁的信息)
A)Current locking显示jvm当前的锁定状态
B)Current monitors显示等待或者阻塞的线程
C)locking history锁定历史
D)monitor history显示等待或者阻塞的线程的历史
E)monitor usage statistics静态计算统计监控搜集的数据
5. Databases(数据库快照对比)
6. Jee&probes(Java探针)
7. Mbeans(描述可管理的资源,是一个Java对象)
监控多个机器(在机器上安装jprofiler包并进行配置)
一.点击Start Center --New session -- new server integration重复上面的配置即可
问题:如何监控一台机器上的多个tomcat
注意事项:切换成root用户
用法参照https://wenku.baidu.com/view/fcdbea47f02d2af90242a8956bec0975f465a43e.html
:%s/待替换/替换/g 全部替换所有行的所有字符串
Isof -i:8080查端口是否被占用