SOCKET

发布时间:2024年01月13日

Linux下将所有外部设备都当作文件,SOCKET返回一个文件描述符

socket的客户端和用户端

tcp的Socket分为服务端和用户端,服务端需要listen()。
udp的Socket没有客户端和用户端的区别,是对等socket。

创建socket

socket(地址族,套接字类型,套接字协议)
socket(AF_INET,SOCKET_STREAM,0)
1. AD_INET是ipv4。
2. SOCKET_STREAM流式套接字,SOCKET_DGRAM数据报套接字,无连接的,SOCKET_RAW原始套接字。
3. 0是指根据设置的地址族和套接字类型自动选择套接字协议,如果需要使用特定的协议,需要使用特定的数字。

绑定目标客户端ip和监听主机端口:bind

bind绑定监听的网卡,所有ip地址的客户端都可以通过服务端的任意网卡连接。

bind(server_socket,server_addr,ip_addr_len);
server_addr{
	sin_family=AF_INET;
	sin_port=8080;//socket监听的端口
	sin_addr.s_addr=INADDR_ANY;//表示监听所有服务端的网卡
	// sin_addr.s_addr=inet.addr("1.1.1.1");表示监听ip为1.1.1.1的网卡
}

TCP专用函数

listen将套接字标记为被动套接字(服务端套接字)

listen(socketfd,int backlog)
backlog:等待队列中的最大连接数,即允许等待连接的客户端数量,后续可以通过accept取出建立连接。

send和recv

recv(sockfd,buf,buf_len,flags);//flags操作标志
send(sockfd,buf,buf_len,flags);
tcp经过accept建立了链路,所以不需要加地址

accept

int client_socketfd=accept(socketfd,&client_addr,client_addr_len);
返回的是创建的与客户端建立连接的socket

三次握手与socket

  1. 客户端connect(),发送syn同步信号,第一次握手。
  2. 服务端accept(),收到syn同步信号,建立与客户端的socket,返回ack信号。
  3. 客户端收到ack,并返回ack

UDP只使用sendto和recvfrom,bind

sendto(sockfd,buf,buf_len,flags,dest_addr,addrlen)
recvfrom(sockfd,buf,buf_len,flags,src_addr,addrlen)
文章来源:https://blog.csdn.net/qq_35693377/article/details/135566726
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。