kill命令在Java应用中使用的注意事项有哪些

本篇内容主要讲解“kill命令在Java应用中使用的注意事项有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“kill命令在Java应用中使用的注意事项有哪些”吧!

市中ssl适用于网站、小程序/APP、API接口等需要进行数据传输应用场景,ssl证书未来市场广阔!成为成都创新互联的ssl证书销售渠道,可以享受市场价格4-6折优惠!如果有意向欢迎电话联系或者加微信:028-86922220(备注:SSL证书合作)期待与您的合作!

linux 中常见的信号

1 SIGHUP 挂起进程

2 SIGINT 终止进程

3 SIGGQUIT   停止进程

9 SIGKILL    无条件终止进程

15 SIGTERM 尽可能终止进程

17 SIGSTOP 无条件停止进程,但不是终止

18 SIGTSTP   停止或者暂停进程,但不终止进程

19 SIGCONT   继续运行停止的进程

在Java中的应用

创建一个SpringBoot的web应用

启动类如下,添加了一个钩子函数,当进程关闭时,将会调用该钩子函数。

@SpringBootApplicationpublic class WebApplication { public static void main(String args[]){ SpringApplication.run(WebApplication.class,args); Runtime.getRuntime().addShutdownHook(new Thread(){ @Override public void run() { System.out.println("do ShutdownHook.......... "); } }); }}

使用maven打包。

mvn package

测试kill -3 

启动应用

这里注意,如果使用相对路径启动应用,则jps看到的进程名称为jar,使用绝对路径如下则显示完整的jar名称:web-1.0.jar。

java -jar ~/aProject/web/target/web-1.0.jar

查看进程pid

lgj@lgj-Lenovo-G470:~/aProject/web/target$ jps | grep web21060 web-1.0.jar

使用kill -3

lgj@lgj-Lenovo-G470:~/aProject/web/target$ kill -3 21060

可以看到启动界面打印了Java应用的堆栈信息。打印的是收到-3信号时刻的线程信息。

如果使用以下方式启动应用

nohup java -jar ~/aProject/web/target/web-1.0.jar &

lgj@lgj-Lenovo-G470:~/aProject/web/target$ ls -l |grep nohup.out -rw------- 1 lgj lgj 22811 Jun 9 00:41 nohup.out

可以看到启动所在的目录多了一个文件nohup.out。该文件记录了应用启动运行过程中的日志。

nohup 命令 & ;

&表示以后台方式运行应用。但如果退出关闭启动的控制台,进程将会停止。

nohup + &也是以后台方式运行应用,但是退出关闭启动的控制台,进程不会停止。且进程日志将会输出到nohup.out中。

此时使用kill -3。打印的线程信息可以到该nohup.out中查看。

测试kill 和kill -9

启动应用

java -jar ~/aProject/web/target/web-1.0.jar

使用kill pid杀死进程

lgj@lgj-Lenovo-G470:~/aProject/web/target$ jps | grep web21470 web-1.0.jarlgj@lgj-Lenovo-G470:~/aProject/web/target$ kill 21470lgj@lgj-Lenovo-G470:~/aProject/web/target$

可以看到输出日志中输出了钩子函数中所打印的

do ShutdownHook..........

2019-06-09 01:18:28.610 INFO 21470 --- [ main] com.demo.web.WebApplication : Started WebApplication in 4.585 seconds (JVM running for 5.274)do ShutdownHook.......... 2019-06-09 01:18:41.381 INFO 21470 --- [ Thread-3] o.s.s.concurrent.ThreadPoolTaskExecutor : Shutting down ExecutorService 'applicationTaskExecutor'

使用kill -9 pid杀死进程

lgj@lgj-Lenovo-G470:~/aProject/web/target$ jps | grep web21568 web-1.0.jarlgj@lgj-Lenovo-G470:~/aProject/web/target$ kill -9 21568

最后的日志并没有输出钩子函数中的内容

2019-06-09 01:20:37.579 INFO 21568 --- [ main] o.s.b.w.embedded.tomcat.TomcatWebServer : Tomcat started on port(s): 8452 (http) with context path ''2019-06-09 01:20:37.585 INFO 21568 --- [ main] com.demo.web.WebApplication : Started WebApplication in 4.171 seconds (JVM running for 4.812)Killed

到此,相信大家对“kill命令在Java应用中使用的注意事项有哪些”有了更深的了解,不妨来实际操作一番吧!这里是创新互联网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!


当前标题:kill命令在Java应用中使用的注意事项有哪些
本文网址:http://hbruida.cn/article/pchojc.html