HighConcurrencyCommFramework c++通讯服务器框架 :简介-信号处理
项目是4月份左右做的现在整理到博客上,顺便加深一下印象
介绍
项目描述:该项目是使用 C++ 实现的高并发服务器脚手架,包含线程池和连接池等技术,支持开发者进行二次开发复用,只需 要添加对应业务逻辑即可完成通信服务器、网络交易,游戏通讯框架等。
项目地址:https://github.com/18953014746/HighConcurrencyComm-Framework-
开端
借鉴nginx模式实现
nginx :简介
//-:nginx简介//nginx(2002年开发,2004年10才出现第一个版本0.1.0):web服务器,市场份额,排在第二位,Apache(1995)第一位;
//web服务器,反向代理,负载均衡,邮件代理;运行时需要的系统资源比较少,所以经常被称呼为轻重级服务器;
//是一个俄罗斯人(Igor Sysoev),C语言(不是c++)开发的,并且开源了;
//nginx号称并发处理百万级别的TCP连接,非常稳定,热部署(运行的时候能升级),高度模块化设
计,自由许可证。//很多人开发自己的模块来增强nginx,第三方业务模块(c++开发);0penResty;
//linux epoll技术;
windows IOCP
为什么选择nginx
//单机10万并发,而且同时能够保持高效的服务,epo11这种高并发技术好处就是:高并发只是占用更多内存就能 做到;
//内存池,进程池,线程池,事件驱动等等;
//学习研究大师级的人写的代码,是一个程序开发人员能够急速进步的最佳途径;
wget http://nginx.org/download/nginx-1.14.2.tar.gz
下载nginx ,然后解压得到
auto :
cc:检测编译器的脚本
lib:检测静态库的脚本
os :检测操作系统的脚本
type:检查平台类型的脚本
CHANGES :修复的bug 新增的说明;
conf :默认的配置文件
contrib/:脚本和工具,典型的是vim高亮工具vimim高亮工具
configure:编译nginx之前必须先执行本脚本以生成一些必要的中间文件
src:nginx 源代码目录;
core :核心代码
event :event(事件模块)
http:http(web服务)模块相关代码
mail :邮件相关代码
os:操作系统代码
stream :流处理相关代码
objs :
ngx_modules.c :内容决定了我们一会编译nginx的时候有哪些模块会被编译到来
Makefile :产生的编译文件
生成了nginx可执文件;
然后 在 make install 会在 usr/local/ nginx 的sbin安装可执行文件;
80
调整进程nginx的进程数量
在windows系统上调节 进程数量 内核为4
通过 grep -c processor /proc/cpuinfo 查看cpu内核
通过vim 编辑 nginx.conf process为4;
重载配置文件
不中断的时候,worker服务老的,服务之后,master 进程再fork出来服务新的
如果你是多核的,他会自动分配给你多少工作线程,然后的你杀掉其中一个,他还会自动fork
多进程服务器编程 (nginx)
怎么讲:
终端与进程的关系
linux 启动的过程中:
进程的集合叫进程组
进程组的集合叫会话
一个bash 上面运行的所有程序都属于一个会话
如果你把一个终端处理了,然后操作系统会给你这个bash进程发送信号,然后bash进程将这个信号发送给这个会话的所有进程,缺省状态下,是退出进程;
信号处理:
signal图为兼容性可靠性弃些历史问题;不建议使用,
建议用 sigaction()函数代替;
signal (SIGNUSR1,sigusr==SIGERR) 在主函数写信号捕捉函数,
//系统函数 ,参数一是个自定义信号,参数二是个函数指针 ,尽量不要调用库函数
函数处理:
kill -USR1 1185 、、发送信号
不捕捉 ,默认处理 终止进程
定义一个函数 ,然后信号处理需要调用,问题是?
答:全局变量不是我们想的15了,而是被信号中断改成20了
先保存全局变量的值,等调用完在复制原来的值
可重入函数(异步信号安全)
/严格意义:muNEfumc()函数不应该是一个可重入函数/所谓的可重入函数:就是我们在信号处理函数中 调用它是安全的;
假设主函数用 malloc 信号处理也用malloc那么当接收信号的时候,内存分配会错乱
信号之间的处理是阻塞等待的而不是抢占信号执行
信号集:
sigemptyset()清空信号集所有的信号都清零,表示这60多个信号都没有来0 sigfillset()把所有的所有信号都设置为1 sigaddset()sigdelset()增加和删除信号集中的信号 sigprocmask()所对应的信号集的内容 sigmember() 信号集中的信号集为1、表示在占用,其他信号集的1都是阻塞状态
sigprocmask()所对应的信号集的内容
newmask信号集通过add函数变成了1 ,然后通过sigprocmask 设置信号为屏蔽里面的信号
oldmask 是0 信号集,最后在设置会不屏蔽,然后阻塞的就可以进来 调用信号