一:信号高级认识范例
ps -eo pid,ppid,sid,tty,pgrp,comm,stat,cmd | grep -E ‘bash|PID|nginx’
用kill 发送 USR1信号给进程
(1)执行信号处理函数被卡住了10秒,这个时候因为流程回不到main(),所以main中的语句无法得到执行;
(2)在触发SIGUSR1信号并因此sleep了10秒种期间,就算你多次触发SIGUSR1信号,也不会重新执行SIGUSR1信号对应的信号处理函数,而是会等待上一个SIGUSR1信号处理函数执行完毕才 第二次执行SIGUSR1信号处理函数;换句话说:在信号处理函数被调用时,操作系统建立的新信号屏蔽字(sigprocmask()),自动包括了正在被递送的信号,因此,保证了在处理一个给定信号的时候,如果这个信号再次发生,那么它会阻塞到对前一个信号处理结束为止;
(3)不管你发送了多少次kill -usr1信号,在该信号处理函数执行期间,后续所有的SIGUSR1信号统统被归结为一次。
比如当前正在执行SIGUSR1信号的处理程序但没有执行完毕,这个时候,你又发送来了5次SIGUSR1信号,那么当SIGUSR1信号处理程序执行完毕(解除阻塞),SIGUSR1信号的处理程序也只会被调用一次(而不会分别调用5次SIGUSR1信号的处理程序)。
kill -usr1,kill -usr2
(1)执行usr1信号处理程序,但是没执行完时,是可以继续进入到usr2信号处理程序里边去执行的,这个时候,相当于usr2信号处理程序没执行完毕,usr1信号处理程序也没执行完毕;此时再发送usr1和usr2都不会有任何响应;
(2)既然是在执行usr1信号处理程序执行的时候来了usr2信号,导致又去执行了usr2信号处理程序,这就意味着,
只有usr2信号处理程序执行完毕,才会返回到usr1信号处理程序,只有usr1信号处理程序执行完毕了,才会最终返回到main函数主流程中去继续执行;
思考:如果我希望在我处理SIGUSR1信号,执行usr1信号处理程序的时候,如果来了SIGUSR2信号,我想堵住(屏蔽住),不想让程序流程跳到SIGUSR2信号处理中去执行,可以做到的;我们后续会讲解其他的如何屏蔽信号的方法;
二:服务器架构初步
老师,要带着大家,从无到有产生这套 通讯架构源代码【项目/工程】
项目 肯定会有多个源文件,头文件,会分别存放到多个目录;我们要规划项目的目录结构;
(2.1)目录结构规划(make编译)
特别注意:不固安是目录还是文件,文件名中一律不要带空格,一律不要用中文,最好的方式:字母,数字,下划线;
不要给自己找麻烦,远离各种坑
主目录名nginx
a)_include目录:专门存放各种头文件; 如果分散:#include “sfaf/sdafas/safd.h”
b)app目录:放主应用程序.c(main()函数所在的文件)以及一些比较核心的文件;
b.1)link_obj:临时目录:会存放临时的.o文件,这个目录不手工创建,后续用makefile脚本来创建
b.2)dep:临时目录,会存放临时的.d开头的依赖文件,依赖文件能够告知系统哪些相关的文件发生变化,需要重新编译,后续用makefile脚本来创建
b.3)nginx.c:主文件,main()入口函数就放到这里;
b.4)ngx_conf.c ,普通的源码文件,跟主文件关系密切,又不值得单独放在 一个目录;
c)misc目录:专门存放各种杂合性的不好归类的1到多个.c文件;暂时为空
d)net目录:专门存放和网络处理相关的1到多个.c文件,暂时为空