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

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

相关推荐
  政府信创国产化的10大政策解读一、信创国产化的背景与意义信创国产化,即信息技术应用创新国产化,是当前中国信息技术领域的一个重要发展方向。其核心在于通过自主研发和创新,实现信息技术应用的自主可控,减少对外部技术的依赖,并规避潜在的技术制裁和风险。随着全球信息技术竞争的加剧,以及某些国家对中国在科技领域的打压,信创国产化显...
工程项目管理   1565  
  为什么项目管理通常仍然耗时且低效?您是否还在反复更新电子表格、淹没在便利贴中并参加每周更新会议?这确实是耗费时间和精力。借助软件工具的帮助,您可以一目了然地全面了解您的项目。如今,国内外有足够多优秀的项目管理软件可以帮助您掌控每个项目。什么是项目管理软件?项目管理软件是广泛行业用于项目规划、资源分配和调度的软件。它使项...
项目管理软件   1354  
  信创国产芯片作为信息技术创新的核心领域,对于推动国家自主可控生态建设具有至关重要的意义。在全球科技竞争日益激烈的背景下,实现信息技术的自主可控,摆脱对国外技术的依赖,已成为保障国家信息安全和产业可持续发展的关键。国产芯片作为信创产业的基石,其发展水平直接影响着整个信创生态的构建与完善。通过不断提升国产芯片的技术实力、产...
国产信创系统   21  
  信创生态建设旨在实现信息技术领域的自主创新和安全可控,涵盖了从硬件到软件的全产业链。随着数字化转型的加速,信创生态建设的重要性日益凸显,它不仅关乎国家的信息安全,更是推动产业升级和经济高质量发展的关键力量。然而,在推进信创生态建设的过程中,面临着诸多复杂且严峻的挑战,需要深入剖析并寻找切实可行的解决方案。技术创新难题技...
信创操作系统   27  
  信创产业作为国家信息技术创新发展的重要领域,对于保障国家信息安全、推动产业升级具有关键意义。而国产芯片作为信创产业的核心基石,其研发进展备受关注。在信创国产芯片的研发征程中,面临着诸多复杂且艰巨的难点,这些难点犹如一道道关卡,阻碍着国产芯片的快速发展。然而,科研人员和相关企业并未退缩,积极探索并提出了一系列切实可行的解...
国产化替代产品目录   28  
热门文章
项目管理软件有哪些?
云禅道AD
禅道项目管理软件

云端的项目管理软件

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

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

内置subversion和git源码管理

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

免费试用