l8-d6 socket套接字及TCP的实现框架

一、socket套接字

/*创建套接字*/

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

/*绑定通信结构体*/

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

/*监听套接字*/

int listen(int sockfd, int backlog);

/*处理客户端发起的连接,生成新的套接字*/

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

/*向服务器发起连接请求*/

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

三元组【IP地址,端口,协议】

IP地址:标识计算机

端口号:标识计算机当中的进程

协议:指定数据传输的方式

地址族结构体

//通用地址族结构体

struct sockaddr {

sa_family_t sa_family;

char sa_data[14];

}

//sa_family

AF_UNIX 使用本地域套接字的地址结构,用于本地通信

AF_INET 使用IPv4的通信地址结构

AF_INET6 使用IPv6的通信地址结构

....

//IPv4

struct sockaddr_in {

sa_family_t sin_family;

in_port_t sin_port;

struct in_addr sin_addr;

};

struct sockaddr {

uint32_t s_addr;

};

套接字类型

流式套接字 (SOCK_STREAM) 提供可靠的、面向连接的通信流;它使用TCP,从而保证数据传输的可靠性和顺序性

**数据报套接字 (SOCK_DGRAM)**定义了一种不可靠、面向无连接的服务,数据通过相互独立的报文进行传输,是无序的,并且不保证是可靠、无差错的。它使用数据报协议UDP

原始套接字(SOCK_RAW) 允许直接访问底层协议,如IP或ICMP,它功能强大但使用较为不便,主要用于协议开发。

二、TCP通信的实现过程

实现过程:

1.通信之前,客户和服务器先创建套接字

2.服务器端调用 bind,把端口号和本地 IP 地址填写到已创建的套接字中

3.服务器端调用 listen(收听),把套接字设置为被动方式,以便随时接受客户的服务请求。UDP 服务器不使用 listen 系统调用

4.服务器端调用 accept(接受),以便把远地客户进程发来的连接请求提取出来。UDP 服务器不使用 accept 系统调用

5.客户进程调用 connect,以便和远地服务器建立连接(这就是主动打开)

6.客户和服务器在 TCP 连接上使用 write传送数据,使用 read接收数据

7.客户或服务器通信结束,调用 close 释放连接和撤销套接字。

相关推荐
寻星探路4 小时前
【深度长文】万字攻克网络原理:从 HTTP 报文解构到 HTTPS 终极加密逻辑
java·开发语言·网络·python·http·ai·https
七夜zippoe7 小时前
CANN Runtime任务描述序列化与持久化源码深度解码
大数据·运维·服务器·cann
盟接之桥7 小时前
盟接之桥说制造:引流品 × 利润品,全球电商平台高效产品组合策略(供讨论)
大数据·linux·服务器·网络·人工智能·制造
会员源码网7 小时前
理财源码开发:单语言深耕还是多语言融合?看完这篇不踩坑
网络·个人开发
米羊1218 小时前
已有安全措施确认(上)
大数据·网络
Fcy6488 小时前
Linux下 进程(一)(冯诺依曼体系、操作系统、进程基本概念与基本操作)
linux·运维·服务器·进程
袁袁袁袁满8 小时前
Linux怎么查看最新下载的文件
linux·运维·服务器
主机哥哥9 小时前
阿里云OpenClaw部署全攻略,五种方案助你快速部署!
服务器·阿里云·负载均衡
ManThink Technology9 小时前
如何使用EBHelper 简化EdgeBus的代码编写?
java·前端·网络
珠海西格电力科技10 小时前
微电网能量平衡理论的实现条件在不同场景下有哪些差异?
运维·服务器·网络·人工智能·云计算·智慧城市