Linux中查看进程、端口以及jps查看进程:ps、top、netstat和jps |
您所在的位置:网站首页 › 查看系统占用端口号 › Linux中查看进程、端口以及jps查看进程:ps、top、netstat和jps |
ps: 查看进程的瞬间消息。 top: 实时监控进程的运行状况,类似于windows的任务管理器。 netstat: 查看系统中的网络连接和端口的监听状况。 jps:是java提供的一个显示当前所有java进程pid的命令. 常用命令: (1)ps -aux | grep 进程名称 (2)ps -ef | grep 进程名称 (3)jps (4)nestat -lntp
场景:某个java进程已经启动,用jps却显示不了该进程进程号?(博客:https://www.cnblogs.com/jpfss/p/11313248.html) 现象: 用ps -ef|grep java能看到启动的java进程,但是用jps查看却不存在该进程的id。待会儿解释过之后就能知道在该情况下,jconsole、jvisualvm可能无法监控该进程,其他java自带工具也可能无法使用 分析: java程序启动后,默认(请注意是默认)会在/tmp/hsperfdata_userName目录下以该进程的id为文件名新建文件,并在该文件中存储jvm运行的相关信息,其中的userName为当前的用户名,/tmp/hsperfdata_userName目录会存放该用户所有已经启动的java进程信息。对于windows机器/tmp用Windows存放临时文件目录代替。 而jps、jconsole、jvisualvm等工具的数据来源就是这个文件(/tmp/hsperfdata_userName/pid)。所以当该文件不存在或是无法读取时就会出现jps无法查看该进程号,jconsole无法监控等问题 原因: (1)、磁盘读写、目录权限问题 若该用户没有权限写/tmp目录或是磁盘已满,则无法创建/tmp/hsperfdata_userName/pid文件。或该文件已经生成,但用户没有读权限 (2)、临时文件丢失,被删除或是定期清理 对于linux机器,一般都会存在定时任务对临时文件夹进行清理,导致/tmp目录被清空。这也是我第一次碰到该现象的原因。常用的可能定时删除临时目录的工具为crontab、redhat的tmpwatch、ubuntu的tmpreaper等等 这个导致的现象可能会是这样,用jconsole监控进程,发现在某一时段后进程仍然存在,但是却没有监控信息了。 (3)、java进程信息文件存储地址被设置,不在/tmp目录下 上面我们在介绍时说默认会在/tmp/hsperfdata_userName目录保存进程信息,但由于以上1、2所述原因,可能导致该文件无法生成或是丢失,所以java启动时提供了参数(-Djava.io.tmpdir),可以对这个文件的位置进行设置,而jps、jconsole都只会从/tmp目录读取,而无法从设置后的目录读物信息,这是我第二次碰到该现象的原因 关于设置该文件位置的参数为-Djava.io.tmpdir 其他: /tmp/hsperfdata_userName/pid文件会在对应java进程退出后被清除。如果java进程非正常退出(如kill -9),那么pid文件会被保留,直到执行一次java命令或是加载了jvm程序的命令(如jps、javac、jstat),会将所有无用的pid文件都清除掉
参考博客1: Linux 中ps 和 top命令详解 https://blog.csdn.net/timchen525/article/details/76364706 参考博客2: Linux中top命令输出详解 https://www.jb51.net/article/165216.htm 参考博客3: Linux netstat命令详解 https://www.cnblogs.com/ftl1012/p/netstat.html
|
今日新闻 |
推荐新闻 |
CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3 |