如何快速上手(了解系统的功能)?
admin管理员用户登录,点击右上角管理,仔细阅读管理首页的说明。
切记:题目导入后一次只能删一题,不要导入过多你暂时用不上的题目,正确的方式是每次训练、作业,导入所需的5-10个题目,比赛作业结束后让题目成为训练题库的一部分。这样能保证题库中题号靠前的题目难度依次上升,适合后来的同学自行训练。不要贪图题目数量而忽视其质量。教练自己看不懂解法的题目,少用、慎用。
阅读两个配置文件,逐个研究选项的注释和含义。
/home/judge/etc/judge.conf 所有与判题相关的选项都在这里
/home/judge/src/web/include/db_info.inc.php 所有与Web页有关的选项都在这里
系统中“用户”“比赛”均只有编辑、禁用功能,没有删除功能,这是为了从根源上防止出现“教学事故”。
如何设置默认显示中文界面?
修改db_info.inc.php中的$OJ_LANG=”cn”;
出现502 Bad Gateway,如何处理?
服务器内存过小,超时,考虑增加php-fpm的进程数量。
sed -i ‘s/pm.max_children = 5/pm.max_children = 64/g’ $(find /etc/php -name www.conf)s
有没有Python题库?
没有针对python的题库,题目都是不针对语言的,相同的题面,你用C也好用C++也好,用Java也行。
如何指定输入输出文件?
测试数据目录准备两个文本文件input.name output.name,其内容为题面指定的输入输出文件名,当他们存在时,判题系统会用他们指定的文件名来取代默认的标准输入输出。选手就可以用input.name里面写的文件名来输入数据,用output.name里面写的文件名作为输出目标。
如何快速构造测试数据?
1、在上传测试数据界面有“随机测试数据生成器”可以用元语言方式生成随机输入。构造系列.in结尾的文件。如:test01.in test02.in
2、自己编写一个标注答案,接受符合格式的输入,产生正确输出。放在测试数据目录中,命名为Main.cc
3、 登陆服务器ssh, 将这个程序编译为可执行文件Main,如g++ -o Main Main.cc
4、在测试数据目录下执行 /home/judge/src/install/makeout.sh Main
5、上述脚本将根据test01.in test02.in自动生成test01.out test02.out
如何手工添加题目?
右上角有管理入口,管理界面有说明,问题管理中添加问题。
添加时只能提供一组样例+一组测试数据,但保存后可以在列表最右侧找到测试数据管理入口,允许上传、生成、解压更多测试数据。
如何修改常见问答内容?
1、修改template/皮肤名/faqs.php
2、添加一个新闻,标题命名为faqs.cn则可以替换系统中的中文FAQ,其他语言雷同。
如何修改页面上的XXXX?
cd home/judge/src/
grep -rn "XXXX" *
sudo vim home/judge/src/web/lang/cn.php
就能找到你应该修改的文件,如果数量过多请调整搜索的关键词,缩小范围。
备份
脚本安装的用户,可以使用 install
目录中的 bak.sh
进行备份。
sudo bash /home/judge/src/install/bak.sh
备份后的数据在 /var/backups/
目录下, 命名格式为 hustoj_%Y%m%d.tar.bz2。
迁移
首先在新服务器上做全新安装和测试,没有问题后,再迁移数据。
将你需要迁移的归档复制到目标系统的/home/judge/backup
目录下,执行下面的脚本进行恢复
cd /home/judge/backup | |
sudo bash /home/judge/src/install/restore.sh hustoj_%Y%m%d.tar.bz2 |
脚本的第一个参数为恢复的目标归档,如果没有参数则默认为按名字排序后字典序最大的归档
如何安装使用Moodle
https://zhuanlan.zhihu.com/p/103899072
更新升级
脚本安装的用户,可以使用 install
目录中的 update-hustoj
进行更新升级。
sudo bash /home/judge/src/install/update-hustoj
修复
自己不小心改坏了 web
代码,可以使用 install
目录中的 fixing.sh
进行系统修复。
sudo bash /home/judge/src/install/fixing.sh
管理员如何查看其它用户代码?
右上角进入管理后台,用户管理,用户-权限-添加
给自己加权限sourse_browser权限
然后,查看前台,注销,重新登录。在状态页,点击提交记录中的语言名称查看源代码。
如何限制未登录用户访问?
db_info.inc.php里面有
$OJ_NEED_LOGIN 和 $OJ_REGISTER
static $OJ_REGISTER=true; //允许注册新用户 |
static $OJ_REG_NEED_CONFIRM=false; //新注册用户需要审核 |
static $OJ_NEED_LOGIN=false; //需要登录才能访问 |
不小心删除了admin的权限,如何修复?
sudo su | |
cd /home/judge/src/install | |
echo "insert into jol.privilege values('admin','administrator','true','N');" | ./mysql.sh |
比赛作业里面的时间是什么含义,OI排名跟普通排名有何区别?
时间是指参与人员做出对应题目“花费”的时间:
即:做出题目的时刻 – 比赛开始的时刻 + 惩罚时间
惩罚时间 = 做对之前错误的提交数 * 20分钟。
普通排名按做对的题目数和“花费”的时间进行排名。
OI排名,按得分排名,在开启judge.conf中的OJ_OI_MODE=1后,题目可以按通过的比例进行记分,每题100分。如果希望数据的分值不平均分配,可以使用[权重]作为文件名结尾。如 test01[60].in / test01[60].out 可占60的分数权重,而 test02[20].in/test02[20].out可占20的权重,如果没有其他测试数据,通过后者可以得本题100分中的25分。没有标明权重的数据,默认权重为10。
人多的时候,随机出现"No input file specified"
编辑/etc/php/7.4/fpm/pool.d/www.conf
修改设定 rlimit_files = 1024 为一个更大的值,如65535。修改后重启php-fpm进程(sudo service php7.4-fpm restart
)生效。
判题核心的原理是怎样的?
- 参考一下wiki
- 阅读一下judge_client.cc中的注释。
判题如何触发的?
judged通过UDP监听1536端口,Web端有新的提交或者重判任务时,将发送消息给judged,judged接受到消息,主动去数据库领取任务,fork出docker中的judge_client进行判题。
在SaaS模式中,judge_hub取代judged监听UDP端口,Web发送的消息包含SaaS目录下的子目录名,judge_hub根据SaaS根目录和消息,拼接出judged的主目录,并fork出judged进程去完成判题。judged完成所有数据库任务队列后,主动退出,等待下一次被judge_hub触发。
参考:JudgeHub
如何让学生账号在比赛中也能看到和练习一样的详细错误信息?
- 编辑db_info.inc.php,设置 $OJ_SHOW_DIFF=true;
- 打开文件reinfo.php 在27行和60行有两处详细注释,根据注释进行调整。
如何获得管理员权限?
- 操作系统Ubuntu的管理员权限是通过在安装过程中产生的账号运行sudo su切换到root。
- OJ的管理员是安装完成后,第一个注册的用户用admin作为用户名注册,自动获得管理权限。
权限表里的记录都是什么含义?
以下权限是手动指派:
- “administrator” 管理员,除查看源码外的所有权限。
- “problem_editor”:题目编辑者,添加和编辑题目。
- “source_browser”:查看审核所有提交的源代码,对比可疑的相似代码。
- “contest_creator”:组织创建比赛,编辑比赛。
- “http_judge”:HTTP远程判题账号。
- “password_setter”:重置普通账户密码。
- “printer”:现场赛打印员,注意该账户的school字段用于分配打印任务,如果只有一个打印区则置空。
- “balloon”:气球配送员,注意该账户的school字段用于分配气球任务,如果只有一个气球配送区则置空。
- “vip”:可以参与所有标题含有VIP字样的私有比赛。
- “problem_start”:HTTP远程判题账户的任务起始题号。
- “problem_end”:HTTP远程判题账户的任务结束题号。
新赋予的权限需要重新登陆获得!
以下权限是系统自动生成:
- p+数字:题目的独立编辑权,管理员可以编辑所有题目,problem_editor只能编辑自己添加的题目。
- m+数字: 比赛的独立编辑权,管理员可以编辑所有比赛,contest_creator只能编辑自己添加的比赛。
- c+数字:比赛的参与权,私有比赛只有有权限或者知道密码的用户可以参与。
如何使用题单功能?
在新闻内容中编写,格式为:
[plist=题号列表]题单名[/plist]
也可以在题目列表里,勾选题目后,点击NewProblemList按钮(仅限bs3/syzoj模板使用)。在db_info.inc.php中有选项 $OJ_MENU_NEWS ,设置为true后可以通过勾选新闻的“是否展示到菜单”,在顶层导航中显示该条目。
是否显示到菜
脚本把OJ装在哪里了?可以卸载么?
- 脚本安装默认位置在/home/judge,其中src是全部源码,data是测试数据,etc目录是判题端的配置文件,install目录是各种工具脚本。
- src/web/upload目录存放着所有上传的图片,包括新闻与题目的图片。
- Ubuntu中默认的数据库文件放置在/var/lib/mysql,但是不建议直接备份库文件,而是推荐用install目录中的bak.sh进行备份。
- 如果想卸载,可以参考src/install/uninstall.sh,注意卸载脚本不考虑服务器上可能存在的其他Web系统,请谨慎使用。(复制脚本里面的命令,root权限下粘贴执行)
题目的限时和内存限制的精度是怎样的?
- 题目限时允许设定的字面精度是0.001s,但是由于操作系统内核参数的限定,实测的精度通常为4ms。
- judge.conf中有个OJ_CPU_COMPENSATION来标注当前系统的CPU速度,安装脚本自动根据BogoMIPS的值来设定。
- 当BogoMIPS的值为5000时,这个值为1.000,当CPU的速度更快时,这个值为大于1.000的值。
- 最终系统记录的时间,将按照这个系数进行调整,对于对时间精度要求较高的场合,如正式比赛,或者判题机配置不均衡的情况,可以通过手工调节该参数,让不同的判题机对于相同题目的运行结果趋于一致。
内存限制的精度是1MB,对于本地native的编译型语言c/c++/pascal/freebasic/clang等是考察程序本身的内存申请空间; 对于虚拟机和脚本语言,则包含了虚拟机本身或解释器本身的内存消耗。
测试文件的大小、数量有什么限制?
一般情况下,单个测试文件大小建议不超过10M,测试文件总量10组(.in + .out)。
- 源码中对测试文件大小有个上限 STD_F_LIM = 32M 定义 生效
- /home/judge/etc/judge.conf 中有下面的若干配置可以影响系统设定。
- 在OJ_OI_MODE=1的情况下,题目限时是依赖于OJ_TIME_LIMIT_TO_TOTAL的:
- 当OJ_TIME_LIMIT_TO_TOTAL=1 限时应用于所有数据的总耗时
- 当OJ_TIME_LIMIT_TO_TOTAL=0,限时应用于每组测试文件。
- 状态页status.php(solution表)中记录的时间,取决于OJ_USE_MAX_TIME:
- 当OJ_USE_MAX_TIME=0时,记录的是总耗时。
- 当OJ_USE_MAX_TIME=1时,记录的是最高耗时。 因此,当测试数据组数较多时,推荐设定OJ_USE_MAX_TIME=0,OJ_TIME_LIMIT_TO_TOTAL=1 。
测试文件的文件名命名有什么规则?
- 一般推荐用英文命名,相同文件名的.in .out文件为一组。
- 不支持.ans的扩展名,请在上传前用Windows的命令行统一修改
ren *.ans *.out
。 - 支持在文件名中使用方括号
[]
来标注分数。如test01[20].in / test01[20].out
将视为分数是20分,未标注的文件按10分计分,系统最终根据所有文件的总分和运行得分,记录提交的通过率pass_rate放入solution表,用于前台显示。 - 评测的时候根据所有.in文件的字典序来评测, 因此test10先于test2评测, 后于test02评测。
为什么我的系统卡在编译中
- 如果修改了数据库密码,请注意除了db_info.inc.php需要修改,还需要修改judge.conf中的数据库密码,并需要重启judged进程。
- 如果judge.conf中启用了OJ_USE_DOCKER=1,请确保禁用了OJ_SHM_RUN=0,并检查run0等目录是真实的目录而非软连接。
- 如果如果OJ_USE_DOCKER=0时系统正常,OJ_USE_DOCKER=1时卡住,请检查install目录下的Dockerfile文件内容是否符合需求,并再次运行docker.sh确认运行结果正常。
- 修改OJ_USER_DOCKER参数,需要重启judged生效,方法是sudo pkill -9 judged && sudo judged
正式比赛或大规模系统需要注意哪些问题?
- 正式比赛推荐激活db_info.inc.php中的两个参数。
//static $OJ_EXAM_CONTEST_ID=1000; // 启用考试状态,填写考试比赛ID | |
//static $OJ_ON_SITE_CONTEST_ID=1000; //启用现场赛状态,填写现场赛比赛ID |
NOI CSP CCF 新标准使用C++14,如何在hustoj中更改默认的编译参数。
已经更新默认C++标准为C++14。可以检查,judge.conf 中是否有 OJ_CPP_STD=-std=c++14
即可。
C++ 中的gets函数哪里去了?为何编译报错?
根据 std::gets - cppreference.com , gets函数已经被移除。 可以使用#define gets(S) fgets(S,sizeof(S),stdin)
作为兼容性宏替换。
Python判题好慢好慢,如何加速?
如果你的系统主要为Python服务,可以修改/home/judge/etc/judge.conf
设 OJ_PYTHON_FREE=1
为了增加安全性,请在/home/judge/src/install
目录运行sudo bash docker.sh
,然后修改/home/judge/etc/judge.conf
设定 OJ_USE_DOCKER=1
这样设定后,可以提高Python的判题速度,并提供额外的安全防护。 推荐使用Ubuntu20.04作为基础系统。
是否可以只由管理员来注册账号,自己不能注册
可以,设置db_info.inc.php中的选项,
static $OJ_REGISTER=true; //true允许注册新用户,false禁止注册 | |
static $OJ_REG_NEED_CONFIRM=true; //true新注册用户需要审核,false无需审核直接登陆 |
关闭注册后,管理员可以在后台“比赛队账户生成器”,生成指定数量的账户用于分配。 http://xxxx.xxxxx/admin/team_generate.php
如何显示MathJax语法的公式?
修改db_info.inc.php设置
static $OJ_MATHJAX=true; // 激活mathjax
需要用户能够正常访问互联网,内网用户需要自行部署mathjax内网镜像,并修改template/bs3/problem.php中相关路径。
如何启用查重机制?
修改/home/judge/etc/judge.conf,设置
OJ_SIM_ENABLE=1
修改/home/judge/src/web/include/db_info.inc.php,设置
$OJ_SIM=true;
- 抄袭只对不同账号间生效,自己抄袭自己不计。拥有Source_browser权限的账号可以看到具体数值和对比。
请问如何重启判题机?
sudo pkill -9 judged | |
sudo judged |
XXXXX 这个文件是在哪的
sudo find /home/judge -name "XXXXX"
数据库账号密码是什么,如何登陆mysql?
数据库账号密码存放在两个配置文件中:
/home/judge/etc/judge.conf | |
/home/judge/src/web/include/db_info.inc.php |
新版本中,快速登陆mysql的脚本在install目录里,名字为mysql.sh 使用方法
sudo bash /home/judge/src/install/mysql.sh
也可以安装phpmyadmin:
sudo apt-get -y install phpmyadmin
第一个对话框询问关于Configure database for phpmyadmin with dbconfig-common
用Tab键选到No,回车。
在后续对话框中,不要选择任何一个(apache/lighthttpd都不选),用Tab键选到最下面的OK
安装完成后,执行
sudo ln -s /usr/share/phpmyadmin /home/judge/src/web/pma
然后就可以在OJ的网页端,用http://IP或域名/pma/ 来访问phpmyadmin了
数据库帐号密码,查看前述配置文件。
如何用Windows上的Navicat去连接远程服务器上的mysql?
利用ssh的端口转发机制,把Windows本地的3306端口映射到远程的3306端口上,就可以用前面一个问题中查到的账号密码去连接数据库了。对于Navicat参考使用Navicat进行ssh通道连接MySQL数据库_温暖如春520的博客-CSDN博客
注意常规标签里写的是配置文件里查到的数据库的账号密码,SSH标签里写的是连接SSH用的账号密码。如果你的ssh服务端口不是22,记得要修改成正确的端口。
对于putty,参考下图:
后台导入问题失败
1、先用谷歌浏览器直接打开xml文件,看是否有语法错误,如果有,用文本编辑器修订提示的行号。
2、如果超过100M,可以先用EasyFPSViewer拆分成多个小文件,然后再导入。
3、对于HUSTOJ,可以先压缩为zip再上传导入
4、修改/etc/php/7.2/fpm/php.ini, 提高post_max_size、upload_max_filesize 、memory_limit、max_execution_time 的值。修改后执行sudo service php7.2-fpm restart生效。
电脑配置太高,造了很多数据还是没法卡住暴力怎么办?
修改/home/judge/etc/judge.conf
OJ_CPU_COMPENSATION=1.0
增加这个值可以降低CPU的评测速度,安装脚本根据CPU的bogomips值来初始化。 最高不超过100,设为100可以将原先1ms的测试数据计成100ms。
为什么题目不见了/如何让比赛里的题目也可以在练习里做?
这是由ACM的规则决定的,因为做错有罚时,如果比赛题目在练习中同时可用,则会导致选手可以先在练习中AC,然后再去比赛中提交,从而绕过罚时。另外,比赛题目如果在比赛还没开始的时候,就在练习中出现,则会有漏题的嫌疑,类似某网络原题赛。
当一个题目在作业里被隐藏的时候,如果有老师希望学生可以做这些题目,可以布置自己的作业,将题目加进去,提供给学生做。
一个题目可以同时出现在不同的作业、比赛里。
练习中出现的题目必须满足:
0、已经被管理员设置为可用
1、不在任何未结束的公开作业、比赛中
2、不在任何私有的作业、比赛中
3、题号大于等于1000
- 比赛的题目在比赛添加后,直到结束前,是不能在练习中看到和提交的,否则比赛将泄题或罚时被绕过。
- 私有比赛的题目,在比赛结束后,仍然保留,即使比赛被隐藏也是一样,这是为了防止下一届新生提前获知测试内容。
- 如果希望私有比赛后,题目公开可做,请将比赛切换为公开。
-
其他主机怎么连接到oj?
这取决于买的阿里云还是校园网服务器,或者虚拟机: 阿里云直接用阿里提供的公网ip访问,也可以添加域名解析后用域名访问。 校园网,用学校提供的内网ip或二级域名访问。 虚拟机,百度“【虚拟机的名字如virtualbox或vmware】+端口映射” ,把80端口转进去,然后用物理机的ip地址访问。
关于NOIP赛制
- 设置judge.conf中的OJ_OI_MODE=1 //不在单个数据点WA时停止判题,而是继续判题
- 设置db_info.inc.php中的 $OJ_MARK=”mark”; // 非AC的提交结果显示得分而非错误比率
- 设置db_info.inc.php中的 $OJ_OI_1_SOLUTION_ONLY=true; //比赛是否采用noip中的仅保留最后一次提交的规则。
- 添加比赛时,比赛标题中包含”NOIP”这个关键词 // 赛后才能看结果
- “NOIP”这个敏感词在db_info.inc.php中可以修改
随机的CE编译错误
- 检查OJ_RUNNING的设置与run?目录的对应关系,例如:OJ_RUNNING=2,需要run0 run1两个目录,属主judge,权限700。
- 有的题目CE有的题目AC,适当放宽judge_client.cc中compile函数里的CPU、内存、文件限制。约1234行前后。修改后需在core目录执行sudo bash make.sh
如何让判题程序忽略行尾的空白字符
在judge_client.cc头部增加宏定义 IGNORE_ESOL 或者修改 Makefile 增加 -DIGNORE_ESOL 参数。
配置文件里的字段什么含义?
点击Configuration
多组数据怎么上传?
加好题目后在题目列表找TestData,点击上传。 主文件名一样的*.in *.out,如test1.in test1.out
为何页面总是需要刷新才能显示?
如果您使用的是ie6浏览器,请禁用服务器上的deflate模块,在ubuntu下的命令是
sudo rm /etc/apache2/mods-enabled/deflate.* sudo /etc/init.d/apache2 restart
为什么我提交的答案始终在pending?
判题程序judged需要用root帐号启动,请重启服务器或手动执行sudo judged。如果无效,请检查/home/judge/etc/judge.conf中的数据库账号配置,参考[Configuration],修正后再次重启服务器或执行sudo pkill -9 judged等待一会儿再执行sudo judged
为什么添加题目时出现warning,题目目录下数据没有自动生成?
您需要修改测试数据目录,给予php-fpm操作数据目录的权限。Ubuntu下php-fpm运行的用户身份是www-data
chgrp www-data -R /home/judge/data | |
chmod g+rw -R /home/judge/data | |
为什么我添加的题目普通用户看不到?
题目默认为删除状态,只有管理员能访问,当管理员确认题目没有问题后,可以点击ProblemList中红色的Reserved,切换为绿色的Available启用题目。
为何我的C/C++都能用,唯独Java总是CE/RE?
目前只支持sun原版jdk和openjdk,其他jdk暂不能保证支持。如果你用的是64位系统,你可能需要自己调整一下源代码。请联系我。
我是管理员,为什么不能查看别人的源码?
请给自己增加source_browser权限。issue1
如何进入后台?
以管理员身份登录,点击Admin/管理进入后台。
如何添加题目?
进入后台,点击左侧NewProblem。
如何添加测试数据?
添加题目时,可以在test input/test output添加一组测试数据,大规模的数据(10kb+)和更多的数据,可以在添加完题目后,通过ftp/sftp,上传到题目对应目录,通常是 /home/judge/data/题号。命名规则是输入数据以.in结尾,输出数据以.out结尾,主文件名相同。
如何编辑题目?
后台中点击ProblemList,找到需要编辑的题目,点击Edit。编辑时不能修改测试数据,测试数据请使用ftp工具修改。
如何启用题目?
题目添加后,默认是停用状态,以防比赛提前漏题,后台中点击ProblemList,找到题目,点击Reserved 切换为Available启用题目,或者组织比赛,比赛中的题目将自动启用。
如何组织比赛?
在题目列表ProblemList中选择使用的题目,在PID一栏打钩,点击CheckToNewContest按钮,进入到比赛添加页面,输入比赛名称,设定比赛时间,语言类型,访问权限提交即可。 | |
也可以使用管理菜单中的NewContest,需要手动输入题目编号,用英文逗号分隔。 |
如何修改、删除比赛?
点击比赛列表ContestList,选择Edit或Delete。
如何修改公告信息?
点击SetMessage。修改无效请检查admin/msg.txt是否对php账号(www-data)可写
如何修改用户密码?
点击ChangPassWD
如何重新判题?
点击Rejudge,输入题号或运行编号。
如何增加用户权限?
Addprivilege/添加权限, administrator为管理员,source_browser为代码审查,contest_creator为比赛组织者。 通常给使用系统的老师分配代码审查和比赛组织者权限即可。
如何导入、导出题目?
使用ImportProblem,上传FPS文件。 | |
使用ExportProblem,输入起始编号,结束编号,或题号列表,如果输入了列表,起始结束将不起作用。 |
如何更新数据库结构?
系统升级中,有对数据库的修改,这些修改不能通过SVN实现自动更新,如果发现升级web/core代码后系统报错,可以执行update database操作,进行数据库升级。因为脚本中有测试代码,所以重复执行不会造成影响。
部署在Centos7系统中无法正常评测,如何解决?
由于hoj使用的判题机中的安全沙盒使用环境的特殊性,如果想在centos7系统中正常运行hoj-judgeserver服务,需要开启 user 命名空间来使用。
echo user.max_user_namespaces=10000 >> /etc/sysctl.d/98-userns.conf
docker restart hoj-judgeserver
重新启动hoj-judgeserver的docker容器即可正常评测。