当前位置:  技术问答>linux和unix

关于进程间发送信号的问题

    来源: 互联网  发布时间:2016-06-27

    本文导语:  问题如下: 创建一个子进程用于监控各个进程的CPU利用率,若发现某个进程CPU利用率超过设定的上限值,就发信号给指定进程,指定进程在收到信号后转入信号处理函数,进行相应的处理。 代码大致如下: 监控进...

问题如下:

创建一个子进程用于监控各个进程的CPU利用率,若发现某个进程CPU利用率超过设定的上限值,就发信号给指定进程,指定进程在收到信号后转入信号处理函数,进行相应的处理。

代码大致如下:
监控进程:
kill(pid, SIGUSR1);

处理进程:
signal(SIGUSR1,sig_handler);

void sig_handler(int signum);

问题:
程序在Linux环境下能正常执行。
在IBM及HP安腾环境执行时,监控进程第一次发信号给处理进程时,处理进程能正确接受并处理,在监控进程第二次发信号给处理进程时,系统提示Signal 16,然后处理进程就退出了。

请教是什么原因导致处理进程退出呢?

|
signal 16 的默认行为是关闭程序,但是安装了自己的信号处理函数就不会关闭进程,而是执行自己的信号处理函数。

有些操作系统,信号必须重新安装。

|
1. signal 设置的handler, 在收到第一次信号后会被reset, 所以需要再handler中返回之前再次调用signal()进行设置。
2. 所以目前推荐的方法是sigaction(), 不需要反复设置

3. 单纯监视cpu使用率的方法好像不太好吧。目前有一种概念叫做maze, 就是在规定时间内cpu占用率达到一定程度就发生问题,有人已经实现了这样功能,你用maze + linux搜索看看

|
你可以试试用sigaction()代替signal()

|
也许不同操作系统在处理信号的机制上有些区别。

你尝试一下在 信号处理函数里重新安装该信号,看看结果怎么样?

|
Signal     Value     Action   Comment
----------------------------------------------------------------------
SIGHUP        1       Term    Hangup detected on controlling terminal
                              or death of controlling process
SIGINT        2       Term    Interrupt from keyboard
SIGQUIT       3       Core    Quit from keyboard
SIGILL        4       Core    Illegal Instruction
SIGABRT       6       Core    Abort signal from abort(3)
SIGFPE        8       Core    Floating point exception
SIGKILL       9       Term    Kill signal
SIGSEGV      11       Core    Invalid memory reference
SIGPIPE      13       Term    Broken pipe: write to pipe with no
                              readers
SIGALRM      14       Term    Timer signal from alarm(2)
SIGTERM      15       Term    Termination signal
SIGUSR1   30,10,16    Term    User-defined signal 1

Linux下的信号处理和传统的UNIX确实是有不同的,而且根据man手册页里面的描述,貌似signal 16的行为确实是terminal程序

    
 
 

您可能感兴趣的文章:

  • 【求助】linux/Unix下创建子进程,向父进程发送信号,子进程也能收到改信号,此时如何让子进程不收到信号
  • 多个进程共用一个信号量,如果某个进程死掉,此时又将信号量锁定,其它进程就死掉,有什么办法可以解决这一问题
  • 如何实现子进程根据父进程的信号来确定是否终止子进程???
  • 非进程所有者如何向该进程发送信号
  • 一个进程可以屏蔽另一个进程对信号的响应吗?
  • 信号灯同步2个进程,一个进程如何主动给另一个进程发送通知?
  • 如何确定信号的来源?即如何知道接收到的信号来自于哪一个进程号?
  • 子进程为什么没有继承父进程的信号
  • 父进程与子进程的信号屏蔽表可以不一样吗?
  • 请教关于Kill向子进程发送信号的问题,子进程如何相应信号,为什么子进程接受不到。
  • 书上说,中断用自旋锁,进程,用信号量,但是,为什么中断不能用信号量?
  • 学习linux的新手问:linux进程信号掩码以及信号阻塞与信号未决怎么理解?
  • 新手提问:父进程结束时子进程会得到什么样的从系统发来的信号?
  • 生产者消费者问题为什么不可以共用一个信号量,如果这个信号量可以设置取值固定为0到N,即当信号量取值为N的时候阻塞进程,是否也可以?
  • 【求助】多进程中 内核信号量无效?
  • linux中 关于 进程和信号的问题
  • 进程间信号通信问题
  • 守护进程为什么要忽略SIGHUP信号呢?
  • 如何向由fork出来的进程家族发送信号?
  • 某daemon进程运行一段时间后接受到不知何地的终止信号导致进程退出,何解?
  • socket发送端、接收端同一机器,kill掉接收端进程,发送端也被kill?
  • 用Delphi或VC怎么向unix发送命令来检测进程甚至能够控制进程?
  • 内核进程间发送信号用哪个函数,如果没有这东西,那内核里异步通知用哪个东西
  • 请问如何判断从raw socket发出的包是哪个进程发送的?
  • 同一个进程,多线程 如何发送消息??
  • 求Linux 2.6 进程调度分析报告一篇,比较急,有的话发送到我的邮箱crazyswan@163.com
  • 内核发送信号给进程的问题,高手来拿分了
  • 核内如何向核外进程发送数据或信息?弄不出来没法毕业了!
  • 进程Afork进程B,进程Bfor进程C,如果进程C退出发出SIGCHLD,A进程是否可以收到 iis7站长之家
  • 应用层可以用signal发送消息通知其他进程,如果是想广播通知的话,怎么办?
  • 网络发送数据时 进程所占内存缓慢增加,直到系统内存耗尽而killed掉,[请大家帮忙]
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • linux僵尸(zombie)进程介绍及清除
  • 进程Afork进程B,进程Bfor进程C,如果进程C退出发出SIGCHLD,A进程是否可以收到
  • Ubuntu查看内存,进程相关命令介绍
  • 如果一个server进程要fork许多子进程,但不等待子进程终止,也不希望子进程结束后处于僵进程状态直到父进程终止。请问可采用什么方法实现
  • linux下进程占用内存空间详解
  • 在多进程中父进程frok子进程,怎样让子进程自举,脱离父进程,而且父进程不退出
  • Linux进程的内核栈和用户栈概念,相互关系及切换过程
  • fock()开出的子进程的进程ID是否进程ID都大于父进程的?
  • android 4.0 托管进程介绍及优先级和回收机制
  • 父进程等待子进程n秒,如果子进程正常退出,父进程立即继续向下执行,如果子出现进程故障一直不退出,父进程等待n秒后继续向下执行,请问
  • linux下进程间通信:共享内存原理及具体用法举例(基于c/c++语言)
  • 多进程问题 子进程读取内容 读完挂起,父进程写 写入后唤醒子进程
  • 一个进程首先监听一个端口,等到有连接了就新开一个进程,让新进程来处理后面的通讯。请问母进程中已经打开了端口,子进程怎么来使用同一
  • 我在一个父进程中,生成了4个子进程,子进程的优先级是一样的。我现在想结束子进程。该如何做?
  • 子进程wait/waitpid//子进程不结束,父进程会等待子进程吗?
  • 在一个进程中我定义了几个全局变量,然后我又fork了几个子进程,子进程中是否可以各自对全局变量进行修改,如果各子进程都对其进行修改,
  • 怎样一次杀掉父进程创建的所有子进程?我在父进程中用kill(0,SIGKILL),结果父进程也给干掉了,参数0难道不是表示除自己外的所有同uid的进
  • 进程创建进程组后,然后创建该组中的进程,然后终止。这里的终止....?
  • 高手请教!linux怎样通过pid获取进程信息,如:进程名、进程状态等?
  • 如何通过进程号获得进程的一些信息,例如:进程运行的目录
  • 【如何彻底杀死子进程】Kill -9子进程后进程呈僵死状态


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3