2.2.2 Posix API与网络协议栈 1

2024-08-27 06:28
文章标签 api 2.2 网络协议 posix

本文主要是介绍2.2.2 Posix API与网络协议栈 1,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

课程链接地址

2.2.2 Posix API与网络协议栈

  1. posix api: linux一开始仿unix不同版本,提供 操作系统——应用程序接口的标准
  2. 上一次2.1.1的reactor.c优化1048576数组
    请添加图片描述

1 建立连接,api

所有linux 上运行的都用的这些api,不管java还是python,底层linux的api都是一样的

  1. 服务端

    socket()返回fd;bind绑定一个接口;listen;accept创建一个客户端的fd;recv;send;close

    epoll; fcntl设置阻塞非阻塞

    客户端

    socket(); bind()可选不一定绑; connect(); send ; recv; close

    tcp传输——建立连接,传data,断连接

tcp连接准备

请添加图片描述

  1. **socket()**如何实现/组成的

    好有意思,socket 插座 = 插fd int型+ 座tcp控制块

    分配fd,用bitmap算法——如果置0 未用,置1用过了

    tcp是不断alloc创建新的

  2. bind()

    还没到tcp连接,跟tcp还没关系这步

    传入fd,绑定一个ip地址+port 五元组:源 目的 ip+端口+协议;本质是个设置set初始化过程

    客户端如果未绑,会随机分配端口,一路,就绑定;一般就默认分配

  3. listen()监听

    tcp状态迁移图

    1. 把tcp里的status状态设置为listen,如果未设置,会拒接消息请求,代表迎宾小姐姐正式上岗
    2. 分配全连接syn,半连接队列queue

listen以后才能三次握手建立连接

server不可以先发起,只能client发起,不管应用层用的什么语言,见posix API与网络协议栈的实现原理.pdf

  1. client发:两个字段——syn这位置1**,seqnum32位,置为1234 随机值**,好处避免被截获破解包

    解析完知道这是握手的包

  2. server回:四个字段——acj置1, acknum是1235(seqnum+1),代表1235以前所有包收到了,syn这位置1, seqnum 5647也是随机的

  3. client回:ack ,acknum 5648(5647+1)承认server都收到了之前的包

为什么三次:脑经急转弯

请添加图片描述

核心是如何记这个三次握手图

tcp是全双工长期通信——1234 client告诉server发的data从哪里开始; 5647 server告诉client发的data从哪里开始

这两个data开始地方id很重要:确保data不重复,不丢失

三次握手发生在what函数

  1. client的conncet

  2. server端连接前listen()准备,连接结束accept()取出连接,被动触发

    man listen 可以看listen函数解释
    int listen(int sockfd, int backlog)
    

    为什么backlog,因为类似古代的虎符,和去吃饭叫号的牌子,确保你拿的号不是自己编的没造假,两次:一半给你client,一半自留

    半连接syn队列:在server为多个client创建半连接,半个虎符 号牌

    全连接accept队列:三次握手结束后的accept这里,半连接syn队列的半个虎符move到,不是copy到accept队列

问题

  1. tcp连接生命周期when开始?

    **从第一次握手server的listen接收到syn包,**协议栈为client分配一个连接节点,连接开始(但是要等到三次握手结束,accept()函数创建的时候fd开始

  2. 第三次握手client来一个data包, server如何从syn半连接队列查找匹配的节点 然后放到accept队列里(半个虎符)

    通过(源、目的 * 端口 、ip ,协议)五元组查出来

  3. 如何防护syn泛洪——client在syn创建连接节点,但是后面不继续发data,那么就不会syn队列里节点move到accept队列,然后syn队列就炸了

    listen(fd, backlog) listen函数,tcp协议栈在1980s就有了,比我年纪大

    用第二个参数backlog设置的是什么?

    1. 最早syn半连接队列长度,防止无限增长炸了

      比较鸡肋,因为防火墙 从物理上接收data前server已经能有这个效果的,物理上隔了防止泛洪

    2. syn + accept 队列总长度 = 未分配fd的tcb的数量

      TCB的全称是“Trusted Computing Base”,指的是在计算机系统中,确保系统安全性的核心部分。它包括硬件、固件和软件组件,用于保护系统免受各种安全威胁。

      防止accept一直不处理会积累大量连接堆着

    3. accept 队列(pending connections 待连接)长度

      大大提升建链的速率(现在的方法), 连接的吞吐量

请添加图片描述

accept()

上面listen()函数讲完了

  1. 分配fd给对应server

  2. fd与tcb(accept队列中节点)建立映射

    在epoll()的listen返回epollIN事件

    listenfd 用的 accept()

    clientfd 用的 recv(), send()

如果ET边沿触发,如何处理所有连接?

多个事件但是只触发一次,有问题,用while(1) 设置accept非阻塞,直到fd=-1,break

请添加图片描述

这篇关于2.2.2 Posix API与网络协议栈 1的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1110884

相关文章

VC网络协议

// PCControlDlg.cpp : 实现文件//#include "stdafx.h"#include "PCControl.h"#include "PCControlDlg.h"#include "afxdialogex.h"#ifdef _DEBUG#define new DEBUG_NEW#endif// 用于应用程序“关于”菜单项的 CAboutDlg 对话框#ifde

【LabVIEW学习篇 - 21】:DLL与API的调用

文章目录 DLL与API调用DLLAPIDLL的调用 DLL与API调用 LabVIEW虽然已经足够强大,但不同的语言在不同领域都有着自己的优势,为了强强联合,LabVIEW提供了强大的外部程序接口能力,包括DLL、CIN(C语言接口)、ActiveX、.NET、MATLAB等等。通过DLL可以使用户很方便地调用C、C++、C#、VB等编程语言写的程序以及windows自带的大

如何更优雅地对接第三方API

如何更优雅地对接第三方API 本文所有示例完整代码地址:https://github.com/yu-linfeng/BlogRepositories/tree/master/repositories/third 我们在日常开发过程中,有不少场景会对接第三方的API,例如第三方账号登录,第三方服务等等。第三方服务会提供API或者SDK,我依稀记得早些年Maven还没那么广泛使用,通常要对接第三方

Java基础回顾系列-第五天-高级编程之API类库

Java基础回顾系列-第五天-高级编程之API类库 Java基础类库StringBufferStringBuilderStringCharSequence接口AutoCloseable接口RuntimeSystemCleaner对象克隆 数字操作类Math数学计算类Random随机数生成类BigInteger/BigDecimal大数字操作类 日期操作类DateSimpleDateForma

Restful API 原理以及实现

先说说API 再说啥是RESRFUL API之前,咱先说说啥是API吧。API大家应该都知道吧,简称接口嘛。随着现在移动互联网的火爆,手机软件,也就是APP几乎快爆棚了。几乎任何一个网站或者应用都会出一款iOS或者Android APP,相比网页版的体验,APP确实各方面性能要好很多。 那么现在问题来了。比如QQ空间网站,如果我想获取一个用户发的说说列表。 QQ空间网站里面需要这个功能。

京东物流查询|开发者调用API接口实现

快递聚合查询的优势 1、高效整合多种快递信息。2、实时动态更新。3、自动化管理流程。 聚合国内外1500家快递公司的物流信息查询服务,使用API接口查询京东物流的便捷步骤,首先选择专业的数据平台的快递API接口:物流快递查询API接口-单号查询API - 探数数据 以下示例是参考的示例代码: import requestsurl = "http://api.tanshuapi.com/a

WordPress开发中常用的工具或api文档

http://php.net/ http://httpd.apache.org/ https://wordpress.org/ https://cn.wordpress.org/ https://core.svn.wordpress.org/ zh-cn:开发者文档: https://codex.wordpress.org/zh-cn:%E5%BC%80%E5%8F%91%E8%80%

Java后端微服务架构下的API限流策略:Guava RateLimiter

Java后端微服务架构下的API限流策略:Guava RateLimiter 大家好,我是微赚淘客返利系统3.0的小编,是个冬天不穿秋裤,天冷也要风度的程序猿! 在微服务架构中,API限流是保护服务不受过度使用和拒绝服务攻击的重要手段。Guava RateLimiter是Google开源的Java库中的一个组件,提供了简单易用的限流功能。 API限流概述 API限流通过控制请求的速率来防止

Docker远程连接和Docker Remote Api

在Docker生态系统中一共有3种API:Registry API、Docker Hub API、Docker Remote API 这三种API都是RESTful风格的。这里Remote API是通过程序与Docker进行集成和交互的核心内容。 Docker Remote API是由Docker守护进程提供的。默认情况下,Docker守护进程会绑定到一个所在宿主机的套接字:unix:///v

基于MinerU的PDF解析API

基于MinerU的PDF解析API - MinerU的GPU镜像构建- 基于FastAPI的PDF解析接口 支持一键启动,已经打包到镜像中,自带模型权重,支持GPU推理加速,GPU速度相比CPU每页解析要快几十倍不等 主要功能 删除页眉、页脚、脚注、页码等元素,保持语义连贯对多栏输出符合人类阅读顺序的文本保留原文档的结构,包括标题、段落、列表等提取图像、图片标题、表格、表格标题自动识别