实战项目《负载均衡在线OJ系统》

一、项目灵感来源

在日常做题的过程中,我们总会去力扣和牛客网上去做题,但是从来没有想过网站是如何加载给用户的,以及在提交代码时,是如何得知我们的代码是否正确。基于这样的原因,也是学习到一定程度的知识后,才来模拟实现一下做题网站的判题系统!

二、项目简介

模拟实现判题功能,并完成不同局域网的主机都可以访问我的OJ系统,在后台也要实现负载均衡,当一个用户提交代码时,选择负载最小的服务器来完成判题功能!

三、相关技术

  • C++ STL 标准库
  • cpp-httplib 第三⽅开源⽹络库
  • ctemplate 第三⽅开源前端⽹⻚渲染库
  • jsoncpp 第三⽅开源序列化、反序列化库
  • 负载均衡设计(轮询法)
  • 多进程、多线程
  • Ace前端在线编辑器
  • html/css/js/jquery/ajax

四、开发环境

  • ubuntu 20.04 云服务器
  • vscode

五、设计思路(搭配整体设计图)

  1. 一定存在很多客户端同时来向我们的系统请求资源,包括但不限于:首页资源、题目列表、指定题目内容、提交代码后的编译运行结果等。

  2. 一定不能让一个服务器来完成上面的所有操作,否则压力很大,也无法实现负载均衡。也就必须让编译运行部分和对用户请求资源的响应部分做解藕,实现两种服务器,一种用来识别用户请求的资源,另一种只用来完成编译运行服务。

  3. 最后基于第二点,我们就可以简单地画出整体设计图了!

六、整体设计图

七、模块分析

1. Choice_Server

首先要明确,我们想让Choice_Server完成的功能:

  • browser请求首页,返回首页资源;
  • browser请求题目列表,返回题目列表的网页;
  • browser请求指定题目信息,返回指定题目信息的网页;
  • brower请求提交代码后的编译运行结果,负载均衡式地选择一台Compile_Run_Server来完成编译运行,并接收Compile_Run_Server的运行结果,再返回给browser。

所以我们就必须要让Choice_Server拥有这几点功能:

  • 请求资源的目录,包含首页、题目列表信息、题目指定内容的信息
  • 负载均衡式地选择Compile_Run_Server,发送代码并接收结果,返回给browser

2. Compile_Run_Server

依旧是思考,Compile_Run_Server需要完成的是什么?

  • 编译
  • 运行

所以我们就必须要以这两个功能为主体来设计Compile_Run_Server

八、遇到的问题及解决

把遇到的问题写了一篇博客

关于【setrlimit函数在设置RLIMIT_AS与进程替换】和【重定向与异常信息】的两个问题及解释-CSDN博客

九、项目总体详细流程图

十、总结

在写完这个项目之后,对Linux系统编程和网络编程有了更深的理解,也希望后续自己可以在学完数据库后,把文件更换为数据库,并且可以陆续添加更多的功能!具体更多的详细设计思路在源代码中记录。

相关推荐
We Just Keep growing14 分钟前
【MySQL运维篇】——日志、主从复制、分库分表、读写分离
java·运维·数据库·windows·学习·mysql
会Tk矩阵群控的小木1 小时前
小红书矩阵系统2026最新技术架构与多账号自动化运营实战
运维·矩阵·架构·自动化·个人开发
戴西软件1 小时前
戴西CAxWorks.AICrash:AI+法规驱动的行人保护自动化分析
linux·运维·网络·人工智能·安全·自动化
CingSyuan1 小时前
Linux服务器数据盘初始化与盘符漂移解决方案:标准分区、LVM逻辑卷、XFS格式化、fstab配置与UUID持久化挂载实战
linux·运维·服务器
Dxy12393102161 小时前
DNS负载均衡:看似简单,实则暗藏玄机
运维·负载均衡
珠海西格电力1 小时前
西格电力零碳园区管理系统的技术架构是怎样的?
大数据·运维·人工智能·物联网·架构·能源
MAHATMA玛哈特科技1 小时前
矫平机的液压系统是干什么的?压下精度背后的控制逻辑
运维·服务器·校平机·矫平机·整平机
打码人的日常分享2 小时前
信息化数据安全管理制度办法(Word)
大数据·运维·网络·云计算·制造
电商API_180079052472 小时前
技术分享:如何实现批量自动化获取淘宝商品视频主图API
运维·爬虫·数据挖掘·自动化
TG_yunshuguoji2 小时前
亚马逊云代理商:如何用 CloudWatch+Lambda 打造自动化告警系统
大数据·运维·自动化·云计算·aws