Linux下socket编程之多线程TCP服务器

代码如下:
thread_server.c

#include<string.h>
#include<stdlib.h>
#include<stdio.h>
#include<sys/types.h>
#include<sys/socket.h>
#include<netinet/in.h>
#include<pthread.h>
#include<arpa/inet.h>
#include<unistd.h>
void usage(char* proc)
{
    printf("%s [ip][port]\n",proc);
}
int startup(char* ip,int port)
{
    int sock=socket(AF_INET,SOCK_STREAM,0);
    if(sock<0)
    {
        perror("socket");
        return 2;
    }
    struct sockaddr_in local;
    local.sin_family=AF_INET;
    local.sin_port=htons(port);
    local.sin_addr.s_addr=inet_addr(ip);
    int opt=1;
    setsockopt(sock, SOL_SOCKET, SO_REUSEADDR, &opt, sizeof(opt));
    if((bind(sock,(struct sockaddr*)&local,sizeof(local)))<0)
    {
        perror("bing");
        return 3;
    }
    if(listen(sock,10)<0)
    {
        perror("listen");
        close(sock);
        exit(4);
    }
    return sock;
}
void handler(char* arg)
{
        int sock=(int)arg;
        char buff[1024];
        while(1)
        {
            ssize_t s = read(sock,buff,sizeof(buff));
            if(s >0)
            {
            buff[s] = '\0';
            printf("client:#%s",buff);
            const char* msg = "HTTP/1.1 200 OK\r\n\r\n<html><h1>This is title</h1></html>\r\n";
            write(sock,msg,strlen(msg));
            }
            if(s==0)
            {
                break;
            }   
        }
        printf("client quit!\n");   
        fflush(stdout);
}
int main(int argc,char* argv[])
{
    if(argc<3)
    {
        usage(argv[0]);
        return 1;
    }
    int listen_sock=startup(argv[1],atoi(argv[2]));
    struct sockaddr_in client_addr;
    socklen_t len=sizeof(client_addr);
    while(1)
    {
        int new_sock=accept(listen_sock,(struct sockaddr *)&client_addr,&len);
        if(new_sock<0)
        {
            perror("accept");
            return 5;
        }
        char ipbuff[INET_ADDRSTRLEN];
        memset(ipbuff,'\0',sizeof(ipbuff));
        inet_ntop(AF_INET,&client_addr.sin_addr,ipbuff,sizeof(ipbuff));
        printf("get connect,ip is %s,port is %d\n",ipbuff,ntohs(client_addr.sin_port));
        pthread_t tid;  
        pthread_create(&tid, NULL, handler, (void*)new_sock);  //创建线程执行handler
        pthread_detach(tid);//将子线程与主线程分离
    }
    close(listen_sock);
    return 0;
}

与tcp和tcp多进程服务器端差别不大,原来是交给一个进程处理,现在是交给一个线程,都类似,不做多的解释,客户端还是看最开始版本tcp客户端,不在这里多写,代码都一样。
实验效果图:
服务器端:
这里写图片描述
客户端1:
这里写图片描述
客户端2:
这里写图片描述
欢迎评论

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值