Skip to content

XOJ 在线判题系统-项目入口,一个编程题目评测系统,能够根据管理员预设的题目用例对用户提交的代码进行执行和评测。

License

Notifications You must be signed in to change notification settings

xiaoxiongmao5/xoj

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

27 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

xoj(在线判题系统)

在线访问

项目介绍

一个编程题目评测系统。能够根据管理员预设的题目用例对用户提交的代码进行执行和评测。

  • 在系统前端,管理员可以创建、管理题目;用户可以自由搜索题目、阅读题目、编写并提交代码。
  • 在系统后端,根据管理员设定的题目测试用例在代码沙箱中对代码进行编译、运行、判断输出是否正确。(其中,代码沙箱可以作为独立服务,提供给其他开发者使用)。

项目架构设计

该项目由前端 + 后端组成,在后端系统中,根据功能职责,将系统划分为三个关键模块:

  • 核心业务后端、校验结果的判题服务、负责编译执行代码的可复用代码沙箱。
  • 各模块相互独立,通过 Dubbo-go + Nacos RPC远程调用 技术实现高效协作。
  1. 后端服务 xoj-backend : 负责核心业务,数据库处理
  2. 判题服务 xoj-judge-service : 负责校验结果的
  3. 代码沙箱 xoj-code-sandbox : 负责编译执行代码的
  4. 前端服务 xoj-frontend : 负责提供用户操作界面

项目展示

题库 && 做题界面

image image image

浏览题目提交 && 提交代码详情界面

image image

题目管理界面

image image

用户管理界面

image image

做题流程的时序图

image

技术栈

后端技术栈

  • 主语言:Golang
  • 框架:Beego
  • 数据库:MySQL8.0、Redis
  • 注册中心:Nacos
  • 接口文档生成:swagger
  • 代码沙箱:Docker
  • 容器化部署:Dockerfile、Docker Compose

前端技术栈

  • 开发框架:Vue3、Vuex 状态管理
  • 脚手架:Vue-CLI
  • 组件库:Arco Design
  • 前端工程化:ESLint + Prettier + TypeScript
  • 接口代码生成:OpenAPI
  • Markdown 富文本编辑器
  • Monaco Editor 代码编辑器
  • 前端项目模版(通用布局、权限管理、状态管理、菜单生成)

快速上手

  1. 单独部署【代码沙箱】服务:部署文档

  2. 单独部署 nacos 服务

    cd docker-nacos
    docker compose up -d

    启动成功后,可以看到如下界面: image

    可以去 nacos 注册中心看一下,访问 http://部署服务器的IP地址:8848/nacos/index.html 默认用户名和密码都是 nacos

    补充:若报错 ! nacos Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. 原因:这个错误与Linux系统的swap分区配额限制有关。Nacos是一个服务发现和配置管理平台,它依赖于Linux的cgroup功能来管理资源和限制。 解决:

    # 编辑 GRUB 配置文件
    sudo vim /etc/default/grub
    
    # 在 GRUB_CMDLINE_LINUX_DEFAULT 行中添加 cgroup_enable=memory swapaccount=1
    GRUB_CMDLINE_LINUX_DEFAULT="quiet splash cgroup_enable=memory swapaccount=1"
    
    # 保存并退出编辑器
    # 更新 GRUB 配置
    sudo update-grub
    
    # 重启系统
    sudo reboot
  3. 部署本项目

    1. 克隆该项目到本地

      git clone https://github.com/xiaoxiongmao5/xoj.git
    2. 修改配置

      vim docker-xoj/docker-compose.yml

      修改 xoj-judge-service.extra_hosts,将 xoj-code-sandbox.com 域名解析的IP修改为你部署的服务器的IP

      vim docker-xoj/docker-xoj-backend/conf/dubbogo.yaml
      vim docker-xoj/docker-xoj-judge-service/conf/dubbogo.yaml

      修改以上两个文件的 dubbo.registries.nacos.address,将 address 修改为你部署的服务器的IP和端口号

    3. 启动本项目

      docker compose up -d

已完成的项目扩展 ⭐⭐

前端

  1. 题库、浏览题目提交界面:对表格字段的标签、判题结果、内存、耗时、执行状态、题目列做更美观的展示:标签化、区分颜色显示
    • 点击题目列可跳转到做题界面
    • 修改通过率字段显式值:仅保留两位小数
    • 当执行状态为判题中时,判题结果显示为loading
  2. 浏览题目提交页面:
    • 添加定时器自动刷新界面,保证获取到题目提交的最新状态
    • 增加查看代码的功能按钮,如果当前用户是题目提交者或者是管理员,就显式该按钮,点击后可以查看提交的代码和具体判题结果
  3. 添加查看已提交题目详情界面,并显示代码编译执行异常时的详细输出内容,并且添加可继续做题的提交按钮
  4. 做题成功后自动跳转到做浏览题目提交界面
  5. 做题界面和查看已提交题目详情界面:
    • 添加根据编程语言区分的tag子标签页,来显式答案信息
    • 添加答案模版默认填充到代码编辑器中,切换语言后自动更新对应的答案模版
  6. 管理题目和创建题目界面:添加答案模版的文本编辑框
  7. 优化代码编辑组件 CodeEditor:允许从外部动态更新代码编辑器的内容;并在监听语言变动的时候,动态更新代码编辑器的内容
  8. 添加用户管理界面、注册账号界面和退出登录功能

后端

  1. 增加题目的通过数、提交数统计,计算通过率
  2. 限制单个用户的提交频率,通过IP限流实现
  3. 使用事务确保题目提交的完整性:添加题目到题目提交表、更新题目提交数+1、将提交题目ID放入消息队列
  4. 添加功能API:获取提交题目的封装信息(仅当前用户是题目提交者或者是管理员才返回提交代码,否则返回空代码)
  5. JudgeInfo结构体添加 Detail 字段,用于存储题目编译或运行时的具体报错信息
  6. 添加使用交叉编译方式,解决在 Mac 下编译出 Linux 的 golang 执行文件
  7. 题目表结构添加 AnswerTemplate 题目答案模版字段
  8. 构建容器化部署方案,使用Docker、Docker Compose实现一键部署,提升应用部署效率

项目过程中的文章产出 📚

欢迎贡献

项目需要大家的支持,期待更多小伙伴的贡献,你可以:

  • 对于项目中的Bug和优化建议,可以提issues,我会积极响应。

About

XOJ 在线判题系统-项目入口,一个编程题目评测系统,能够根据管理员预设的题目用例对用户提交的代码进行执行和评测。

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published