在 Linux 中如何判断哪个进程向我的进程发送了信号

2024-11-08 09:04:00
admin
原创
56
摘要:问题描述:我有一个 Java 应用程序收到SIG TERM。我想知道发送此信号的进程的 pid。 这可能吗?解决方案 1:两个 Linux 特定的方法是SA_SIGINFO和signalfd(),它们允许程序接收有关发送的信号的非常详细的信息,包括发送者的 PID。调用sigaction()并向其传递一个s...

问题描述:

我有一个 Java 应用程序收到SIG TERM。我想知道发送此信号的进程的 pid。

这可能吗?


解决方案 1:

两个 Linux 特定的方法是SA_SIGINFOsignalfd(),它们允许程序接收有关发送的信号的非常详细的信息,包括发送者的 PID。

  • 调用sigaction()并向其传递一个struct sigaction包含所需信号处理程序sa_sigactionSA_SIGINFO已设置标志的参数sa_flags。使用此标志,您的信号处理程序将收到三个参数,其中一个是siginfo_t包含发送方的 PID 和 UID 的结构。

  • 调用signalfd()signalfd_siginfo从中读取结构(通常在某种选择/轮询循环中)。内容将类似于siginfo_t

使用哪一个取决于您的应用程序是如何编写的;它们可能在纯 C 之外无法很好地工作,而且我也不指望它们在 Java 中工作。它们在 Linux 之外也无法移植。它们也可能是实现您想要实现的目标的错误方式。

解决方案 2:

我还需要在程序中识别信号发送者,因此我采用了 Grawity 的答案,并将其用于我的程序中,效果很好。

以下是示例代码:

发送信号提升.c

// send signal to self test - raise()

#include <stdio.h>
#include <signal.h>
#include <pthread.h>
#include <unistd.h>
#include <stdlib.h>
#include <errno.h>
#include <string.h>

static int int_count = 0, max_int = 5;
static struct sigaction siga;

static void multi_handler(int sig, siginfo_t *siginfo, void *context) {
    // get pid of sender,
    pid_t sender_pid = siginfo->si_pid;

    if(sig == SIGINT) {
        int_count++;
        printf("INT(%d), from [%d]
", int_count, (int)sender_pid);
        return;
    } else if(sig == SIGQUIT) {
        printf("Quit, bye, from [%d]
", (int)sender_pid);
        exit(0);
    }

    return;
}

int raise_test() {
    // print pid
    printf("process [%d] started.
", (int)getpid());

    // prepare sigaction
    siga.sa_sigaction = *multi_handler;
    siga.sa_flags |= SA_SIGINFO; // get detail info

    // change signal action,
    if(sigaction(SIGINT, &siga, NULL) != 0) {
        printf("error sigaction()");
        return errno;
    }
    if(sigaction(SIGQUIT, &siga, NULL) != 0) {
        printf("error sigaction()");
        return errno;
    }

    // use "ctrl + c" to send SIGINT, and "ctrl + \" to send SIGQUIT,
    int sig;
    while(1) {
        if(int_count < max_int) {
            sig = SIGINT;
        } else {
            sig  = SIGQUIT;
        }
        raise(sig); // send signal to itself,

        sleep(1); // sleep a while, note that: SIGINT will interrupt this, and make program wake up,
    }

    return 0;
}

int main(int argc, char *argv[]) {
    raise_test();
    return 0;
}

编译:

gcc -pthread -Wall send_signal_raise.c

执行:

./a.out

它的作用:

该程序SIGINT向自身发送 10 次,然后才发送SIGQUIT终止自身。

另外,在执行过程中,按CTRL+C发送SIGINT,或按CTRL+`发送SIGQUIT`将手动终止程序。

该程序可以成功识别是谁发送了信号。

解决方案 3:

BCC包含killsnoop实用程序。它需要支持 BPF 的内核。

摘自killsnoop (8) 手册页:

       killsnoop  traces  the  kill()  syscall, to show signals sent via this method. This may be
       useful to troubleshoot  failing  applications,  where  an  unknown  mechanism  is  sending
       signals.

       This  works by tracing the kernel sys_kill() function using dynamic tracing, and will need
       updating to match any changes to this function.

       This makes use of a Linux 4.5 feature (bpf_perf_event_output()); for  kernels  older  than
       4.5, see the version under tools/old, which uses an older mechanism.

       Since this uses BPF, only the root user can use this tool.

解决方案 4:

不,信号并非用作进程间通信通道。据我所知,没有传递 PID。发送 PID 与我所见过的所有信号用途无关。您可以相对确定发送信号的进程要么具有 root 权限,要么与您的进程属于同一个 UID。

发送信号的进程可能不再存在。如果使用 kill 命令而不是 shell 内置命令,则几乎可以肯定该进程不再存在。

从 Java 的角度来看,这更加困难。该过程在 Java 虚拟机中运行,该虚拟机是从操作系统抽象出来的。并非所有操作系统概念都存在于此机器中。

相关推荐
  为什么项目管理通常仍然耗时且低效?您是否还在反复更新电子表格、淹没在便利贴中并参加每周更新会议?这确实是耗费时间和精力。借助软件工具的帮助,您可以一目了然地全面了解您的项目。如今,国内外有足够多优秀的项目管理软件可以帮助您掌控每个项目。什么是项目管理软件?项目管理软件是广泛行业用于项目规划、资源分配和调度的软件。它使项...
项目管理软件   681  
  在项目管理领域,集成产品开发(IPD)流程以其高效、协同的特点,被众多企业视为提升产品竞争力的关键。IPD流程强调跨部门、跨职能的紧密合作,以确保产品从概念到市场各个环节的无缝衔接。然而,实现这一目标并非易事,它需要企业深刻理解并掌握IPD流程中的跨部门协作艺术。本文将深入探讨IPD流程中跨部门协作的三个关键点,旨在为...
IPD项目管理咨询   9  
  掌握IPD流程图:提升团队协作的关键路径在当今快速变化的商业环境中,团队协作的效率与效果直接关系到项目的成功与否。集成产品开发(Integrated Product Development,简称IPD)作为一种先进的研发管理理念,通过跨部门、跨领域的协同工作,能够显著提升产品开发的速度与质量。而IPD流程图,则是这一理...
IPD流程阶段   9  
  IPD流程概述:理解其核心价值与实施背景集成产品开发(Integrated Product Development,简称IPD)是一种先进的产品开发管理理念,它强调跨部门协作、市场导向和快速响应变化的能力。IPD流程不仅关注产品本身的技术创新,更注重将市场、研发、生产、销售等各个环节紧密集成,以实现产品从概念到市场的高...
华为IPD是什么   7  
  在项目管理领域,IPD(Integrated Product Development,集成产品开发)流程以其跨部门协作、高效决策和快速响应市场变化的特点,被众多企业视为提升竞争力的关键。然而,实践IPD流程并非易事,项目管理中的种种错误往往阻碍了其效果的充分发挥。本文旨在深入探讨如何在实施IPD流程时避免这些常见错误,...
IPD框架   7  
热门文章
项目管理软件有哪些?
云禅道AD
禅道项目管理软件

云端的项目管理软件

尊享禅道项目软件收费版功能

无需维护,随时随地协同办公

内置subversion和git源码管理

每天备份,随时转为私有部署

免费试用