2020年粤澳计算机程序设计大赛网络赛总结(转自我的知乎回答)

https://www.zhihu.com/question/390424213/answer/1179758442

今天是WeJudge3.0项目2018年立项开发以来,举办过的最大型比赛了!

本次网赛迎来了广东省各大高校的诸多高手同台竞技,充分展示了各位选手的实力。早上8时开始,不到10分钟,就有6题被拿了一血,不到3小时,排行榜首过15题了!(吐槽一下出题人,怎么出的这么简单;-)截止至晚上8时整,共1196名同学至少过题一道,有19道题被拿一血(总共20题,其中E题无人过题),排行榜上第一名是来自华南理工大学的郑炜城同学,恭喜!

凡事没有一帆风顺,作为WeBug系统(不是),此前花了大量时间在服务端优化上,结果比赛开始的时候,服务端看上去还挺顺的哦。于是顺手点了一下排行榜…嗯?我浏览器怎么卡爆了?经过一个多小时的排查,最终问题定位在了react-virtualized组件的CellMeasurerCache上,因为没有设置fixWidth属性,导致在渲染大量Cell的时候,每个Cell都去渲染并计算了Width,2300 * 20 == BOOM,紧急修复后恢复正常。

考虑到是2000多人的比赛,我们手上也就只有一台双路E5 2603 v2,学校借给我们一台单路E5-1620 v4作为主服务器,以及三台E5 2603 v2的单路服务器作为判题机服务器。根据百度统计的数据估算,短时间内大概在800 – 900 PV的时候我们服务器的承受量达到了峰值,接口访问出现也拥塞的情况。但总体来说,除了比赛结束那一瞬间可能有大批人访问排行榜,导致服务器压力过大,接口拥塞2-3分钟左右以外,整个比赛期间没有出现大面积崩溃、拥塞的情况,我悬着的一颗心终于放了下来,长舒了一口气。

再来看看咱们的各个数据库服务的工作情况。咱们的系统在设计上采用了MySQL作为主数据库、Redis和MongoDB作为副数据库和缓存服务,RabbitMQ作为队列数据库,虽然设计上支持分布式部署,奈何我们没有那么多服务器_(:з」∠)_于是主服务器基本上都是用来承担这个他们的工作了。

这次最佳凉快奖颁给了我们的MariaDB同学(也就是MySQL的好兄弟),平均不到20%的CPU占用率,您搁这儿树下泡茶喝咖啡呐?

劳动光荣奖,颁给Redis和MongoDB同学吧。账号数据、题目数据、排行榜的数据计算和缓存是Redis同学负责输出的,MongoDB同学则负责储存判题任务、判题结果和日志、题目配置信息等。

最惨996加班奖,就颁给我们最惨的RabbitMQ同学吧!从头到尾忙不停,内存都不够用了。判题队列、判题结果处理和查重队列,都是他在负责处理,可谓是“多人运动”…咳咳…鞠躬尽瘁!下次一定给你安排上16G内存,别再告警了求你了_(:з」∠)_

接下来是判题机。之前我们拿java压测了一波,python也压测了一波,也就是想看看这些高负载的评测对整个队列有啥影响。结果实际情况,确实没有压测时设想的那么恐怖。通过压力测试,也成功的怼出了判题机的一些问题,比如WA、PE没判对,以及测试文件太大的时候判题机出现访问文件失败的问题,这才使得我们在比赛前能够尽可能解决存在的问题。感觉下图判题机的CPU都没完全吃满,绰绰有余咯~(吃满你们就全TLE了哈哈)

再来看看比赛一个月来的访问量统计,PV达到了100W+!今日UV达到3000+!

Wow! Awesome! 这是OJ独享的moment…. 😉

可能对于那些商业OJ来说,这不算什么,但是对于我们来说,这是一次前所未有的经历。感谢主办方对我们的信任,也感谢北京师范大学珠海分校信息技术学院的领导、老师对我们整个系统的人力、物力、财力上的大力支持,感谢来自五湖四海的参赛者同学们对我们的理解和支持!

最后,来感谢一下为WeJudge作出贡献的大家!

从2015年立项以来,WeJudge前前后后更新了三个大版本。当初做这个是为了给同学们提供一个教学用的评测平台,所以,在肖红玉老师(咱们团队的指导老师)的帮助下,从2015年9月就开始使用到她的C语言课程中,逐步推广到整个学院在使用,也因此积累下来很多质量较高的题目,因此,也很感谢肖老师和信院的各位老师、我的同学 Wolf Zheng (@草原狼)、 @QuanQqqqq 和Tosh Qiu等大佬,以及北师珠ACM协协会各届的大佬,为OJ提供了许多优秀的题目资源和测试数据。

然后是咱们团队~在初期我单枪匹马独干了2年多的时间里,系统存在一些自身的不足和偏见,3.0版本以前的WeJudge在现在看来是一个大作业水平的作品。在经历了一个很棒的科技公司实习后(很感谢那位老板给我的实习机会~),让我清楚的意识到,如果我想把它做好,就需要重头开始。在即将毕业的那一年,我很幸运遇到了两位大佬121和ztr( @三好少年R某 ),在我们共同的努力下,把3.0系统做出来了。我负责架构多一些,业务代码大多数是他们在整,大家都是在同一个起跑线上成长,也见证了整个系统从0到1的过程。很感谢你们两年多来为WeJudge的付出!无论WeJudge的未来如何,我相信它带给你们的都是技术上成长和收获!

再然后,是关于这次比赛的。比赛筹备大概是3月份开始的,一开始接到的是说比赛我们来搞,报名也我们来搞,不仅要支付,还要小程序(??)。于是乎我们在两个星期左右的时间里,内把支付接好了,并把小程序搞了出来。期间感谢ztr大佬搭建微信小程序的项目(我一窍不通哈哈哈),以及我们可爱的xj小姐姐在开发上的帮助~考虑到比赛需要消耗较大的服务器资源,申请到的备用服务器需要做相应的配置才有用。由于疫情期间,学校没开学,我本人也毕业两年了不在学校,所以只好请实验室管理员郑义老师帮忙新服务器的安装操作系统工作,以及原有主机的内存扩容、故障硬盘更换等。郑老师辛苦啦,周末都还在帮我们装系统啥的,我有点儿过意不去,总之非常感谢啦!

最后最后,当然要感谢我们的大老板小红鱼老师了!肖老师从15年立项到现在一直在支持这个项目,幕后的运营、推广都是她在负责搞。可以说,如果没有她帮忙,OJ也许就真是一个大作业玩具了,基本上是没人会用的。这次比赛的顺利进行,相信是对她辛劳和努力的一个最好的回礼!

老板的鸡腿已加,请查收

大家见证了WeJudge的成长,WeJudge也见证了你们的成就和荣耀!

衷心感谢大家,我们明年再见!哦不,别急,这才网络资格赛呢,还有现场赛呢!到时会有更好玩的功能出现在现场哦,也许还会在B站有直播?

不骄不躁,脚踏实地,继续前行!

一些私货

WeJudge官方网站:https://oj.bnuz.edu.cn
判题机核心模块开源:https://github.com/LanceLRQ/deer-executor
WeJudge团队:https://github.com/wejudge