Linux网络协议.之 tcp,udp,socket网络编程(三).之多进程实现并发demon

一、fork创建进程,来实现多并发

这只是个demon,并不能用于实际项目,多进程,消耗太多资源。没有人这么玩

1、服务端代码:

c 复制代码
#include <stdio.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
 
int main(int argc,char **argv)
{
        int s_fd;
        int c_fd;
        int n_read;
        char readBuf[128];
 
        char msg[128] = {0};
        struct sockaddr_in s_addr;
        struct sockaddr_in c_addr;
 
        if(argc != 3)
        {
                printf("param is not good\n");
                exit(-1);
        }
 
        memset(&s_addr,0,sizeof(struct sockaddr_in));
        memset(&c_addr,0,sizeof(struct sockaddr_in));
		
        //1.socket
        s_fd = socket(AF_INET,SOCK_STREAM,0);
        if(s_fd == -1)
        {
                perror("socket");
                exit(-1);
        }
 
        s_addr.sin_family = AF_INET;
        s_addr.sin_port = htons(atoi(argv[2]));
        inet_aton(argv[1],&s_addr.sin_addr);
 
        //2.bind
        bind(s_fd,(struct sockaddr *)&s_addr,sizeof(struct sockaddr_in));
 
        //3.listen 
        listen(s_fd,10);
 
        //4.accept
        int clen = sizeof(struct sockaddr_in);
        while(1)
        {
                c_fd = accept(s_fd,(struct sockaddr *)&c_addr,&clen);//父进程负责accept
                if(c_fd == -1)
                {
                        perror("accept");
                }
                printf("get connect:%s\n",inet_ntoa(c_addr.sin_addr));
 
                if(fork() == 0)//创建一个子进程,来实现读写功能,父进程负责accept
                {
                        if(fork() == 0)//创建一个子进程的子进程,来实现写功能
                        {
                                while(1)
                                {
                                        memset(msg,0,sizeof(msg));
                                        printf("input:");
                                        fgets(msg,sizeof(msg),stdin);
                                        write(c_fd,msg,strlen(msg));
                                }
                        }
 
                        //5.read
                        while(1)//子进程父进程,来实现读功能
                        {
                                memset(readBuf,0,sizeof(readBuf));
                                n_read = read(c_fd,readBuf,128);
                                if(n_read == -1)
                                {
                                        perror("read");
                                }
                                else
                                {
                                        printf("get message:%d,%s\n",n_read,readBuf);
                                }
                        }
                        break;
                }
        }
        return 0;
}

2、客户端代码:

c 复制代码
#include <stdio.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
 
int main(int argc,char **argv)
{
        int c_fd;
        int n_read;
        char readBuf[128];
 
//      char *msg = "msg form client";
        char msg[128] = {0};
        struct sockaddr_in c_addr;
 
        memset(&c_addr,0,sizeof(struct sockaddr_in));
 
        if(argc != 3)
        {
                printf("parm is not good\n");
                exit(-1);
        }
        //1.socket
        c_fd = socket(AF_INET,SOCK_STREAM,0);
        if(c_fd == -1)
        {
                perror("socket");
                exit(-1);
        }
 
        c_addr.sin_family = AF_INET;
        c_addr.sin_port = htons(atoi(argv[2]));
        inet_aton(argv[1],&c_addr.sin_addr);
 
        //2.connect
        if(connect(c_fd,(struct sockaddr *)&c_addr,sizeof(struct sockaddr)) == -1)
        {
                perror("connect");
                exit(-1);
        }
      
        if(fork() == 0)//创建一个子进程,来实现写功能
        {
                while(1)
                {
                        memset(msg,0,sizeof(msg));
                        printf("input:");
                        fgets(msg,sizeof(msg),stdin);
                        write(c_fd,msg,strlen(msg));
                }
        }
        while(1)//父进程进程,来实现读功能
        {
                memset(readBuf,0,sizeof(readBuf));
                n_read = read(c_fd,readBuf,128);
                if(n_read == -1)
                {
                        perror("read");
                }
                else
                {
                        printf("get message form server:%d,%s\n",n_read,readBuf);
                }
        }

        
        return 0;
}       
相关推荐
内核程序员kevin1 小时前
TCP Listen 队列详解与优化指南
linux·网络·tcp/ip
网易独家音乐人Mike Zhou3 小时前
【卡尔曼滤波】数据预测Prediction观测器的理论推导及应用 C语言、Python实现(Kalman Filter)
c语言·python·单片机·物联网·算法·嵌入式·iot
搬砖的小码农_Sky5 小时前
C语言:数组
c语言·数据结构
朝九晚五ฺ6 小时前
【Linux探索学习】第十四弹——进程优先级:深入理解操作系统中的进程优先级
linux·运维·学习
自由的dream6 小时前
Linux的桌面
linux
xiaozhiwise6 小时前
Makefile 之 自动化变量
linux
意疏8 小时前
【Linux 篇】Docker 的容器之海与镜像之岛:于 Linux 系统内探索容器化的奇妙航行
linux·docker
BLEACH-heiqiyihu9 小时前
RedHat7—Linux中kickstart自动安装脚本制作
linux·运维·服务器
一只爱撸猫的程序猿9 小时前
一个简单的Linux 服务器性能优化案例
linux·mysql·nginx