首页 > 系统相关 >kill 进程时遇到的一件有意思的事情

kill 进程时遇到的一件有意思的事情

时间:2023-04-06 14:37:28浏览次数:54  
标签:有意思 pkill pid 命令 kill pgrep 进程

案例现象

一般来讲,我们在 kill 掉一个进程的时候通常有两个选择:

  1. 找到进程的 pid 号,然后执行 kill 命令

  2. 找到进程的名字,然后执行 pkill 命令

 

pkill 和 kill 命令都是向指定的进程发送信号,从而完成终结进程的操作,主要区别在于 pkill 命令与 pgrep 配套使用,能够踢出指定终端用户、同时根据 UID 和用户名来终止进程

 

今天给大家分享一件我在使用 pkill 命令时遇到的比较有意思的事情

 

这台机器上(Cent OS7)运行着一个进程 after_sleep60s_output

 

 

执行 pkill 命令

 

 

然后当我使用 ps 命令查看的时候,我发现这个进程还在,而且返回了状态码 1

 

用 kill 命令试试,发现成功了

 

奇怪?为什么用 pkill 命令 kill 不掉这个进程?

 

定位问题

通过 man pkill 我发现,pkill 命令是默认结合 pgrep 来使用的

 

pgrep 首先找出目标进程(running),然后 pkill 再根据 pgrep 的结果来 kill 目标进程

 

 

pgrep 找目标进程是通过获取 /proc/[pid]/stat 文件中的进程名来实现的,但是这个文件中的进程名是有长度限制的——只有15个字符

 

Linux 中的每一个进程都维护了一个 struct_task_struct 结构体,这个结构体在/usr/src/kernels/内核版本/include/linux/sched.h里面

 

这里面有一个字段定义了不包括路径的可执行文件的名字,最大长度是 16 bytes,除去最后一个留给 null 的,就只有最多 15 个字符

 

 

 

然后我们看一下上面例子中进程对应的 stat 文件

 

 

可以看到文件里面的进程名字被截断成了15个字符:after_sleep60s_

 

如果要使用 pkill 命令,正确方式如下:

 

你也可以加一个 -f 参数

 

这个参数会告诉 pkill 不去/proc/[pid]/stat 文件找进程,而是去 /proc/[pid]/cmdline

里面找

 

这个文件里面包含了进程启动的时候的完整命令,包括参数

 

解决问题

想要准确的 kill 掉一个进程,可以使用下面的方法:

  • pidof命令获取到进程对应的 PID,再使用 kill 命令

  • 使用 systemd 启动的,通过 systemctl 命令来控制

  • 使用 pkill 命令的时候建议加上 -f 参数

 

最后附上相关 issue 链接:

1、https://stackoverflow.com/questions/23534263/what-is-the-maximum-allowed-limit-on-the-length-of-a-process-name

标签:有意思,pkill,pid,命令,kill,pgrep,进程
From: https://www.cnblogs.com/edisonfish/p/17292630.html

相关文章

  • 进程、线程退出方式
    一、进程退出有8种方式使进程终止(termination),其中5种为正常终止:(1)从main返回。(2)调用exit。(3)调用_exit或_Exit。(4)最后一个线程从其启动例程返回。(5)最后一个线程调用pthread_exit。异常终止有3种方式:(6)调用abort。(7)接到一个信号并终止。(8)最后一个线程对取消请求作出响应。......
  • pytest多进程运行用例,缩短测试时间
    -n表示多进程执行用例,如下所示‘2'表示2个进程同时执行用例,数值的确定要根据执行机的cpu核数前置条件:安装pytest-xdist插件,安装命令“pipinstallpytest-xdist注意:每个进程执行的测试用例是随机的,不可控,所以测试用例要解耦1importos23importpytest45#整个项......
  • 使用jstack排查JVM进程死锁
    前言在Linux系统使用JDK自带的jstack指令分析输出的线程信息排查死锁的详细步骤。例子程序下面是一个模拟线程死锁的例子程序,编译(javacDeadLockSample.java)后执行(javaDeadLockSample)这个程序来启动一个JVM进程。其中一个线程会成功获取到DeadLockSample的Class对象锁持续打......
  • 进程间通信方式--匿名管道通信
    管道的特点管道其实是一个在内核内存中维护的缓冲器,这个缓冲器的存储能力时有限的,不同的操作系统大小不一定相同。管道拥有文件的特质:读操作、写操作,匿名管道没有文件实体,有名管道由文件实体,但不存储数据。可以按照操作文件的方式对管道进行操作。一个管道是一个字节流,试用管......
  • 进程间通信-信号量
    资源竞争资源竞争:当多个进程在同时访问共享资源时,会产生资源竞争,最终最导致数据混乱临界资源:不允许同时有多个进程访问的资源,包括硬件资源(CPU、内存、存储器以及其他外围设备)与软件资源(共享代码段、共享数据结构)临界区:访问临界资源代码多进程对stdout资源的竞争......
  • windows监控进程是否存在
    @echooff:runtasklist/FI"IMAGENAMEeqSDPAgent.exe"2>NUL|find/I/N"SDPAgent.exe">NULif"%ERRORLEVEL%"=="0"(echoProgramisrunningfor/f"skip=3tokens=2"%%iin(......
  • node子进程(Child Process)获取硬盘分区
    node  child_process文档 child_process.exec(command[,options][,callback])command <string> Thecommandtorun,withspace-separatedarguments.options<Object>cwd <string> Currentworkingdirectoryofthechildprocess. Default: null.env......
  • EasyCVR新增功能:Windows系统下托盘可显示进程图标
    EasyCVR视频融合平台基于云边端一体化架构,具有强大的数据接入、处理及分发能力,平台支持海量视频汇聚管理,可支持多协议接入,包括市场主流标准协议与厂家私有协议及SDK,如:国标GB28181、RTMP、RTSP/Onvif、海康Ehome、海康SDK、宇视SDK等(具体见下图)。近期我们对EasyCVR新增了托盘显示......
  • 蓝牙三国Kill:这算不算是鸡肋?
    其实三国杀官方开发的Java、Android、iOS的版本都早就发布了,那这款在与最近又特地从JAVA移植到Android平台的蓝牙三国Kill算不算是食之无味弃之可惜的鸡肋呢?看看就知道了。游戏名称:蓝牙三国Kill平台:Android价格:免费三国杀的基本规则小编相信大家都很熟悉了,不需要额......
  • 进程间通信的概念-简介
    进程间通信的概念进程是一个独立的资源分配单元,不同进程(这里所说的进程通常是指用户进程)之间的资源是独立的,没有关联。不能在一个进程中访问另一个进程的资源。但是,进程不是孤立的,不同的进程需要进行信息的交互和状态的传递等,因此需要进程间通信(IPC:InterprocessesCommunica......