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;
}       
相关推荐
打不了嗝 ᥬ᭄30 分钟前
Linux的权限
linux
落幕35 分钟前
C语言-进程
linux·运维·服务器
深度Linux44 分钟前
C++程序员内功修炼——Linux C/C++编程技术汇总
linux·项目实战·c/c++
风静如云2 小时前
OpenBMC:BmcWeb定义service
linux
leoufung3 小时前
VIM FZF 安裝和使用
linux·编辑器·vim
bugtraq20214 小时前
XiaoMi Mi5(gemini) 刷入Ubuntu Touch 16.04——安卓手机刷入Linux
linux·运维·ubuntu
CodeWithMe4 小时前
[ Vim ] 常用命令 and 配置
linux·编辑器·vim
DC_BLOG4 小时前
Linux-GlusterFS进阶分布式卷
linux·运维·服务器·分布式
cookies_s_s5 小时前
Linux--进程(进程虚拟地址空间、页表、进程控制、实现简易shell)
linux·运维·服务器·数据结构·c++·算法·哈希算法
丁劲犇5 小时前
碳基生物的悲歌-DeepSeek思考实现Linux动态库递归收集工具
linux·递归·deepseek·ldd