美文网首页
子进程 并发

子进程 并发

作者: 菜汁橙 | 来源:发表于2018-09-20 15:28 被阅读0次
#include "socket_includes.h"
#include <signal.h>


int mz_ipv4_tcp_create_socket(void)
{
    int listenfd, sockfd, opt = 1;
    struct sockaddr_in server, client;
    socklen_t len;
    int timep;
    int ret;

    listenfd = socket(AF_INET, SOCK_STREAM, 0);
    if(listenfd < 0){
        perror("Create socket fail.");
        return -1;
    } 

    if((ret = setsockopt(listenfd, SOL_SOCKET, SO_REUSEADDR, &opt, sizeof(opt))) < 0){
        perror("Error, set socket reuse addr failed");  
        return -1;
    }

    bzero(&server, sizeof(server));
    server.sin_family = AF_INET;
    server.sin_port   = htons(SERV_PORT);
    server.sin_addr.s_addr  = htonl(INADDR_ANY);
    
    len = sizeof(struct sockaddr);
    if(bind(listenfd, (struct sockaddr *)&server, len)<0){
              perror("bind error.");
        return -1;
    }
    
      
    listen(listenfd, MAX_LISTEN_QUE);

    return listenfd;
}

int mz_process_data(int sockfd)
{
    int bytes;
    char buf[MAX_BUFFER_SIZE], read_buf[MAX_BUFFER_SIZE];

    memset(read_buf, 0x00, MAX_BUFFER_SIZE);
    memset(buf, 0x00, MAX_BUFFER_SIZE);

    while(1){
        
        bytes = recv(sockfd, read_buf, 100, 0);
        if(bytes < 0){
            printf("read err.\n");
            return -1;
        }
        if(bytes == 0){
            printf("client connection closed.\n");
            return 0;
        }
        printf("Bytes:%d\n", strlen(read_buf));
        printf("read_buf: %x %x %x \n", read_buf[0], read_buf[1], read_buf[2]);

        send(sockfd, read_buf, bytes, 0);

        if(!strcmp(read_buf, "q")){
            break;
        }
        if(!strcmp(read_buf, "c")){
            printf("i love you.\n");
            sprintf(read_buf, "%s","i love you.\n" );
            send(sockfd, read_buf, bytes, 0);
        }
    }
    close(sockfd);
    return 0;
}

int mz_process_signal(int signo)
{
    switch(signo){
        case SIGCHLD:
            printf("dddddddddd\n");
            while(waitpid(-1, NULL, WNOHANG)>0);    
        break;
    }
}

int mz_set_signal_handler(void)
{
    struct sigaction act, oact;
    act.sa_handler = (void *)mz_process_signal;
    sigemptyset(&act.sa_mask);
    act.sa_flags = 0;
    act.sa_flags |= SA_RESTART;
    if(sigaction(SIGCHLD, &act, &oact) < 0){
        return -1;
        }
        return 0;
}

int main(int argc, char *argv[])
{
    int listenfd, sockfd;
    struct sockaddr_in server, client;
    socklen_t len;
    int bytes =0 ;

    
    mz_set_signal_handler();
    
    len = sizeof(struct sockaddr);
    
    listenfd = mz_ipv4_tcp_create_socket();
    
    while(1){
        sockfd = accept(listenfd, (struct sockaddr *)&client, &len);
        if(sockfd < 0){
            perror("accept error.");
            return -1;
        }

        printf("sockfd=%d\n", sockfd);
        printf("IP: 0x%x, Port:%d\n", ntohl(client.sin_addr.s_addr), ntohs(client.sin_port));
        if(fork() == 0){
            close(listenfd);
            mz_process_data(sockfd);
            exit(0);
        }
        close(sockfd);
      

    }
    return 0;
}











#include <stdio.h>
#include <stdlib.h>
#include <string.h>


#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>


#include <unistd.h>
#include <fcntl.h>



#define MAX_LISTEN_QUE 5


#define SERV_PORT 8888

#define MAX_BUFFER_SIZE 100




相关文章

  • 子进程 并发

  • 优雅关闭以及如何检测对端已经关闭

    1. 什么是优雅关闭 一种情况是在多进程并发时,假设客户端有两个进程,父进程和子进程,子进程是在父进程和服务器建立...

  • Linux中的wait()

    编程过程中,因为并发的前提,需要让一个进程等待另一个进程,最常见的是父进程等待自己的子进程,或者父进程回收自己的子...

  • Node.js多进程

    Node.js多进程Node.js单线程模式运行的,使用事件处理并发。 exec() 使用子进程的执行命令,缓存子...

  • apache调优

    最初建立的子进程数 最小空闲进程数,如果空闲的进程小于设定值,apache会自动创建进程,如遇服务器并发负载较大时...

  • python 进程与并发

    多进程:Python中提供multiprocess模块实现多进程并发 进程并发:concurrent模块 虽然mu...

  • python如何处理并发

    Mutilprocessing 包提供本地和远程并发性,通过子进程而不是线程有效地侧移“全局解释器锁”。进程是通过...

  • java 多线程1-进程与线程

    简而言之:进程让系统执行任务时让并发成为可能,线程让程序执行他的子任务时的并发成为可能,线程粒度更细。 1.进程(...

  • Nodejs child_process学习

    Nodejs子进程、多进程 我们都知道 Nodejs 是以单线程的模式运行的,但它使用的是事件驱动来处理并发,这样...

  • happypack 提升 Webpack 构建速度

    Happypack 的作用就是将文件解析任务分解成多个子进程并发执行,发挥多核 CPU 电脑的威力。子进程处理完任...

网友评论

      本文标题:子进程 并发

      本文链接:https://www.haomeiwen.com/subject/sxlnnftx.html