服务器程序框架 - Linux C++网络编程(十三)

一:信号高级认识范例

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文件,暂时为空

e)proc目录:专门存放和进程处理有古安的1到多个.c文件,暂时为空

f)signal目录:专门用于存放和信号处理 有古安的1到多个.c文件;

    ngx_signal.c

linux上用tree看一下目录结构

(2.2)编译工具make的使用概述(编译出可执行文件)

我们 要用传统的 ,经过验证没有问题的方式来编译我们的项目,最终生成可执行文件

每个.c生成一个.o,多个.c生成多个.o,最终这些.o被链接到一起,生成一个可执行文件

gcc -o nginx ng1.c

gcc -o nginx ng1.c ng2.c

a)我们要借助make的命令来编译:能够编译,链接。。。。最终生成可执行文件,大型项目一般都用make来搞;

b)make命令的工作原理,就去当前目录读取一个叫做makefile的文件(文本文件),根据这个makefile文件里的

    规则把咱们的源代码编译成可执行文件;咱们开发者的任务就是要把这个makefile文件写出来;

    这个makefile里边就定义了我们怎么去编译整个项目的编译、链接规则

        【实际上makefile文件就是一个我们编译工程要用到的各种源文件等等的一个依赖关系描述】

有类似autotools自动生成makefile,这里不讲

c)makefile文件:文本文件,utf8编码格式,没有扩展名,一般放在根目录下[也会根据需要放在子目录](这里nginx)

不同的程序员写的makefile代码也会千差万别;但不管怎么说,最终都要把可执行文件给我生成出来;

老师挑选 灵活性、通用性比较好的一种makefile写法,介绍给大家;

(1)-o:指定编译链接后生成的可执行文件名,比如
gcc -o nginx nginx.c
(2)-c:  将.c编译成.o目标文件[仅执行编译操作,不进行链接操作]
gcc -c nginx.c
将生成nginx.o的目标文件
(3)-M:显示一个源文件所依赖的各种文件
gcc -M nginx.c
(4)-MM:显示一个源文件所依赖的各种文件,但不包括系统的一些头文件;
gcc -MM nginx.c
这种扫描是有用途的,尤其是在写makefile文件时,需要用到这些依赖关系,以做到比如当某个.h头文件更改时,整个工程会实现自动重新编译的目的;
 
(5) -g:生成调试信息。GNU 调试器可利用该信息。
(6)-I:gcc会先到你 用这个参数指定的目录去查找头文件,你在.c/.cpp中可以 
#include <abc.h>   //这里用尖括号了
gcc -I /mnt/mydir

规划一下makefile文件的编写

a)nginx根目录下我会放三个文件:

    a.1)makefile:是咱们编译项目的入口脚本,编译项目从这里开始,起总体控制作用;

    a.2)config.mk:这是个配置脚本,被makefile文件包含;单独分离出来是为了应付一些可变的东西,所以,一般变动的东西都往这里搞;

    a.3)common.mk:是最重要最核心的编译脚本,定义makefile的编译规则,依赖规则等,通用性很强的一个脚本,

        并且各个子目录中都用到这个脚本来实现对应子目录的.c文件的编译;

b)每个子目录下(app,signal)都有一个叫做makefile的文件,每个这个makefile文件,都会包含根目录下的common.mk,

    从而实现自己这个子目录下的.c文件的编译

现在的makefile不支持目录中套子目录,除非大家自己修改;

c)其他规划,上边讲过;

    app/link_obj临时目录,存放.o目标文件

    app/dep:存放.d开头的依赖关系文件;

(2.3)makefile脚本用法介绍

a)编译项目,生成可执行文件

make

make clean

(2.4)makefile脚本具体实现讲解

从common.mk讲起

将来增加新目录时:

a)修改根目录下的config.mk来增加该目录

b)在对应的目录下放入makefile文件,内容参考signal目录ixa的makefile文件即可

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值