【网络编程】如何创建一个自己的并发服务器?

 

hello !大家好呀! 欢迎大家来到我的网络编程系列之如何创建一个自己的并发服务器,在这篇文章中,你将会学习到在Linux内核中如何创建一个自己的并发服务器,并且我会给出源码进行剖析,以及手绘UML图来帮助大家来理解,希望能让大家更能了解网络编程技术!!!

希望这篇文章能对你有所帮助,大家要是觉得我写的不错的话,那就点点免费的小爱心吧!

               

  如何创建高并发服务器

 对于如何创建一个自己的并发服务器,我们首先需要了解框架,就比如一个简单的shttpd服务器,其框架如图:

 在其中我们要知道这个框架能实现什么功能,有什么作用。

那么我们知道了这个微型服务器的大致框架,我们就要运用到代码上:

创建一个自己的并发 HTTP 服务器(shttpd)涉及到网络编程和 HTTP 协议的实现。以下是一个基本的步骤指南,用于在 Linux 系统上使用 C 语言和 POSIX 线程(pthread)创建一个简单的并发 HTTP 服务器。

大致服务过程如下:

那么如何实现呢? 

1. 确定服务器需求

明确你的服务器需要支持哪些 HTTP 方法(GET, POST 等),以及预期的并发量。

2. 选择合适的编程语言和库

我们将使用 C 语言和 POSIX 线程(pthread)库来创建一个多线程的 HTTP 服务器。

3. 创建 socket

使用 socket() 系统调用创建一个 TCP socket。

int serv_sock = socket(PF_INET, SOCK_STREAM, 0);
if (serv_sock == -1) {perror("socket() error");exit(1);
}

4. 绑定地址和端口

使用 bind() 系统调用将 socket 绑定到一个地址和端口。

struct sockaddr_in serv_addr;
memset(&serv_addr, 0, sizeof(serv_addr));
serv_addr.sin_family = AF_INET;
serv_addr.sin_addr.s_addr = htonl(INADDR_ANY);
serv_addr.sin_port = htons(PORT);if (bind(serv_sock, (struct sockaddr*)&serv_addr, sizeof(serv_addr)) == -1) {perror("bind() error");exit(1);
}

5. 监听连接

使用 listen() 系统调用开始监听连接。

if (listen(serv_sock, 5) == -1) {perror("listen() error");exit(1);
}

6. 创建线程处理函数

编写一个函数,用于线程处理客户端连接。这个函数将解析 HTTP 请求,并返回一个简单的 HTTP 响应。

void *handle_client(void *arg) {int clnt_sock = *(int *)arg;char request[1024];int read_len;// 读取 HTTP 请求read_len = read(clnt_sock, request, sizeof(request) - 1);if (read_len > 0) {request[read_len] = 0;printf("Received request: %s\n", request);// 发送 HTTP 响应char *response = "HTTP/1.1 200 OK\r\nContent-Type: text/html\r\n\r\n<html><body><h1>Hello, World!</h1></body></html>";write(clnt_sock, response, strlen(response));}close(clnt_sock);return NULL;
}

7. 接受连接并创建线程

使用 accept() 系统调用接受客户端连接,并为每个连接创建一个新的线程。

while (1) {struct sockaddr_in clnt_addr;socklen_t clnt_addr_size = sizeof(clnt_addr);int clnt_sock = accept(serv_sock, (struct sockaddr*)&clnt_addr, &clnt_addr_size);if (clnt_sock == -1) {perror("accept() error");continue;}pthread_t t_id;if (pthread_create(&t_id, NULL, handle_client, (void *)&clnt_sock) != 0) {perror("pthread_create() error");continue;}pthread_detach(t_id); // 使线程分离,不需要等待其终止
}

8. 关闭服务器 socket

在服务器终止前,关闭服务器 socket。

close(serv_sock);

9. 编译和运行

将上述代码保存为一个 .c 文件,例如 shttpd.c,然后使用以下命令编译:

gcc -o shttpd shttpd.c -lpthread

运行服务器:

./shttpd

以上过程分析可以总结为一下uml图的过程: 

 

注意事项

  • 上述代码仅用于演示目的,没有错误处理和资源清理。
  • 在生产环境中,应该添加适当的错误处理和日志记录。
  • 应确保服务器能够正确处理客户端断开连接的情况。
  • 考虑到安全性,可能需要实现更多的功能,如数据加密和身份验证。
  • 这个基本的示例仅支持 GET 方法,并且返回一个简单的 HTML 响应。实际应用中,你可能需要解析更多的 HTTP 请求头,支持其他 HTTP 方法,以及提供动态内容。

 

 

 根据以上一个简单并发服务器的结构分析,我们知道了如何实现一个最简单属于自己的服务器,

 

 

 

   好啦!到这里这篇文章就结束啦,关于实例代码中我写了很多注释,如果大家还有不懂得,可以评论区或者私信我都可以哦!! 感谢大家的阅读,我还会持续创造网络编程相关内容的,记得点点小爱心和关注哟!  

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/624939.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

3D目标检测实用技巧(三)- 生成虚拟点

一、引言 本次参考的是VirConv生成虚拟点的方法&#xff1a; VirConv/tools/PENet at master hailanyi/VirConv GitHubVirtual Sparse Convolution for Multimodal 3D Object Detection - VirConv/tools/PENet at master hailanyi/VirConvhttps://github.com/hailanyi/Vir…

手写spring IOC底层源码来模拟spring如何利用多级缓存解决循环依赖的问题

在文章开始之前&#xff0c;先来看一张spring IOC加载过程的脑图吧 Spring IOC的加载过程 首先,当我们去new了一个applicationContext,它底层呢就会把我们配置的bean进行扫描,然后创建成一个一个的beanDefinition放在我们的beanDefinitionMap中,此时就有了一切创造bean的原料信…

计算机网络:MAC地址 IP地址 ARP协议

计算机网络&#xff1a;MAC地址 & IP地址 & ARP协议 MAC地址IP地址ARP协议 MAC地址 如果两台主机通过一条链路通信&#xff0c;它们不需要使用地址就可以通信&#xff0c;因为连接在信道上的主机只有他们两个。换句话说&#xff0c;使用点对点信道的数据链路层不需要使…

宝剑锋从磨砺出,透视雀巢咖啡品牌焕新与产品升级的想象力

自1989年进入中国市场以来&#xff0c;陪伴着国内咖啡行业由启蒙期走向兴盛期的雀巢咖啡&#xff0c;始终坚持以消费者高品质、个性化需求为本位&#xff0c;在保有独特性的基础上持续创新&#xff0c;实现了从无到有的攻克与突破。 近日&#xff0c;深耕中国三十六载的雀巢咖…

2024蓝桥杯每日一题(组合计数)

备战2024年蓝桥杯 -- 每日一题 Python大学A组 试题一&#xff1a;计算系数 试题二&#xff1a;求组合数1 试题三&#xff1a;求组合数2 试题四&#xff1a;杨辉三角形 试题一&#xff1a;计算系数 【题目描述】 给定一个多项式 (axby)k&#xff0c;请…

数字革命的先锋:Web3对社会的影响

引言 在信息技术飞速发展的当下&#xff0c;Web3作为一个新兴的互联网模式&#xff0c;正在逐渐改变我们的生活方式、商业模式和社会结构。本文将深入探讨Web3的核心特点、它在各个领域中的应用以及对社会产生的深远影响。 1. Web3的核心特点 1.1 去中心化 Web3强调去中心化…

电脑不能上网,宽带调制解调器出现问题如何处理

目录 一、问题说明 二、解决方案 一、问题说明 内网的设备能互联&#xff0c;内网的各个设备无法连外网。 电脑在检测网络时&#xff0c;出现以下提示&#xff1a; 二、解决方案 首先重启光猫&#xff08;我们是电信宽带&#xff09;。 如果还是有问题&#xff0c;再重启…

【Blockchain】连接智能合约与现实世界的桥梁Chainlink

去中心化预言机试图实现依赖因果关系而不是个人关系的去信任和确定性结果。它以与区块链网络相同的方式实现这些结果&#xff0c;即在许多网络参与者之间分配信任。通过利用许多不同的数据源并实施不受单个实体控制的预言机系统&#xff0c;去中心化的预言机网络有可能为智能合…

第十五届蓝桥杯题解-数字接龙

题意&#xff1a;经过所有格子&#xff0c;并且不能进行交叉&#xff0c;走的下一个格子必须是当前格子值1%k&#xff0c;输出路径最小的那一条&#xff08;有8个方向&#xff0c;一会粘图&#xff09; 思路&#xff1a;按照8个方向设置偏移量进行dfs&#xff0c;第一个到达终…

Achronix FPGA增加对Bluespec提供的基于Linux的RISC-V软处理器的支持,以实现可扩展数据处理

Bluespec支持加速器功能的RISC-V处理器将Achronix的FPGA转化为可编程SoC 2024年4月——高性能FPGA芯片和嵌入式FPGA&#xff08;eFPGA&#xff09;硅知识产权&#xff08;IP&#xff09;领域的领先企业Achronix半导体公司&#xff0c;以及RISC-V工具和IP领域的行业领导者Blues…

【论文阅读02】一种基于双通道的水下图像增强卷积神经网络

来源&#xff1a;海洋论坛▏一种基于双通道的水下图像增强卷积神经网络 当前不会的 一、背景&#xff1a; 水下图像增强方法包含有无水下成像模型的水下图像增强方法、基于水下成像模型的水下图像恢复方法、水下成像模型与深度学习相结合的方法以及完全采用深度学习的方…

Mybatis常用注解说明

MyBatisPlus 常用注解说明 TableName(opens new window) 描述&#xff1a;表名注解&#xff0c;标识实体类对应的表 使用位置&#xff1a;实体类 TableName("sys_user") public class User {private Long id;private String name;private Integer age;private Strin…