三次握手内部实现原理

news/2025/3/4 6:17:56/

socket()创建一个新的套接字

int socket(int domain, int type, int protocol);

参数:

domain:地址族,如 AF_INET(IPv4),AF_INET6(IPv6)

type:套接字类型,如 SOCK_STREAM(TCP),SOCK_DGRAM(UDP)

protocol:协议类型,通常为 0(默认协议)

返回值:成功返回套接字描述符,失败返回 -1

Linux操作系统流行一句话,“一切皆文件”,这里的文件不是说文件系统,磁盘里的某个文件,而是struct flie

也就是说,socket也其实也是一个struct file,将socket的所有底层都抽象为一个socket

bind()就是将套接字绑定到一个本地地址(IP+端口)

具体操作也就是将IP和端口号赋值到socket对象的成员里面去

int bind(int sockfd, const struct sockaddr *addr, socklen_t addrlen);

参数:

sockfd:套接字描述符

addr:指向 struct sockaddr 类型的指针,包含要绑定的地址信息

addrlen:地址长度,通常为 sizeof(struct sockaddr_in)

返回值:成功返回 0,失败返回 -1

listen()将套接字设置为被动监听模式,准备接受连接请求

int listen(int sockfd, int backlog);

参数:

sockfd:套接字描述符

backlog:等待连接队列的最大长度

返回值:成功返回 0,失败返回 -1

Listen()函数的最主要作用就是:初始化半连接队列(哈希表) + 全连接队列(链表)

半连接队列的作用就是,区分来客户端的请求是第一次握手还是第三次握手

全连接队列的作用是,让accept()函数从其中取走已完成连接的socket

accept()接受一个来自客户端的连接请求

底层就是去全连接队列里取socket

int accept(int sockfd, struct sockaddr *addr, socklen_t *addrlen);

参数:

sockfd:监听套接字描述符

addr:指向 struct sockaddr 类型的指针,接收客户端的地址信息

addrlen:地址长度指针,接收客户端地址长度

返回值:成功返回新的套接字描述符,失败返回 -1

connect()主动发起与服务器的连接

底层就是去,动态选择一个本地可用端口,作为发起连接的源端口

int connect(int sockfd, const struct sockaddr *addr, socklen_t addrlen);

参数:

sockfd:套接字描述符

addr:指向 struct sockaddr 类型的指针,包含服务器的地址信息

addrlen:地址长度,通常为 sizeof(struct sockaddr_in)

返回值:成功返回 0,失败返回 -1


http://www.ppmy.cn/news/1576472.html

相关文章

【CSS—前端快速入门】CSS 常用样式

CSS 常用 CSS 样式 1. 前端样式查询网站: MDN Web Docs (mozilla.org) w3school 2. border 2.1 借助 MDN 了解 border 我们借助 MDN 网站来学习 border 样式的使用: 2.2 border 常见属性 保存代码,打开页面: 对于标签不同样式的…

内网渗透测试-Vulnerable Docker靶场

靶场来源: Vulnerable Docker: 1 ~ VulnHub 描述:Down By The Docker 有没有想过在容器中玩 docker 错误配置、权限提升等? 下载此 VM,拿出您的渗透测试帽并开始使用 我们有 2 种模式: - HARD:这需要您将 d…

数据库基础四

创建数据表(创建mysql数据表需要以下信息:表名、表字段名、定义每个表字段) 一个关系型数据库,一般以表的形式显示 创建数据表(创建mysql数据表需要以下信息:表名、表字段名、定义每个表字段) CREATE TABLE 表名 (属性名 数据类型 完整性约束条件, 属性名 数据类型 完…

MySQL—授权与权限回收

1、查看某个用户的权限 --查看某个用户的权限 show grants; --查看root用户的权限 show grants for stc1; --查看stc1用户的权限 2、授权stc用户远程登录test库,并授予所有的执行权限 grant all privileges on stc.* to stc% identified by ppp; 3、授予stc1用户…

AI学习资料留档(持续更新)

一、模型部署/硬件资源 1、动态量化版部署方法、大小 完整的671B MoE DeepSeek R1怎么塞进本地化部署?详尽教程大放送! | 机器之心 2、 二、模型应用 1、deepseek R1cursor使用 不卡顿、免费的满血版DeepSeek-R1 API,在无问芯穹这里用上…

前端依赖nrm镜像管理工具

npm 默认镜像 :https://registry.npmjs.org/ 1、安装 nrm npm install nrm --global2、查看镜像源列表 nrm ls3、测试当前环境下,哪个镜像源速度最快。 nrm test4、 切换镜像源 npm config get registry # 查看当前镜像源 nrm use taobao # 等价于 npm…

中间件专栏之Redis篇——Redis中过期key删除和内存淘汰策略

在Redis中,过期键的删除和内存淘汰策略是管理Redis内存的重要机制,确保Redis可以高效地使用内存,并避免由于内存不足导致的性能问题。以下是这两个概念的详细介绍: 一、过期键删除机制 Redis支持对存储的键设置过期时间&#xf…

技术速递|Copilot Usage Advanced Dashboard 教程

作者:Xuefeng Yin 排版:Alan Wang Copilot Usage Advanced Dashboard 是为了充分利用 GitHub Copilot API 中的几乎所有数据,用到的 API 有: List teams of an onganization Get a summary of Copilot metrics for a team Get C…