网络编程客户端和服务端连接流程

复制代码
服务器端:

socket()-->bind( )-->listen()-->accept()-->read()/write()--->close()

socket()//创建套接字
bind()//命名socket,分配套接字地址
listen()//监听状态,等待连接请求状态
accept()//允许连接(被动连接)
read()/write()或者send()/recv() //进行数据交换
close()//断开连接

客户端: 

socket()-->connect()-->read()/write()-->close()

socket()//创建套接字
connect()//请求连接
read()/write() send()/recv()//进行数据交换
close()//断开连接

对于服务端,创建socket后需要分配其地址,调用bind函数

XML 复制代码
#include <sys/types.h> 					
#include <sys/socket.h>
bind(socket,(struct sockaddr*)addr,socklen_t addrlen)
//该函数参数为需要命名的socket,socket地址和该地址的长度。addr的IP为自己主机的IP地址

//返回值  成功0
          失败 -1并设置erron

而对于客户端,socket地址是匿名分配的,不需要自己来分配,只需要用connect函数来请求连接,该连接为主动连接。

XML 复制代码
#include <sys/types.h> 					
#include <sys/socket.h>
int connect(int sockfd, const struct sockaddr *addr, socklen_t addrlen);

参数:
第一个参数:int sockdf:
		    socket文件描述符
第二个参数: const struct sockaddr *addr:
			传入参数,指定服务器端地址信息,含IP地址和端口号
第三个参数:socklen_t addrlen:
			传入参数,传入sizeof(addr)大小
返回值:
	成功: 0
	失败:-1,设置errno

客户端发送connect()连接请求后,并不意味着服务端执行accept后才接收连接,因此connect()返回后不代表进行数据交换。客户端的连接请求首先会存放到listne创建的监听队列中,而accept只是从监听队列中取出连接,不关心连接处于何种状态(比如ESTABLISHED和CLOSE_WAIT),更不关心网络状态的变化。

XML 复制代码
#include<sys/socket.h>
int listen(int sockfd,int backlog);

//参数1: 表示进入监听的命名后的socket
//参数2: 表示内核监听队列最大长度,linux2.2后表示完全连接状态的最大上限

//返回:
// 成功:0
// 失败:-1 设置erron
XML 复制代码
#include<sys/types.h>
#include<sys/socket.h>
int accept(int sockfd,struct sockaddr*addr,socklen_t*addrlen);

//参数1: 执行过listen系统调用的监听socket

//参数2 :客户端的socket地址(自动分配)

//参数3: 客户端的socket地址长度

//返回值  
// 成功: 0
//失败 : -1 设置erron
相关推荐
wanhengidc8 小时前
裸金属服务器都有哪些优势?
运维·服务器·安全·智能手机·生活
Jamesvalley8 小时前
【centos】安装python3.12
linux·运维·centos
qq_150841998 小时前
搭建一个基于星空组网的免费虚拟局域网
网络
凯子坚持 c8 小时前
Redis 数据库的服务器部署与 MCP 智能化交互深度实践指南
服务器·数据库·redis
肉清8 小时前
linux自用命令
linux·服务器·前端
Xの哲學8 小时前
Linux链路聚合深度解析: 从概念到内核实现
linux·服务器·算法·架构·边缘计算
wanhengidc8 小时前
具有ARM架构云手机的功能
运维·服务器·arm开发·科技·智能手机·云计算
wanhengidc8 小时前
巨 椰 云手机离线多开
运维·服务器·科技·智能手机·云计算
代码游侠8 小时前
应用——管道与文件描述符
linux·服务器·c语言·学习·算法
wefg18 小时前
【Linux】环境变量
linux·运维·服务器