如何使用fork系统调用在c++套接字上编写多用户tcp服务器



我在c++中的套接字上编写服务器和客户端。我有一个为一个客户端运行的服务器。告诉我如何使用fork编写多用户服务器。

服务器:

    int main() {
    int server_socket = Socket(AF_INET, SOCK_STREAM, 0);
    struct sockaddr_in adr = {0};
    adr.sin_family = AF_INET;
    adr.sin_port = htons(1110);
    Bind(server_socket, (struct sockaddr* )&adr, sizeof(adr));
    Listen(server_socket, SOMAXCONN);
    socklen_t adr_len = sizeof(adr);
    int res_accept = Accept(server_socket, (struct sockaddr* ) &adr, &adr_len);
    while(true) {
        char buffer[1024];
        ssize_t count_read = Recv(res_accept, buffer, 1024, 0);
        printf("%sn", buffer);
        fflush(stdin);
        char res[10];
        int result = words_counter(buffer);
        sprintf(res, "%dn", result);
        ssize_t count_send = Send(res_accept, res, 10, 0);
    }
    close(res_accept);
    close(server_socket);
    return 0;
}

客户端:

    int main(int argc, char const *argv[]) {
    int client_socket = Socket(AF_INET, SOCK_STREAM, 0);
    struct sockaddr_in adr = {0};
    adr.sin_family = AF_INET;
    adr.sin_port = htons(1110);
    Inet_pton(AF_INET, "127.0.0.1", &adr.sin_addr);
    int res_connect = Connect(client_socket, (struct sockaddr* ) &adr, sizeof(adr));
    
    while (true) {
        char message[1024];
        printf("input messagen");
        fgets(message, 1024, stdin);
        if (strncmp(message, "quit!", 5) == 0) break;
        ssize_t count_send = Send(client_socket, message, 1024, 0);
        char buffer[10];
        ssize_t count_read = Recv(client_socket, buffer, 10, 0);
        printf("SERVER: The number of words in the transmitted message: %s", buffer);
    }
    close(client_socket);
    return 0;
}

我使用自己编写的包装函数(为了方便错误处理(,如bindlisten等。因此,函数名称用大写字母书写。感谢的帮助

告诉我如何使用fork编写多用户服务器。

我认为您正在询问如何通过使用fork调整现有服务器以服务于多个客户端。最简单的方法是

  1. 对从Accept()调用到close(res_accept)的所有内容进行循环。这提供了接受多个连接。如果您只想按顺序处理多个客户端,那么这将在没有任何分叉的情况下完成。但是为了能够同时处理多个客户端

  2. CCD_ 8。让(仅(子级执行while循环,然后执行_exit()。相反,父级将跳过while循环到close(res_accept)。这释放了父级以接受更多的连接,而子级则处理与新接受的客户端的交互。

相关内容

  • 没有找到相关文章

最新更新