TCP多线程服务端-客户端模板(Linux下)

简介: TCP多线程服务端-客户端模板(Linux下)

服务器模板

#include <stdio.h>
#include <sys/types.h>          /* See NOTES */
#include <sys/socket.h>
#include <stdlib.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <string.h>
#include <unistd.h>
#include <time.h>
#include <pthread.h>
#include <malloc.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <signal.h>
#define PORT 9999   // 端口
void *client_thread(void *arg);
//多线程 并发服务器
int main(int argc, char const *argv[])
{
    int ret;
    int sockfd;  //套接字描述符
    int connfd;
    char buf[1024];
    int fp;
    sockfd = socket(AF_INET, SOCK_STREAM, 0); //创建通信套接字ipv4协议 tcp通信
    if(sockfd==-1){
        printf("socket failed\n");
        exit(-1);
    }
    //定义addr存入本机地址信息
    struct sockaddr_in addr;
    addr.sin_family =  AF_INET   ;  //协议
    addr.sin_port =  htons(PORT) ;  //端口
    addr.sin_addr.s_addr = inet_addr("0") ; //ip  0代表本机
    //绑定地址信息(sockfd + addr)
    ret = bind(sockfd, (struct sockaddr *)&addr, sizeof(addr)); 
    if(ret==-1){
        printf("bind failed\n");
        exit(-1);
    }
    listen(sockfd,255);  //建立监听队列,并监听状态
    while(1){
        printf("wait...\n");
        connfd =  accept(sockfd, NULL, NULL); //建立连接
        printf("connect a client\n");
        // 创建子线程
        pthread_t pid;
        pthread_create(&pid, NULL, client_thread, (void *)&connfd);
        pthread_detach(pid);
    }
    close(sockfd);
    return 0;
}
// 线程函数
void *client_thread(void *arg)
{
    int connfd = *(int *)arg;
    char buf[256];  // 接收缓冲区,大小根据你的需求定
    while(1) {
      // 你的程序逻辑
        // 接收函数: ret = read(connfd, buf, sizeof(buf));   // 返回值为实际接收的字节数,ret <= 0 表示客户端断开连接
        // 发送函数: ret = write(connfd, buf, sizeof(buf));  // 返回值为实际发送的字节数
    }
}

客户端模板

#include <stdio.h>
#include <stdlib.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <string.h>
#include <sys/socket.h>
#include <time.h>
#include <unistd.h>
#include <sys/stat.h>
#include <fcntl.h>
#define HOST "192.168.1.108"  // 服务器地址
#define PORT 9999  // 服务器端口
//搭建tcp客服端
int main(int argc, char const *argv[])
{
  int ret,ret1,ret2;
  int sockfd; //套接字描述符
  srand(time(NULL));
  sockfd = socket(AF_INET ,SOCK_STREAM, 0); //创建通信套接字(TCP)
  if(sockfd == -1)
  {
    printf("socket failed\n");
    exit(-1);
  }
  //定义addr存入本机地址信息
  struct sockaddr_in addr;
    addr.sin_family = AF_INET; //协议
    addr.sin_port = htons(PORT);    //端口
    addr.sin_addr.s_addr= inet_addr(HOST); //服务器地址
    ret = connect(sockfd, (struct sockaddr *)&addr, sizeof(addr));  //连接tcp客服端
    if(ret == -1)
    {
      printf("connect failed1\n");
      return 0;
    }
    printf("connect success!\n");
    while(1)
    {
      // 你的程序逻辑
        // 接收函数: ret = read(connfd, buf, sizeof(buf));   // 返回值为实际接收的字节数
        // 发送函数: ret = write(connfd, buf, sizeof(buf));  // 返回值为实际发送的字节数
    }
    close(sockfd); //关闭通信套接字(TCP)
}
目录
相关文章
|
2月前
|
网络协议 C语言
C语言 网络编程(十四)并发的TCP服务端-以线程完成功能
这段代码实现了一个基于TCP协议的多线程服务器和客户端程序,服务器端通过为每个客户端创建独立的线程来处理并发请求,解决了粘包问题并支持不定长数据传输。服务器监听在IP地址`172.17.140.183`的`8080`端口上,接收客户端发来的数据,并将接收到的消息添加“-回传”后返回给客户端。客户端则可以循环输入并发送数据,同时接收服务器回传的信息。当输入“exit”时,客户端会结束与服务器的通信并关闭连接。
|
2月前
|
C语言
C语言 网络编程(九)并发的UDP服务端 以线程完成功能
这是一个基于UDP协议的客户端和服务端程序,其中服务端采用多线程并发处理客户端请求。客户端通过UDP向服务端发送登录请求,并根据登录结果与服务端的新子线程进行后续交互。服务端在主线程中接收客户端请求并创建新线程处理登录验证及后续通信,子线程创建新的套接字并与客户端进行数据交换。该程序展示了如何利用线程和UDP实现简单的并发服务器架构。
|
3月前
|
运维 Kubernetes Linux
docker和kubectl客户端安装Linux
通过上述步骤,您应该已经在Linux环境中成功安装了Docker和kubectl客户端。安装完成后,您可以开始使用Docker来创建和管理容器,使用kubectl来管理Kubernetes集群。这些工具的安装和使用,对于现代云原生应用的开发和运维来说,是一个基础且关键的步骤。
40 0
|
3月前
|
Linux 数据安全/隐私保护
Linux下svn服务端的安装与配置
Linux下svn服务端的安装与配置
58 0
|
5月前
|
API
linux---线程互斥锁总结及代码实现
linux---线程互斥锁总结及代码实现
|
5月前
|
安全 Linux 测试技术
|
5月前
|
Linux API
Linux线程总结---线程的创建、退出、取消、回收、分离属性
Linux线程总结---线程的创建、退出、取消、回收、分离属性
|
5月前
|
API
Linux---线程读写锁详解及代码实现
Linux---线程读写锁详解及代码实现
|
4月前
|
缓存 Linux 编译器
【Linux】多线程——线程概念|进程VS线程|线程控制(下)
【Linux】多线程——线程概念|进程VS线程|线程控制(下)
69 0
|
4月前
|
存储 Linux 调度
【Linux】多线程——线程概念|进程VS线程|线程控制(上)
【Linux】多线程——线程概念|进程VS线程|线程控制(上)
72 0
下一篇
无影云桌面