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

2024-11-08 09:04:00
admin
原创
31
摘要:问题描述:我有一个 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 虚拟机中运行,该虚拟机是从操作系统抽象出来的。并非所有操作系统概念都存在于此机器中。

相关推荐
  为什么项目管理通常仍然耗时且低效?您是否还在反复更新电子表格、淹没在便利贴中并参加每周更新会议?这确实是耗费时间和精力。借助软件工具的帮助,您可以一目了然地全面了解您的项目。如今,国内外有足够多优秀的项目管理软件可以帮助您掌控每个项目。什么是项目管理软件?项目管理软件是广泛行业用于项目规划、资源分配和调度的软件。它使项...
项目管理软件   601  
  华为IPD与传统研发模式的8大差异在快速变化的商业环境中,产品研发模式的选择直接决定了企业的市场响应速度和竞争力。华为作为全球领先的通信技术解决方案供应商,其成功在很大程度上得益于对产品研发模式的持续创新。华为引入并深度定制的集成产品开发(IPD)体系,相较于传统的研发模式,展现出了显著的差异和优势。本文将详细探讨华为...
IPD流程是谁发明的   7  
  如何通过IPD流程缩短产品上市时间?在快速变化的市场环境中,产品上市时间成为企业竞争力的关键因素之一。集成产品开发(IPD, Integrated Product Development)作为一种先进的产品研发管理方法,通过其结构化的流程设计和跨部门协作机制,显著缩短了产品上市时间,提高了市场响应速度。本文将深入探讨如...
华为IPD流程   9  
  在项目管理领域,IPD(Integrated Product Development,集成产品开发)流程图是连接创意、设计与市场成功的桥梁。它不仅是一个视觉工具,更是一种战略思维方式的体现,帮助团队高效协同,确保产品按时、按质、按量推向市场。尽管IPD流程图可能初看之下显得错综复杂,但只需掌握几个关键点,你便能轻松驾驭...
IPD开发流程管理   8  
  在项目管理领域,集成产品开发(IPD)流程被视为提升产品上市速度、增强团队协作与创新能力的重要工具。然而,尽管IPD流程拥有诸多优势,其实施过程中仍可能遭遇多种挑战,导致项目失败。本文旨在深入探讨八个常见的IPD流程失败原因,并提出相应的解决方法,以帮助项目管理者规避风险,确保项目成功。缺乏明确的项目目标与战略对齐IP...
IPD流程图   8  
热门文章
项目管理软件有哪些?
云禅道AD
禅道项目管理软件

云端的项目管理软件

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

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

内置subversion和git源码管理

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

免费试用