Linux TCP 连接问题

我是土豆不是地瓜 2018-03-01 05:59:11
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <sys/socket.h>
#include <arpa/inet.h>
#include <strings.h>

#define MAXSIZE 4096
#define SERV_PORT 8000

int main(void)
{
int listenFd, connectFd;
struct sockaddr_in servaddr, cliaddr;
socklen_t cliaddr_len;
char buf[MAXSIZE];
char str[INET_ADDRSTRLEN];
ssize_t numRead;
int ret;

listenFd = socket(AF_INET, SOCK_STREAM, 0);
if (-1 == listenFd)
{
perror("socket");
exit(EXIT_FAILURE);
}

bzero(&servaddr, sizeof(servaddr));
servaddr.sin_family = AF_INET;
servaddr.sin_addr.s_addr = htonl(INADDR_ANY);
servaddr.sin_port = htons(SERV_PORT);

int opt = 1;
setsockopt(listenFd, SOL_SOCKET, SO_REUSEADDR, &opt, sizeof(opt));

ret = bind(listenFd, (struct sockaddr *)&servaddr, sizeof(servaddr));
if (-1 == ret)
{
perror("bind");
exit(EXIT_FAILURE);
}

ret = listen(listenFd, 5);
if (-1 == ret)
{
perror("listen");
}

cliaddr_len = sizeof(cliaddr);
connectFd = accept(listenFd, (struct sockaddr *) &cliaddr, &cliaddr_len);
if (-1 == connectFd)
{
perror("accept");
exit(EXIT_FAILURE);
}

printf("receive from %s at PROT %d\n",
inet_ntop(AF_INET, &cliaddr.sin_addr, str, INET_ADDRSTRLEN),
ntohs(cliaddr.sin_port));

while (1)
{
numRead = recv(connectFd, buf, MAXSIZE, 0);
if (-1 == numRead)
{
perror("recv");
exit(EXIT_FAILURE);
}

printf("receive: %s\n", buf);

memset(buf, 0, MAXSIZE);
}

return 0;
}




最近在学习Linux 网络,很多不理解。以上时我写一个程序,使用命令netstat -apn | grep 8000查看连接状态,想感受什么叫做TCP是面向连接?

有个问题想请教网友,我写的这个程序只能连接一次,为什么开启第二个客户端开始连接的时候,状态栏会显示ESTABLISHED?
开启第一个客户端时,服务器运行到while(1){}语句内的 numRead = recv(connectFd, buf, MAXSIZE, 0);,一直阻塞在这里;当开启第二个客户端时,应该没有连接上呀?
初学者,求各位大牛帮我分析解释下!最好能够将connect(); accept() 和 TCP层 以及SYN, ACK, 结合起来帮我分析下,十分感激
...全文
429 5 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
zilaishuichina 2018-03-05
  • 打赏
  • 举报
回复
服务端回复 ack 之后, 说明客户端到服务器的链接建立好了, 客户端回复 ack 之后, 说明服务器到客户端的链接建立好了, 你可以看什么时候变成ESTABLISHED状态了,就是什么时候建立好了
  • 打赏
  • 举报
回复
引用 2 楼 zilaishuichina 的回复:
tcp3次握手成功后 就是 ESTABLISHED状态, 这个链接已经建立好了,放在全连接队列里了(lz可以去搜TCP 半连接队列和全连接队列,了解一下), accept只是从这个队列里将建立好的链接取出来而已。 所以即使你上层逻辑在recv那阻塞了, TCP底层该接受链接还是接受链接,直到这个队列满了为止。


客户端向服务器发送一个SYN,服务器接收到后,这时候是不是说明了服务器到客户端的连接已经建立好了?
客户端想服务器发送一个ACK,服务器接收到后,是否说明客户端到服务器的连接已经建立好了?
  • 打赏
  • 举报
回复
引用 2 楼 zilaishuichina 的回复:
tcp3次握手成功后 就是 ESTABLISHED状态, 这个链接已经建立好了,放在全连接队列里了(lz可以去搜TCP 半连接队列和全连接队列,了解一下), accept只是从这个队列里将建立好的链接取出来而已。 所以即使你上层逻辑在recv那阻塞了, TCP底层该接受链接还是接受链接,直到这个队列满了为止。
谢谢!
zilaishuichina 2018-03-03
  • 打赏
  • 举报
回复
tcp3次握手成功后 就是 ESTABLISHED状态, 这个链接已经建立好了,放在全连接队列里了(lz可以去搜TCP 半连接队列和全连接队列,了解一下), accept只是从这个队列里将建立好的链接取出来而已。 所以即使你上层逻辑在recv那阻塞了, TCP底层该接受链接还是接受链接,直到这个队列满了为止。
赵4老师 2018-03-02
  • 打赏
  • 举报
回复
百度搜相关关键字。

70,022

社区成员

发帖
与我相关
我的任务
社区描述
C语言相关问题讨论
社区管理员
  • C语言
  • 花神庙码农
  • 架构师李肯
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧