Linux C++项目推荐:文件服务器+如何快速上手C++大项目

1 本次分享的意义

源码地址:https://github.com/shangguanyongshi/WebFileServer.git

视频讲解:Linux C++项目推荐:WebFileServer文件服务器+如何快速上手C++大项目

学完C++和Linux编程后, 可以以WebFileServer文件服务器作为练手项目,比WebServer项目多了文件上传的功能,更加有意义。

这次分享不单只是讲解这个WebFileServer项目如何运行,也能让大家掌握如何快速掌握自己不熟悉的C++项目。

2 项目功能

Web 文件服务器,通过浏览器发送 HTTP 请求管理服务器指定文件夹下的所有文件。主要功能包括:

  • 以 HTML 页面形式返回该文件夹下的所有文件
  • 可以选择本地文件上传到服务器
  • 可以对列表中的文件文件执行下载操作
  • 可以删除服务器中的指定文件

3 整体框架

  • 使用 Reactor 事件处理模型,通过统一事件源,主线程使用 epoll 监听所有的事件,工作线程负责执行事件的逻辑处理
  • 预先创建线程池,当有事件发生时,加入线程池的工作队列中,使用随机选择算法选择线程池中的一个线程处理工作队列的事件
  • 使用 HTTP GET 方法获取文件列表,发起下载文件、删除文件的请求。使用 POST 方法向服务器上传文件
  • 服务端使用有限状态机对请求消息进行解析,根据解析结果执行操作后,向客户端发送页面、发送文件或发送重定向报文
  • 服务端使用 sendfile 函数实现零拷贝数据发送

4 编译和运行

  1. build 项目
sh ./build.sh

默认的编译不支持调试,可以修改makefile增加-g编译选项。

然后再重新编译,以方便调试代码。

  1. 启动文件服务器
./main
  1. 在浏览器端输入 服务端ip:端口号(端口号默认是8888)
serverip:8888

5 如何快速分析代码

5.1 main函数入口

(gdb) b main
Breakpoint 1 at 0x5555555590ad: file main.cpp, line 3.

5.2 分析网络模型

通过info threads可以看到 共有五个线程,其中主线程是调用了epoll,再加上README的讲解可以推断出来这个项目是单个epoll +线程池的模式

* 1    Thread 0x7ffff79a9740 (LWP 339328) "main" 0x00007ffff7c1c68e in epoll_wait (epfd=4, events=0x7fffffffaf14, maxevents=1024, timeout=-1) at ../sysdeps/unix/sysv/linux/epoll_wait.c:30
  2    Thread 0x7ffff79a8700 (LWP 339343) "main" futex_abstimed_wait_cancelable ( ) at ../sysdeps/nptl/futex-internal.h:320
  3    Thread 0x7ffff71a7700 (LWP 339344) "main" futex_abstimed_wait_cancelable ( ) at ../sysdeps/nptl/futex-internal.h:320
  4    Thread 0x7ffff69a6700 (LWP 339345) "main" futex_abstimed_wait_cancelable ( ) at ../sysdeps/nptl/futex-internal.h:320
  5    Thread 0x7ffff61a5700 (LWP 339346) "main" futex_abstimed_wait_cancelable ( ) at ../sysdeps/nptl/futex-internal.h:320

5.3 网络数据收发

5.3.1 数据接收

断点 recv

Thread 4 "main" hit Breakpoint 4, __libc_recv (fd=5, buf=0x7ffff69a5600, len=2048, flags=0) at ../sysdeps/unix/sysv/linux/recv.c:24
24      ../sysdeps/unix/sysv/linux/recv.c: No such file or directory.
(gdb) bt
#0  __libc_recv (fd=5, buf=0x7ffff69a5600, len=2048, flags=0) at ../sysdeps/unix/sysv/linux/recv.c:24
#1  0x000055555555df4a in HandleRecv::process (this=0x55555558bb90) at event/myevent.cpp:38
#2  0x000055555555c114 in ThreadPool::run (this=0x55555558b2b0) at threadpool/threadpool.cpp:114
#3  0x000055555555bc5c in ThreadPool::worker (arg=0x55555558b2b0) at threadpool/threadpool.cpp:77
#4  0x00007ffff7f8a609 in start_thread (arg=<optimized out>) at pthread_create.c:477
#5  0x00007ffff7c1c353 in clone () at ../sysdeps/unix/sysv/linux/x86_64/clone.S:95

很明显,这个项目是在线程池的线程里读取socket 数据并解析解析处理。

5.3.2 数据发送

断点 send

说明数据的响应也是在线程池的线程进行的。

6 拓展建议

建议将本项目的功能一直到muduo库进一步测试,对比分析性能的差异。

也建议和nginx做更多测试对比。

这样可以不断优化项目的性能,面试的时候也能有更多可以讲解的内容。

#我的失利项目复盘##校招过来人的经验分享##校招##简历中的项目经历要怎么写##c++#
全部评论
mark一下项目地址
点赞 回复 分享
发布于 2025-05-06 08:45 广东

相关推荐

01-12 20:29
莆田学院 Java
我的解压方式,是进行一场有仪式感的“数字隔离”与“物理重启”。当压力达到临界点,我会立刻合上电脑,并非休息,而是将办公地点从工位移至公司楼下最近的便利店或咖啡馆。用一个完全陌生的环境作为“上下文切换”的强制信号,点一份简单的食物,不思考,只专注于感受味道和观察周遭流动的生活。这短短的半小时,像一次有效的系统缓存清理,让我能稍后以更清醒的状态重新加载任务。其次,我会启动一项低门槛、高即时反馈的体力活动。对我而言,不是去健身房完成一套复杂计划,而是立刻换上跑鞋,下楼进行一段三到五公里的慢跑。重点不在于锻炼效果,而在于让身体节奏取代大脑的纷乱思绪,让风声和脚步声覆盖内心的嘈杂。跑步时,我有时会刻意在脑海中反复“运行”一个最简单的程序逻辑,比如默写一个排序算法,这种机械的思维练习能奇妙地带来一种掌控感,对冲工作上的失控压力。最后,也是最重要的,是进行一次非功利性的“技术沉浸”。我会找一个与工作项目完全无关,但能引发纯粹兴趣的技术小课题。例如,写一段代码控制智能家居的灯光变幻,或是研究一个有趣的开源小工具的源码。这个过程没有交付压力,只有探索和玩耍的乐趣。它像一次精神上的“沙盘游戏”,提醒我最初对技术产生热情的那个单纯原点——解决问题和创造带来的快乐本身,就是对抗职业倦怠与压力的终极解药。
工作压力大,你会干什么?
点赞 评论 收藏
分享
评论
点赞
8
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务