cu_Cbear 发表于 2012-02-19 23:16

Linux 基础总结(二)

Linux 基础总结(二)










1) SIGHUP本信号在用户终端连接(正常或非正常)结束时发出,通常是在终端的控制进程结束时, 通知同一session内的各个作业,这时它们与控制终端不再关联.

2) SIGINT程序终止(interrupt)信号,在用户键入INTR字符(通常是Ctrl-C)时发出

3) SIGQUIT和SIGINT类似,但由QUIT字符(通常是Ctrl-\)来控制.进程在因收到SIGQUIT退出时会产生core文件,在这个意义上类似于一个程序错误信号.

4) SIGILL执行了非法指令. 通常是因为可执行文件本身出现错误,或者试图执行数据段. 堆栈溢出时也有可能产生这个信号.

5) SIGTRAP由断点指令或其它trap指令产生.由debugger使用.

6) SIGABRT程序自己发现错误并调用abort时产生.

7) SIGIOT在PDP-11上由iot指令产生,在其它机器上和SIGABRT一样.

8) SIGBUS非法地址, 包括内存地址对齐(alignment)出错. eg:访问一个四个字长的整数, 但其地址不是4的倍数.

9) SIGFPE在发生致命的算术运算错误时发出. 不仅包括浮点运算错误,还包括溢出及除数为0等其它所有的算术的错误.

10) SIGKILL用来立即结束程序的运行. 本信号不能被阻塞,处理和忽略.

11) SIGUSR1留给用户使用

12) SIGSEGV试图访问未分配给自己的内存, 或试图往没有写权限的内存地址写数据.

13) SIGUSR2留给用户使用

14) SIGPIPE Broken pipe

15) SIGALRM时钟定时信号, 计算的是实际的时间或时钟时间. alarm函数使用该信号.

16) SIGTERM程序结束(terminate)信号,与SIGKILL不同的是该信号可以被阻塞和处理.通常用来要求程序自己正常退出. shell命令kill缺省产生这个信号.

17) SIGCHLD子进程结束时, 父进程会收到这个信号.

18) SIGCONT让一个停止(stopped)的进程继续执行.本信号不能被阻塞. 可以用一个handler来让程序在由stopped状态变为继续执行时完成特定的工作.例如, 重新显示提示符.

19) SIGSTOP停止(stopped)进程的执行.注意它和terminate以及interrupt的区别:该进程还未结束, 只是暂停执行.本信号不能被阻塞, 处理或忽略.

20) SIGTSTP停止进程的运行, 但该信号可以被处理和忽略.用户键入SUSP字符时(通常是Ctrl-Z)发出这个信号

21) SIGTTIN当后台作业要从用户终端读数据时, 该作业中的所有进程会收到SIGTTIN信号.缺省时这些进程会停止执行.

22) SIGTTOU类似于SIGTTIN, 但在写终端(或修改终端模式)时收到.

23) SIGURG有紧急数据或out-of-band数据到达socket时产生.

24) SIGXCPU超过CPU时间资源限制.这个限制可以由getrlimit/setrlimit来读取/改变

25) SIGXFSZ超过文件大小资源限制.

26) SIGVTALRM虚拟时钟信号. 类似于SIGALRM,但是计算的是该进程占用的CPU时间.

27) SIGPROF类似于SIGALRM/SIGVTALRM, 但包括该进程用的CPU时间以及系统调用的时间.

28) SIGWINCH窗口大小改变时发出.

29) SIGIO文件描述符准备就绪, 可以开始进行输入/输出操作.

30) SIGPWR Power failure

对于2和3信号量好理解,屏蔽ctrl+c和ctrl+\。但是1信号量到底什么作用呢?

转自http://blog.csdn.net/cugxueyu/archive/2008/01/16/2046565.aspx

SIGHUP信号与控制终端

UNIX中进程组织结构为 session (会话)包含一个前台进程组及一个或多个后台进程组,一个进程组包含多个进程。一个session可能会有一个session首进程,而一个session首进程可能会有一个控制终端。一个进程组可能会有一个进程组首进程。进程组首进程的进程ID与该进程组ID相等。这儿是可能会有,在一定情况之下是没有的。与终端交互的进程是前台进程,否则便是后台进程。

SIGHUP会在以下3种情况下被发送给相应的进程:

1、终端关闭时,该信号被发送到session首进程以及作为job提交的进程(即用& 符号提交的进程)

2、session首进程退出时,该信号被发送到该session中的前台进程组中的每一个进程

3、若父进程退出导致进程组成为孤儿进程组,且该进程组中有进程处于停止状态(收到SIGSTOP或SIGTSTP信号),该信号会被发送到该进程组中的每一个进程。

系统对SIGHUP信号的默认处理是终止收到该信号的进程。所以若程序中没有捕捉该信号,当收到该信号时,进程就会退出。

下面观察几种因终端关闭导致进程退出的情况,在这儿进程退出是因为收到了SIGHUP信号。login shell是session首进程。

首先写一个测试程序,代码如下:

#include <stdio.h>

#include <signal.h>

char **args;

void exithandle(int sig)

...{

printf("%s : sighup received ",args);

}

int main(int argc,char **argv)

...{

args = argv;

signal(SIGHUP,exithandle);

pause();

return 0;

}

程序中捕捉SIGHUP信号后打印一条信息,pause()使程序暂停。

编译后的执行文件为sigtest。

1、命 令:sigtest front > tt.txt

操 作:关闭终端

结 果:tt.txt文件的内容为front : sighup received

原 因: sigtest是前台进程,终端关闭后,根据上面提到的第1种情况,login shell作为session首进程,会收到SIGHUP信号然后退出。根据第2种情况,sigtest作为前台进程,会收到login shell发出的SIGHUP信号。

2、命 令:sigtest back > tt.txt &

操 作:关闭终端

结 果:tt.txt文件的内容为 back : sighup received

原 因: sigtest是提交的job,根据上面提到的第1种情况,sigtest会收到SIGHUP信号。

3、命 令:写一个shell,内容为,然后执行该shell

操 作:关闭终端

结 果:ps -ef | grep sigtest会看到该进程还在,tt文件为空

原 因:执行该shell时,sigtest作为job提交,然后该shell退出,致使sigtest变成了孤儿进程,不再是当前session的job了,因此sigtest即不是session首进程也不是job,不会收到SIGHUP。同时孤儿进程属于后台进程,因此login shell退出后不会发送SIGHUP给sigtest,因为它只将该信号发送给前台进程。第3条说过若进程组变成孤儿进程组的时候,若有进程处于停止状态,也会收到SIGHUP信号,但sigtest没有处于停止状态,所以不会收到SIGHUP信号。

4、命 令:nohup sigtest > tt

操 作:关闭终端

结 果:tt文件为空

原 因: nohup可以防止进程收到SIGHUP信号

至此,我们就清楚了何种情况下终端关闭后进程会退出,何种情况下不会退出。

要想终端关闭后进程不退出有以下几种方法,均为通过shell的方式:

1、编写shell,内容如下

trap "" SIGHUP #该句的作用是屏蔽SIGHUP信号,trap可以屏蔽很多信号

sigtest

2、nohup sigtest可以直接在命令行执行,

若想做完该操作后继续别的操作,可以 nohup sigtest &

3、编写shell,内容如下

sigtest &

其实任何将进程变为孤儿进程的方式都可以,包括fork后父进程马上退出。



(8)Linux stty

在linux/unix平台上的sqlplus中,如果输错了字符,要想删除,习惯性的按下backspace键后,发现非但没有删除想要删掉的字符,还多出了两个字符^H。当 然,我们可以同时按下ctrl+backspace键来删除,但对于习惯了用backspace来删除的用户,这样很不爽。这可以通过修改tty终端的设置来实现backspace删除功能。通过使用stty命令,就可以查看或者修改终端的按键设置。

例如,设置backspace为删除键:

$ stty erase ^h

如果要改回使用ctrl+backspace为删除键

$ stty erase ^?

如果需要重启后自动设置终端,可以将上述命令加入到profile中。

可以通过stty -a命令来查看所有的终端设置。下面是在linux下执行的输出:

$ stty -a

speed 38400 baud; rows 66; columns 132; line = 0;

intr = ^C; quit = ^\; erase = ^H; kill = ^U; eof = ^D; eol = <undef>; eol2 = <undef>; start = ^Q; stop = ^S; susp = ^Z; rprnt = ^R;

werase = ^W; lnext = ^V; flush = ^O; min = 1; time = 0;

-parenb -parodd cs8 -hupcl -cstopb cread -clocal -crtscts

-ignbrk -brkint -ignpar -parmrk -inpck -istrip -inlcr -igncr icrnl ixon -ixoff -iuclc -ixany -imaxbel

opost -olcuc -ocrnl onlcr -onocr -onlret -ofill -ofdel nl0 cr0 tab0 bs0 vt0 ff0

isig icanon iexten echo echoe echok -echonl -noflsh -xcase -tostop -echoprt echoctl echoke

其中:
• eof : 输入结束
• erase : 向后删除字符,
• intr : 中断当前程序
• kill : 删除整条命令
• quit :退出当前程序
• start : 启动屏幕输出
• stop :停止屏幕输出;
• susp : terminal stop当前程序。



参看引用链接:

源文档 <http://blog.csdn.net/cheungjustin/article/details/5678679>

源文档 <http://blog.csdn.net/cyberreality/article/details/6838788>

源文档 <http://blog.chinaunix.net/space.php?uid=21825410&do=blog&id=416073>

源文档 <http://blog.csdn.net/cheungjustin/article/details/5825213>

源文档 <http://powerclark.iteye.com/blog/564821>

源文档 <http://www.cnblogs.com/dkblog/archive/2011/09/04/2166571.html>

源文档 <http://blog.csdn.net/holandstone/article/details/6738769>

源文档 <http://blog.chinaunix.net/uid-26667139-id-3064721.html>

寂寞冲咖啡 发表于 2012-02-19 23:17

谢谢分享
页: [1]
查看完整版本: Linux 基础总结(二)