Linux 创建TCP连接流程

Linux创建TCP的步骤

TCP编程需要客户端和服务器两套编码,其创建TCP的流程也是不完全一致的

服务端
  1. 使用socket函数创建一个套接字
  2. 使用setsockopt函数设置套接字的属性
  3. 使用bind函数绑定IP地址、端口信息到套接字上
  4. 使用listen函数监听指定端口
  5. 使用accept函数接收客户端的连接请求
  6. 使用send/recv和read/write函数进行数据的收发
  7. 使用close函数关闭网络连接和监听
客户端
  1. 使用socket函数创建套接字
  2. 使用setsockopt函数设置套接字属性
  3. 使用bind函数绑定IP地址和端口信息
  4. 设置需要连接的IP地址和端口
  5. 使用connect函数请求建立连接
  6. 使用send/recv和read/write函数进行数据的收发
  7. 使用close函数关闭网路连接
TCP建立流程

在这里插入图片描述

示例代码

服务器

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <string.h>
#include <fcntl.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <pthread.h>
#include <time.h>
#define MAXSIZE 128

char news[MAXSIZE];
int res;			//用以接收函数返回值

void* pthread_chat(void * arg)		//创建线程用以接收数据
{
    int confd = *(int *)arg;
    while(1)
    {
        res  = recv(confd, news, sizeof(news), 0);
        if(res <= 0)
        {
        perror("recv");
        break;
        }
        printf("The news is: %s\n",news);
        memset(news,0,MAXSIZE);
        send(confd,"OK",2,0);
    }

    printf("One client over\n");
    close(confd);
}

char *Time()					//获取当前时间
{
	time_t timer;
	struct tm *tblock;
	timer = time(NULL);
	tblock = localtime(&timer);
	return asctime(tblock);
}

void save(char *s)				//储存日志文件
{
    int fd;
    fd = open("journal",O_RDWR|O_APPEND|O_CREAT);

    if(fd < 0)
        perror("open");
    else
    {
        char *buf = Time();
        strcat(buf,s);
                
        write(fd,buf,MAXSIZE);
        lseek(fd,0,SEEK_END);
        
        if(res < 0)
            perror("write");
    }
}

int main()
{
    int sockfd = socket(AF_INET, SOCK_STREAM, 0);
    struct sockaddr_in saddr, caddr;
    saddr.sin_family = AF_INET;
    saddr.sin_port = htons(6666);
    saddr.sin_addr.s_addr = inet_addr("127.0.0.1");

    res = bind(sockfd,(struct sockaddr*)&saddr, sizeof(saddr));
    if(res < 0)
        perror("bind");

    listen(sockfd, 5);			//监听端口

    while(1)
    {
        int len = sizeof(caddr);
        int confd = accept(sockfd,(struct sockaddr*)&caddr, &len);
        if(confd < 0)
        {
            perror("accept");
            continue;
        }else
        {
            save(inet_ntoa(caddr.sin_addr));
        }

        printf("Accept confdis:%d, ip=%s\n",confd,inet_ntoa(caddr.sin_addr));

        pthread_t tid;
        pthread_create(&tid, NULL, pthread_chat, &confd);
    }
}

客户端

#include <string.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>  
#define MAXSIZE 128

char news[MAXSIZE];
int res;					//用来接收函数返回值
int main()
{
    printf("------Welcome join the chat room-----\n");
    printf("If you want to quit,please input --bye--\n");
    int sockfd = socket(AF_INET, SOCK_STREAM, 0);
      
    struct sockaddr_in saddr;
    saddr.sin_family = AF_INET;
    saddr.sin_port = htons(6666);
    saddr.sin_addr.s_addr = inet_addr("127.0.0.1");
  
    int confd = connect(sockfd,(struct sockaddr*)&saddr,sizeof(saddr));
    if(confd < 0)
        perror("connect");
    
    while(1)
    {
        printf("Please input the news\n");
        fgets(news,MAXSIZE,stdin);
          
        if(strncmp(news,"bye",3) == 0)
        {
            break;
        }

        send(sockfd, news, strlen(news), 0);
        memset(news,0,MAXSIZE);
        recv(sockfd, news, sizeof(news), 0);
          printf("The serve's news is: %s\n",news);
    }

    close(sockfd);
    exit(0);
}

请注意,服务端由于使用了多线程开发,需要在编译时添加-lpthread选项

程序运行效果如下:
在这里插入图片描述

  • 0
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
很抱歉,我无法提供图片或图表。但是,我可以用文字描述Linux TCP流程。以下是一个简化的描述: 1. 服务器创建一个套接字并绑定一个端口号,开始监听来自客户端的连接请求。 2. 客户端创建一个套接字,并向服务器发起连接请求。 3. 服务器接受连接请求,并为该连接创建一个新的套接字。 4. 客户端与服务器之间建立起TCP连接。双方可以通过套接字进行数据传输。 5. 数据传输过程中,发送方将数据分成较小的数据块,并在每个数据块上添加TCP头部信息。 6. 发送方将数据块发送给接收方,接收方收到数据后,将确认信息发送回发送方。 7. 如果发送方收到确认信息,表示数据已成功传输到接收方。如果发送方在一定时间内没有收到确认信息,则认为数据丢失或损坏,将重新发送该数据块。 8. TCP协议通过拥塞控制算法来避免网络拥塞。如果网络拥塞,发送方将减少发送速率。 9. 当发送方完成数据传输后,发送一个FIN包给接收方,表示数据传输结束。 10. 接收方收到FIN包后,发送一个ACK包作为确认,并进入半关闭状态。 11. 发送方收到ACK包后,关闭连接。接收方继续等待可能延迟的数据,并在收到后发送一个ACK包给发送方。 12. 当接收方也完成数据传输后,发送一个FIN包给发送方。 13. 发送方收到FIN包后,发送一个ACK包作为确认,并关闭连接。 这是一个简化的描述,实际的TCP流程可能会有更多的细节和协议规定。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值