系统架构图_基于,LAMP,架构的,ACMICPC在线评测系统设计

系统架构图_基于,LAMP,架构的,ACMICPC在线评测系统设计,第1张

摘 要 本课题在牡丹江师范学院已有的在线评测系统上进行全面重构,将 OJ 系统各个组成部分进行解耦,使得 OJ 系统各个模块之间独立性增强,容易修改现有功能及扩充新功能,以应对举办比赛时的访问压力。包括本课题的系统架构设计,对其下各个模块核心内容的阐述,包括基于 Linux 系统的沙箱模型、基于 Java 的多线程服务器、基于AMP 架构和 MVC 设计模式的 Web 前端系统的设计与实现,以及影响系统安全的各种因素和对应的解决方案。
关键词 在线评测系统 ACM/ICPC LAMP 架构
中图分类号:TP31152 文献标识码:A
0 绪论
ACM/ICPC 目的旨在使大学生运用计算机来充分展示自己分析问题和解决问题的能力。在线评测系统(Online Judge System,以下简称 OJ)起到了非常重要的作用。集训队员可以在线评测系统上挑选各种题目挑战自我,提高自我,学习各种数据结构和算法;在统一组织的集中训练中可以通过指定题目的形式来强化训练效果;而在线评测系统对比赛功能的支持,进一步提高了集训队员的学习热情,同时还可以模拟比赛的环境,培养那些计划参与 ACM/ICPC 赛事的队伍的团结合作能力。
但是其中大部分OJ 系统是闭源、封闭的,无法获取其源代码进行修改扩充以满足现有需求,牡丹江师范学院 ACM/ICPC 集训队才于 2010 年推出自己的OJ。但是该系统存在几个问题:一,效率不足,无法承受每年牡丹江师范学院程序设计大赛预选赛的压力;二,由于该系统没有应用沙箱技术运行用户代码,存在安全隐患,可能直接导致服务器被劫持。此后,Google Code 上陆续出现了几个开源 OJ 系统,但是在架构设计上仍不够完善,且无法与原系统的数据格式兼容,因此,有必要重新开发一个经过合理设计的新 OJ 系统,从根本上解决上述的问题,为集训队提供一个稳定可用的学习环境。
1 系统架构设计
为了方便用户的使用,本系统采用 B/S 架构,只要用户使用的是有网络接入的计算机,就可以通过浏览器进行访问。根据该系统的具体情况,在设计上将其分为以下四个组成部分:(1)网站系统(Web 端);(2)评测核心(Judge);(3)评测核心封装层(Judge Wrapper);监听守护进程(Daemon)。
在设计上,该项目将系统的几个主要组成模块充分解耦,一方面,多个模块之间可以并行开发;另一方面,各个模块解耦后使得系统的修改和扩充更加容易,每个模块的可重用性也相应增强。例如,当其他学校需要实现一个功能界面完全不同的 OJ 系统或是作业平台时,可以直接采用本项目的评测核心,避免重复开发。
2 评测核心的设计与实现
作为在线评测系统中最核心的部分,尤其是需要监控用户运行,需要涉及到很多相关技术,特别是与系统底层关系密切的技术。在 Linux 下,系统调用的实现通常是用户程序通过触发80号软中断或者执行 SYSCALL/SYSENTER 等平台相关的 CPU 指令陷入到内核中,内核通过寄存器获 取用户程序的输入,在通过严格的检查后执行相应 *** 作。
在本系统中涉及的主要系统调用包括 fork、setitimer、execve、wait、ptrace、setrlimit、chroot、setuid 等。
(1)fork 系统调用通过复制调用进程的上下文来创建一个新进程。(2)setitimer 系统调用用于设置定时器。(3)execve 系统调用用于载入一个新的可执行程序,替换当前进程的地址空间。(4)wait 系统调用允许父进程阻塞,直到子进程发生一些事件。(5)ptrace 系统调用是一个可以使父进程在用户层拦截和修改系统调用的函数,可以监控和控制其他进程,该函数还能够改变子进程中的寄存器和内核映像,因而可以实现断点调试和系统调用的跟踪。(6)setrlimit 系统调用可以改变进程的资源限制。(7)chroot 系统调用使得调用进程的将某一目录当作其根目录,以此限制该进程及子进程对该目录外文件的访问。(8)setuid 系统调用允许进程改变其有效用户 ID。在本系统中,用户提交的代码可能存在恶意,对其编译后的程序需要运行在服务器上,因此必须对其进行严密的监控,防止恶意代码带来的危害。在本系统支持的四种语言中,C、C++、Pascal 三者经过编译后产生本地代码,可以通过Linux 系统调用(主要是 fork、execve、chroot、setuid 和 ptrace)来创建一个沙箱,限制恶意代码访问文件、控制系统的权限,尤其是通过 ptrace 来限制可使用的系统调用,在很大程度上保证了系统的安全。
运行时检测是最重要、最复杂的运行时监控机制。本系统中通过 ptrace 系统调用来监控用户进程。每当用户进程出发一个系统调用,或者是收到某些信号的时候,用户进程会将控制权暂时移交给监控核心。监控核心将严格监控用户进程的各项参数,以保证其不执行危害系统安全的 *** 作:(1)检查程序是否正常退出。(2)检查程序是否收到了非正常的信号。(3)通过进程的缺页中断次数计算进程使用的内存资源是否超出限制。(4)检查进程系统调用是否合法。
在以上四项检测都不存在问题的情况下,用户进程才能继续执行。
由于题目根据其合法结果数量可以分成普通类型和 Special Judge 类型,因此针对不同的类型,需要分别对其进行判断。(1)普通类型的题目,其合法结果唯一,因此只需要简单判断用户程序与标准答案的一致性即可。(2)Special Judge 类型的题目,在本系统中,约定了 SPJ 程序的名称以及数据的传递方式,包括标准输出、用户输出,以及 SPJ 程序的数据,由评测核心调用 SPJ 程序来完成最后的评判过程。
3 评测核心层的设计与实现
每当用户提交一份新的代码,Wrapper 即会被调用,从数据库中获取代码的详细信息。在此阶段需要关注的信息主要包括:(1)用户提交的代码本身及其关键属性(如语言类型)。(2)此代码的提交用户类型,是普通用户还是管理员。(3)此代码所属的题目是否处于正在进行的比赛。(4)此代码是否已经被评测过。

负载均衡,三台就足够了,四台绰绰有余,不但可以实现负载均衡,还可以实现主从。
具体来说四台服务器,要进行合理分配。可以这样做。首先你对四台机器性能进行排序,从高到底为A/B/C/D。
拿性能最差的一台服务器D做负载均衡,安装haproxy软件。

是可以实现的!WEB服务器相对于来说要求比较简单,MAIL服务器可以用WEBMAIL来控制,DNS 和DHCP相对于来说比较难点,建议选用稳定性好的主机或者专用服务器,安装WIN2003SERVER企业高级服务器版本,进行配置 访问速度还不错,我目前就是这样做的!最主要的一点是在配置WEB服务器的时候,对PHP的支持最好不要用IIS,那样效果不是很好,AP的支持的要好点,如果是一台服务器的话,对端口设置做好就可以了!


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zz/12878247.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-28
下一篇 2023-05-28

发表评论

登录后才能评论

评论列表(0条)

保存