及其含义-进程间通信-Linux常用信号 (及其释义)

教程大全 2025-07-17 00:52:00 浏览

进程的管理主要是指进程的关闭与重启。我们一般关闭或重启软件,都是关闭或重启它的程序,而不是直接操作进程的。比如,要重启 apache 服务,一般使用命令”service httpd restart”重启 apache的程序。

那么,可以通过直接管理进程来关闭或重启 apache 吗?答案是肯定的,这时就要依赖进程的了。我们需要给予该进程号,告诉进程我们想要让它做什么。

系统中可以识别的信号较多,我们可以使用命令”kill -l”或”man 7 signal”来查询。命令如下:

[root@localhost ~]#kill -l1) SIGHUP 2) SIGINT 3) SIGQUIT 4) SIGILL 5) SIGTRAP6) SIGABRT 7) SIGBUS 8) SIGFPE 9) SIGKILL 10) SIGUSR111)SIGSEGV 12) SIGUSR2 13) SIGPIPE 14) SIGALRM 15)SIGTERM 16) SIGSTKFLT 17) SIGCHLD 18) SIGCONT 19) SIGSTOP 20) SIGTSTP 21) SIGTTIN 22) SIGTTOU 23) SIGURG24) SIGXCPU 25) SIGXFSZ 26) SIGVTALRM 27) SIGProF 28) SIGWINCH 29) SIGIO 30) SIGPWR 31) SIGSYS 34) SIGRTMIN 35) SIGRTMIN+1 36) SIGRTMIN+2 37) SIGRTMIN+3 38) SIGRTMIN +4 39) SIGRTMIN +5 40) SIGRTMIN+6 41)SIGRTMIN+7 42) SIGRTMIN+8 43) SIGRTMIN +9 44) SIGRTMIN +10 45) SIGRTMIN+11 46) SIGRTMIN+1247) SIGRTMIN+13 48) SIGRTMIN +14 49) SIGRTMIN +15 50) SIGRTMAX-14 51) SIGRTMAX-13 52) SIGRTMAX-12 53) SIGRTMAX-11 54) SIGRTMAX-10 55) SIGRTMAX-9 56) SIGRTMAX-8 57) SIGRTMAX-7 58) SIGRTMAX-6 59) SIGRTMAX-5 60) SIGRTMAX-4 61) SIGRTMAX-3 62) SIGRTMAX-2 63) SIGRTMAX-1 64) SIGRTMAX

这里介绍一下常见的进程信号,如表 1 所示。

表 1 常见的进程信号
信号代号 信号名称 说明
该信号让进程立即关闭.然后重新读取配置文件之后重启
程序中止信号,用于中止前台进程。相当于输出 Ctrl+C 快捷键
在发生致命的算术运算错误时发出。不仅包括浮点运算错误,还包括溢出及除数为 0 等其他所有的算术运算错误
用来立即结束程序的运行。本信号不能被阻塞、处理和忽略。般用于强制中止进程
时钟定时信号,计算的是实际的时间或时钟时间。alArm 函数使用该信号
正常结束进程的信号,kill 命令的默认信号。如果进程已经发生了问题,那么这 个信号是无法正常中止进程的,这时我们才会尝试 SIGKILL 信号,也就是信号 9
该信号可以让暂停的进程恢复执行。本信号不能被阻断
该信号可以暂停前台进程,相当于输入 Ctrl+Z 快捷键。本信号不能被阻断

我们只介绍了常见的进程信号,其中最重要的就是 “1”、”9″、”15″这三个信号,我们只需要记住这三个信号即可。

关于如何把这些信号传递给进程,从而控制这个进程,这就需要使用 kill、killall 以及 pkill 命令了,我们会在后续章节中详解介绍这 3 个命令。


进程间软中断通信(signal函数和kill函数)相关问题

两个问题:1. while((p1=fork( ))= =-1);写法有错误, 应该是 while((p1=fork( ))==-1); C里面 ==不能分开的。 这里导致编译问题。 2. 改好上面的代码后,运行,你会发现Ctrl-c后,只会打印 Parent process is killed ,这是因为当你Ctrl-c的时候,系统会给父进程及其两个子进程都发送 SIGINT信号 (对bash来说,这三个进程都是前台进程,所以都发送), 对于父进程来说,收到这个信号自然是调用 stop函数了,但是对于两个子进程来说,默认的对这个信号的处理就是退出(exit),所以你看不到子进程的打印。 解决方法有两种:A: 不要用Ctrl-c的方法来发送SIGINT,而是用 kill 命令来向父进程单独发送 SIGINT,比如父进程pid是,那么就在终端下 kill -SIGINT ,你就可以看到你所预想看到的打印了。 B: 在两个子进程中,调用 signal(SIGINT, SIG_IGN); 来让子进程忽略SIGINT信号. (具体你可以放在你原来代码中 signal(16, stop)和signal(17, stop) 的后面),这样Ctrl-c后,也能看到你所想要的打印。

关于linux编程中fork和pipe的问题

及其释义

fork()不仅创建出与父进程代码相同的子进程,而且父进程在fork执行点的所有上下文场景也被自动复制到子进程中,包括: —全局和局部变量 —打开的文件句柄 —共享内存、消息等同步对象由于pipe调用相当于创建了2个文件句柄,因此在fork后这两个句柄也被自动复制到子进程中,对这两个句柄的操作效果与在主进程中的操作效果是一致的,这就使父子进程之间很容易通过该机制实现数据交换,如:假设pipe产生的句柄为P[0],P[1],在fork后父子进程都拥有了P[0],P[1]句柄,那么: —父进程可向自己的P[1]中写入数据,子进程从P[0]中即可读出该数据;切记此时父进程不能也从P[0]读数据,否则自己写入的数据可能先被自己读走了 —反之亦然,子进程向P[1]中写入数据后,父进程从P[0]中可读出该数据;切记此时子进程不要从P[0]读走数据你可能难以理解为什么进程内部的数据读写会被传递到另一个进程,但别忘了,pipe匿名管道和文件,socket等一样是属于操作系统的管理对象,对其进行读写都是由OS的内核代码来进行控制的。 在父进程调用pipe创建出管道后,该管道对象是存储在OS内部的,父进程得到的P[0]和P[1]都只是对该对象的引用(相当于指针);在fork出子进程后,子进程复制出的也只是同一个指针,所指向的还是OS中的同一个对象,这就是为什么父子进程能通过其进行互相通信的原因。

linux中查看进程在哪个cpu上运行

ps命令的输出格式可以通过-o参数定制,可以使用如下命令显示进程所对应的执行CPU:# ps -eo pid,args,psr参数的含义:pid - 进程IDargs - 该进程执行时传入的命令行参数psr - 分配给进程的CPU

本文版权声明本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,请联系本站客服,一经查实,本站将立刻删除。

发表评论

热门推荐