91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

在Java中使用kill命令時需要注意哪些事項

發布時間:2021-03-24 17:24:59 來源:億速云 閱讀:260 作者:Leah 欄目:編程語言

在Java中使用kill命令時需要注意哪些事項?相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。

kill在linux系統中是用于殺死進程。

kill pid [..]

kill命令可將指定的信號發送給相應的進程或工作。 kill命令默認使用信號為15,用于結束進程或工作。如果進程或工作忽略此信號,則可以使用信號9,強制殺死進程或作業.

因此,如果確保將進程殺死,可以使用-9參數

kill -9 pid [..]

linux 中常見的信號

 1   SIGHUP             掛起進程

 2   SIGINT               終止進程

 3   SIGGQUIT    停止進程

 9   SIGKILL     無條件終止進程

15  SIGTERM          盡可能終止進程

17  SIGSTOP           無條件停止進程,但不是終止

18  SIGTSTP   停止或者暫停進程,但不終止進程

19 SIGCONT   繼續運行停止的進程

在Java中的應用

創建一個SpringBoot的web應用

啟動類如下,添加了一個鉤子函數,當進程關閉時,將會調用該鉤子函數。

@SpringBootApplication
public 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 web
21060 web-1.0.jar

使用kill -3 

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

可以看到啟動界面打印了Java應用的堆棧信息。打印的是收到-3信號時刻的線程信息。

在Java中使用kill命令時需要注意哪些事項

如果使用以下方式啟動應用

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 web
21470 web-1.0.jar
lgj@lgj-Lenovo-G470:~/aProject/web/target$ kill 21470
lgj@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 web
21568 web-1.0.jar
lgj@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應用時

1.kill -3 pid可以打印當前進程的線程信息,但是不會關閉Java應用!

2.kill pid 也就是kill -15 pid ,將會調用鉤子函數ShutdownHook,一般ShutdownHook中會進行一些操作,比如保存數據,關閉連接等。

3.kill  -9 pid.不會調用鉤子函數ShutdownHook。

看完上述內容,你們掌握在Java中使用kill命令時需要注意哪些事項的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

吕梁市| 囊谦县| 汕头市| 阿克陶县| 崇州市| 阳江市| 阿尔山市| 响水县| 鄂尔多斯市| 马鞍山市| 乌拉特后旗| 申扎县| 松阳县| 泌阳县| 日喀则市| 中山市| 札达县| 阿合奇县| 吕梁市| 正镶白旗| 定远县| 逊克县| 武宁县| 灵璧县| 和林格尔县| 抚顺县| 曲沃县| 关岭| 衡阳市| 新乡县| 民县| 呼和浩特市| 张掖市| 平乐县| 房山区| 米林县| 清流县| 贺兰县| 根河市| 九龙坡区| 陵水|