ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

连接池 和 监听队列

2021-05-24 14:34:03  阅读:145  来源: 互联网

标签:调用 函数 epoll 队列 对象 监听 连接池


采用Nginx的源码思想来写

监听套接字队列

监听端口数有多少个,那么监听队列就多长
结构体ngx_listening_s 每一个都包含

  • 端口号
  • sockfd
  • 指向连接对象的指针

vector<ngx_listening_s> 对象数组,刚开始在运行前就被初始化,配置好

连接池

可以看成 对象数组
每一个对象是一个结构体,包含

  • 监听套接字对象指针
  • 序号 iCurrsequence ,每一次分配时候都+1
  • 失效标志位instance ,初始为1,即失效; unsigned instance:1 // :1代表只占一位
  • 指向对象的指针,维护一条空闲连接链表,lpngx_connection_t指针永远指向链表头。
  • 成员函数指针
    CSocekt类的成员函数指针,参数(连接对象指针)指向读操作时候调用的函数

当需要时候,直接返回链表头节点,高效。

过程调用

  1. 监听对象队列在运行前就初始化,监听端口,

  2. 在子进程不断循环的过程中,调用epoll_init()初始化,

  3. 调用epoll_create()函数生成epoll对象(文件描述符)
    int epoll = epoll_create(int size);
    每一个进程都调用该函数,那么每一个进程都生成epoll对象、都有连接池,每一个进程的连接池都和监听套接字队列进行关联(这就是SO_REUSEADDR的作用)

  4. 初始化连接对象链表,遍历监听套接字队列,将监听对象和连接对象互相关联。

  5. 监听对象增加监听事件,关注读事件和关闭事件。

在子进程不断地调用ngx_epoll_process_events()函数
epoll_wait()函数返回捕获事件个数,遍历捕获的事件个数,判断事件类型,若是读事件,则执行回调函数

	回调函数ngx_event_accept()是在接收到三次握手后,建立新连接
	
	accpet(监听sockfd,sock地址,socklen)
	或accpet4(监听sockfd,sockaddr地址,sockaddr地址长度,设置非阻塞)
	
	用accept()返回的新的客户端sockfd取出连接数组里的对象
	用连接对象调用读取函数,将读事件写入监控。

标签:调用,函数,epoll,队列,对象,监听,连接池
来源: https://www.cnblogs.com/appearAndLeave/p/14804188.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有