TCP与SOCKET

栏目: 服务器 · 发布时间: 6年前

三次握手

TCP与SOCKET

四次挥手

TCP与SOCKET

SOCKET

TCP与SOCKET

在内核中,会维护两个队列:

  • 半连接队列(syn队列),存放处于SYN-RCVD状态的socket
  • 全连接队列(accept队列),存放处于ESTABLISHED状态的socket

accept函数会从全连接队列里取出一个连接,如果没有则阻塞。这里取出的是一个新的连接,叫已连接socket,不同于一开始创建的监听socket。Socket在 Linux 中以文件的形式存在,有自己的文件描述符,读写就如同一个文件流。

TCP与SOCKET

socket结构里有一个发送队列和一个接收队列,里面保存着缓存sk_buff,里面可以看到完整的包结构。

数据接收流程

网卡接收到数据后写入内存,并向CPU发起中断,操作系统执行中断程序唤醒对应socket等待队列里的进程。

如何同时监听多个socket:

  • select

将进程放入所有需要监听的socket的等待队列里,如果有一个socket接收到了数据就唤醒进程,然后遍历socket列表查看是哪个socket接收到了数据。

  • epoll
int epfd = epoll_create(...)
epoll_ctl(epfd, ...)
while(1){
    int n = epoll_wait(...)
    for (接收到数据的socket){
        //处理
    }
}

利用epoll_ctl将需要监视的socket添加到epoll_create创建的对象(eventpoll)中,然后利用epoll_wait进行阻塞,将进程放入eventpoll的等待队列中。当有socket接收到数据,中断程序将其被eventpoll的就绪列表所(rdllist)引用,然后唤醒进程,进程只需要遍历就绪列表就可以了。socket在eventpoll中利用红黑树存储,而就绪列表利用双向链表存储。


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

The Elements of Statistical Learning

The Elements of Statistical Learning

Trevor Hastie、Robert Tibshirani、Jerome Friedman / Springer / 2009-10-1 / GBP 62.99

During the past decade there has been an explosion in computation and information technology. With it have come vast amounts of data in a variety of fields such as medicine, biology, finance, and mark......一起来看看 《The Elements of Statistical Learning》 这本书的介绍吧!

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具

RGB HSV 转换
RGB HSV 转换

RGB HSV 互转工具