jvm 性能调优工具之 jps 命令详解
JPS名称:jps - Java Virtual Machine Process Status Tool
命令用法:jps [options] [hostid]
options:命令选项,用来对输出格式进行控制
hostid:指定特定主机,可以是ip地址和域名, 也可以指定具体协议,端口。
[protocol:][[//]hostname][:port][/servername]
功能描述:
jps是用于查看有权访问的hotspot虚拟机的进程. 当未指定hostid时,默认查看本机jvm进程,否者查看指定的hostid机器上的jvm进程,此时hostid所指机器必须开启jstatd服务。 jps可以列出jvm进程lvmid,主类类名,main函数参数, jvm参数,jar名称等信息。
jps 命令类似与 linux 的 ps 命令,但是它只列出系统中所有的 Java 应用程序。 通过 jps 命令可以方便地查看 Java 进程的启动类、传入参数和 Java 虚拟机参数等信息。
如果在 linux 中想查看 java 的进程,一般我们都需要 ps -ef | grep java 来获取进程 ID。
如果只想获取 Java 程序的进程,可以直接使用 jps 命令来直接查看。
使用方法:
在当前命令行下输入jps(jps存放在JAVA_HOME/bin/jps,使用时为了方便需将JAVA_HOME/bin/加入到Path) 。
参数说明:
无参数:显示进程的ID和类的名称
-q:仅显示进程ID
-m:输出传入 main 方法的参数
-l:输出java进程全路径,比如应用程序主类完整package名称或jar完整名称
-v:输出jvm参数,比如堆大小,此命令方便我们查看JVM大小,不用去找配置文件
-V:输出通过flag文件(.hotsportrc或-XX:Flags=<filename>)传递到JVM中的参数
用法示例:
[root@hadoop ~]# cd /usr/local/zookeeper/bin/ #首先启动zookeeper,对比一下jps和ps -ef|grep java的区别
[root@hadoop bin]# zkServer.sh start
ZooKeeper JMX enabled by default
Using config: /usr/local/zookeeper/bin/../conf/zoo.cfg
Starting zookeeper ... STARTED
[root@hadoop bin]# jps #jps 不带参数,默认显示进程ID和启动类的名称。
4060 QuorumPeerMain
4077 Jps
[root@hadoop bin]# ps -ef|grep java
root 4060 1 1 16:50 pts/0 00:00:00 /usr/java/bin/java -Dzookeeper.log.dir=. -Dzookeeper.root.logger=INFO,CONSOLE -cp /usr/local/zookeeper/bin/../build/classes:/usr/local/zookeeper/bin/../build/lib/*.jar:/usr/local/zookeeper/bin/../lib/slf4j-log4j12-1.6.1.jar:/usr/local/zookeeper/bin/../lib/slf4j-api-1.6.1.jar:/usr/local/zookeeper/bin/../lib/netty-3.10.5.Final.jar:/usr/local/zookeeper/bin/../lib/log4j-1.2.16.jar:/usr/local/zookeeper/bin/../lib/jline-0.9.94.jar:/usr/local/zookeeper/bin/../zookeeper-3.4.9.jar:/usr/local/zookeeper/bin/../src/java/lib/*.jar:/usr/local/zookeeper/bin/../conf:.:/usr/java/lib/dt.jar:/usr/java/lib/tools.jar:/usr/java/jre/lib -Dcom.sun.management.jmxremote -Dcom.sun.management.jmxremote.local.only=false org.apache.zookeeper.server.quorum.QuorumPeerMain /usr/local/zookeeper/bin/../conf/zoo.cfg
root 4088 2748 0 16:50 pts/0 00:00:00 grep --color=auto java [root@hadoop bin]# jps -q #参数-q只输出进程ID,而不显示出类的名称
4091
4060 [root@hadoop bin]# jps -m #参数-m可以输出传递给Java进程(main方法)的参数
4101 Jps -m
4060 QuorumPeerMain /usr/local/zookeeper/bin/../conf/zoo.cfg [root@hadoop bin]# jps -l #参数-l可以输出主函数的完整路径(类的全路径)
4060 org.apache.zookeeper.server.quorum.QuorumPeerMain
4111 sun.tools.jps.Jps [root@hadoop bin]# jps -v #参数-v可以显示传递给Java虚拟机的参数
4121 Jps -Denv.class.path=.:/usr/java/lib/dt.jar:/usr/java/lib/tools.jar:/usr/java/jre/lib -Dapplication.home=/usr/java -Xms8m
4060 QuorumPeerMain -Dzookeeper.log.dir=. -Dzookeeper.root.logger=INFO,CONSOLE -Dcom.sun.management.jmxremote -Dcom.sun.management.jmxremote.local.only=false [root@hadoop bin]# jps -V
4131 Jps
4060 QuorumPeerMain
获取远程服务器 jps 信息
jps [ip]:可以列出远程机器上的java进程信息,不过需要安全授权。
步骤:
1.在远程机器%JAVA_HOME%/bin/目录下创建jstatd.all.policy文件,内容如下:
grant codebase "file:${java.home}/../lib/tools.jar" {
permission java.security.AllPermission;
};
2.在远程机器%JAVA_HOME%/bin/目录下,执行如下命令:
jstatd -J-Djava.security.policy=jstatd.all.policy &
3.在本地机器上使用jps访问远程机器上的JVM。
现在就让我们实际试一下吧~
.首先在本地执行命令,发现报错(报错信息:RMI服务未注册)
C:\Users\Administrator>jps 192.168.146.128
RMI Registry not available at 192.168.146.128:
Connection refused to host: 192.168.146.128; nested exception is:
java.net.ConnectException: Connection refused: connect .在远程服务器创建策略文件并执行命令
[root@hadoop ~]# java -version #查看java版本
java version "1.8.0_11"
Java(TM) SE Runtime Environment (build 1.8.0_11-b12)
Java HotSpot(TM) -Bit Server VM (build 25.11-b03, mixed mode)
[root@hadoop ~]# echo $JAVA_HOME #找到JAVA_HOME目录
/usr/java
[root@hadoop ~]# cd /usr/java/bin/ #进入%JAVA_HOME%/bin/目录
[root@hadoop bin]# vi jstatd.all.policy #创建文件
grant codebase "file:${java.home}/../lib/tools.jar" {
permission java.security.AllPermission;
};
[root@hadoop bin]# jstatd -J-Djava.security.policy=jstatd.all.policy & #执行命令
[] .测试是否成功
[root@hadoop ~]# cd /usr/local/zookeeper/bin/ #启动一个java进程,这里我启动zk
[root@hadoop bin]# zkServer.sh start
ZooKeeper JMX enabled by default
Using config: /usr/local/zookeeper/bin/../conf/zoo.cfg
Starting zookeeper ... STARTED
[root@hadoop bin]# jps #在远程机器上查看jps
QuorumPeerMain
Jstatd
Jps C:\Users\Administrator>jps 192.168.146.128 #在本地机器上查看jps
QuorumPeerMain
Jstatd
实操
遇到问题:Java RMI:rmi Connection refused to host: 127.0.0.1异常解决
解决方法:https://blog.csdn.net/chenchaofuck1/article/details/51558995
参考:
jps官方文档:https://docs.oracle.com/javase/1.5.0/docs/tooldocs/share/jps.html
JAVA JPS 命令详解:https://www.cnblogs.com/tulianghui/p/5914535.html
jvm 性能调优工具之 jps:https://www.jianshu.com/p/d39b2e208e72
jvm 性能调优工具之 jps 命令详解的更多相关文章
- jvm 性能调优工具之 jstat 命令详解
Jstat名称:Java Virtual Machine statistics monitoring tool 官方文档:https://docs.oracle.com/javase/1.5.0/do ...
- jvm 性能调优工具之 jmap 命令详解
jmap名称:Java Memory Map(内存映射) 官方文档:https://docs.oracle.com/javase/1.5.0/docs/tooldocs/share/jmap.html ...
- JVM性能调优监控工具专题一:JVM自带性能调优工具(jps,jstack,jmap,jhat,jstat,hprof)
性能分析工具jstatjmapjhatjstack 前提概要: JDK本身提供了很多方便的JVM性能调优监控工具,除了集成式的VisualVM和jConsole外,还有jps.jsta ...
- 【十一】jvm 性能调优工具之 jmap
jvm 性能调优工具之 jmap 概述 命令jmap是一个多功能的命令.它可以生成 java 程序的 dump 文件, 也可以查看堆内对象示例的统计信息.查看 ClassLoader 的信息以及 fi ...
- JVM 性能调优工具
jdk自带的工具,在macOs系统中的目录位置(jdk具体版本位置要替换):/Library/Java/JavaVirtualMachines/jdk1.8.0_191.jdk/Contents/Ho ...
- 【十三】jvm 性能调优工具之 jstack
一.介绍 jstack是java虚拟机自带的一种堆栈跟踪工具.jstack用于打印出给定的java进程ID或core file或远程调试服务的Java堆栈信息,如果是在64位机器上,需要指定选项&qu ...
- jvm 性能调优工具之 jstat
概述 Jstat是JDK自带的一个轻量级小工具.全称“Java Virtual Machine statistics monitoring tool”,它位于java的bin目录下,主要利用JVM内建 ...
- 【十二】jvm 性能调优工具之 jhat (JVM Heap Analysis Tool)
jhat也是jdk内置的工具之一.主要是用来分析java堆的命令,可以将堆中的对象以html的形式显示出来,包括对象的数量,大小等等,并支持对象查询语言. jhat 非常耗费cpu和内存,所以一般不使 ...
- jvm 性能调优工具之 jmap
概述 命令jmap是一个多功能的命令.它可以生成 java 程序的 dump 文件, 也可以查看堆内对象示例的统计信息.查看 ClassLoader 的信息以及 finalizer 队列. jmap ...
随机推荐
- 使用Commons Logging
Commons Logging 和Java标准库提供的日志不同,Commons Logging是一个第三方日志库,它是由Apache创建的日志模块,需要导入commons-logging-1.2.ja ...
- ranche2.0-CN
遵循以下两步,快速运行rancher2.0 Step1:准备一台linux主机 准备一台64位Linux主机(推荐centos7.5+),至少4GB内存.安装Kubernetes支持的Docker-c ...
- 将js进行到底:node学习4
使用Node做web开发 HTTP与TCP 上一回使用node.js的NET(TCP)模块开发了一个聊天室demo.单纯用到了原始的TCP协议,可以说TCP是HTTP,SMTP,FTP的鼻祖了,后面的 ...
- Springboot整合Dubbo和Zookeeper
Dubbo是一款由阿里巴巴开发的远程服务调用框架(RPC),其可以透明化的调用远程服务,就像调用本地服务一样简单.截至目前,Dubbo发布了基于Spring Boot构建的版本,版本号为0.2.0,这 ...
- 使用Win10自带的虚拟机安装Linux
Win10自带了一款虚拟机,感觉不错,可以试用一下: 安装:http://news.mydrivers.com/1/650/650018.htm 主要思路就是在BIOS里面开启CPU虚拟化,然后在Wi ...
- SolrJ 的运用
SolrJ 是操作 Solr 的 Java 客户端,它提供了增加.修改.删除.查询 Solr 索引的 Java 接口.SolrJ 针对 Solr 提供了 REST 的 Http 接口进行了封装, So ...
- 致敬——C语言
2016年4月26日21:00 OJ考试平台关闭,C语言这门课程也就随之结束了. 回顾学习历程,坦诚的讲学习期间也努力过也颓废过,但从来没有绝对的放弃过.由于种种客观原因与主观原因导致没有给 ...
- TCP传输连接管理
TCP传输连接管理 一.传输连接的三个阶段 1.1.概述 传输连接就有三个阶段,即:连接建立.数据传送和连接释放. 连接建立过程中要解决以下三个问题: 要使每一方能够确知对方的存在. 要允许双方协商一 ...
- Context与ApplicationContext的区别
ApplicationContext并没有这个类,其实更应该叫做:Activity与Application在作为Context时的区别.嗯,的确是这样的,大家在需要Context的时候,如果是在Act ...
- 如何看待Java是世界上最好的语言?
Java出现二十多年以来,一直都是主流的开发语言,Java创建于 1995 年,在 20多年的发展历程中,Java 已经证明自己是用于自定义软件开发的顶级通用编程语言. Java 广泛应用于科学教育. ...