使用 kill 命令杀死 java进程,你用对了吗?

createh55个月前 (02-01)技术教程35

原文地址:https://dwz.cn/E88v8sLN

作者: 占小狼


在本地调试agent相关功能,需要经常性的杀掉Java进程,验证一些极端情况。

每次都是本能执行如下步骤

  • jps
  • kill -9
  • reboot

有一次发现代码中添加的 ShutdownHook没有生效,难道和 kill命令后面的数字有关?

经过一番查阅,后面的数字代表的是具体信号, kill命令可将指定的信号发送给相应的进程,linux中常见的信号如下:

  • 1 SIGHUP 挂起进程
  • 2 SIGINT 终止进程
  • 3 SIGGQUIT 停止进程
  • 9 SIGKILL 无条件终止进程
  • 15 SIGTERM 尽可能终止进程
  • 17 SIGSTOP 无条件停止进程,但不是终止
  • 18 SIGTSTP 停止或者暂停进程,但不终止进程
  • 19 SIGCONT 继续运行停止的进程

kill命令默认情况使用15,下面我们验证下使用不同信号,有什么不同的表现。

创建一个springBoot应用

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

你可以通过

也可以加上nohup + &启动

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

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

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

kill -3

通过执行jps 拿到对应的pid

并执行 kill-35085,惊奇的发现,Java进程并没有被杀掉,而是打印了一堆线程信息。

kill -9

上一步的 kill-3 并没有成功的把进程杀掉,我们继续使用之前的pid。 这次执行 kill-95085

执行完 -9,java进程消失了,只留下这么一段话。

kill -15

最后,再试试 kill-15,犹豫Java进程已经被 -9 给kill了,需要重新启动一次。

这一次,它打印了钩子函数中的信息,随之进程也消失了。

总结

kill -3这玩意一般用不到,可以打印当前进程的线程信息,但是不会关闭Java应用! kill -9很暴力,不会调用钩子函数ShutdownHook。 kill也就是kill -15很柔和,将会调用钩子函数ShutdownHook,一般ShutdownHook中会进行一些操作,比如保存数据,关闭连接等。

我目前是在职Java开发,如果你现在正在了解Java技术,想要学好Java,渴望成为一名Java开发工程师,在入门学习Java的过程当中缺乏基础的入门视频教程,你可以关注并私信我:01。我这里有一套最新的Java基础JavaSE的精讲视频教程,这套视频教程是我在年初的时候,根据市场技术栈需求录制的,非常的系统完整。

相关文章

java小知识-ShutdownHook(优雅关闭)

作者:京东物流 崔冬冬一、先提出一个问题我们如果在JVM退出的时候做一些事情,比如关闭远程链接,怎么实现呢?二、ShutdownHook简介java里有个方法Runtime.getRuntime#ad...

Spring正确关闭线程池姿势——优雅停机

前言前几天看到一篇文章,关于线程池关闭的知识点,有点收获;给大家分享一下线程池正确关闭方式我们直接用个案例,公布方法上面就是常规的线程池的使用为简化讨论的复杂性,本文的线程池均是指JDK中的java....

实战!如何在退出登录时借助外力使JWT令牌失效?

大家好,我是不才陈某~今天这篇文章介绍一下如何在修改密码、修改权限、注销等场景下使JWT失效。文章的目录如下:解决方案JWT最大的一个优势在于它是无状态的,自身包含了认证鉴权所需要的所有信息,服务器端...

【Linux】Linux服务器高效关闭JAR包服务的绝妙技巧

本文介绍以下几种方法有效地在Linux服务器上关闭正在运行的JAR包服务。在Linux服务器上关闭JAR包服务,可以通过以下几种方法实现:一、使用ps和kill命令查找JAR包进程ID:ps aux...

难搞的偏向锁终于被 Java 移除了(偏向锁的实现原理)

背景在 JDK1.5 之前,面对 Java 并发问题, synchronized 是一招鲜的解决方案:普通同步方法,锁上当前实例对象静态同步方法,锁上当前类 Class 对象同步块,锁上括号里面配置的...

大白话详解Spring Cloud服务降级与熔断

1. Hystrix断路器概述1.1 分布式系统面临的问题复杂分布式体系结构中的应用程序有数十个依赖关系,每个依赖关系在某些时候将不可避免地失败。这就造成有可能会发生 服务雪崩 。那么什么是服务雪崩呢...