(二)OJ的主要文件

2018-06-22 04:58:28来源:未知 阅读 ()

新老客户大回馈,云服务器低至5折

OJ搭建好了后,我们要熟悉一下OJ项目下的文件及文件夹。

首先,安装好的OJ是在目录var/www/html下。

html下的php文件

  这些php文件都是些主要跳转页面。

admin文件夹

  登录管理员账号后管理的管理界面

bootstrap文件夹

  css样式和图片,如果要修改某些页面的小地方请到www\html\bootstrap\css\bootstrap里面去找到对应的css修改即可。如果要大方面的修改,建议还是自己写个css文件要好。

include文件夹

  公共的配置文件所在文件夹(学过php的应该都会知道的吧- -);

  这里主要是有一个web使用的配置文件db_info.inc.php

  主要内容如下:

static $DB_HOST="localhost"; 数据库的服务器地址
static $DB_NAME="jol"; 数据库名
static $DB_USER="root"; 数据库用户名
static $DB_PASS="root"; 数据库密码
// connect db 
static $OJ_NAME="HUSTOJ"; OJ的名字,将取代页面标题等位置HUSTOJ字样。
static $OJ_HOME="./"; OJ的首页地址
static $OJ_ADMIN="root@localhost"; 管理员email
static $OJ_DATA="/home/judge/data"; 测试数据所在目录,实际位置。
static $OJ_BBS="discuss";//"bbs" 论坛的形式,discuss为自带的简单论坛,bbs为外挂论坛,参考bbs.php代码。
static $OJ_ONLINE=false; 是否使用在线监控,需要消耗一定的内存和计算,因此如果并发大建议关闭
static $OJ_LANG="cn"; 默认的语言,中文为cn
static $OJ_SIM=true; 是否显示相似度检测的结果。
static $OJ_DICT=false; 是否启用在线英字典
static $OJ_LANGMASK=1008; //1mC 2mCPP 4mPascal 8mJava 16mRuby 32mBash 1008 for security reason to mask all other language 用掩码表示的OJ接受的提交语言,可以被比赛设定覆盖。
static $OJ_EDITE_AREA=true;// 是否启用高亮语法显示的提交界面,可以在线编程,无须IDE。
static $OJ_AUTO_SHARE=false;//true: 自动分享代码,启用的话,做出一道题就可以在该题的Status中看其他人的答案。
static $OJ_CSS="hoj.css"; 默认的css,可以选择dark.css和gcode.css,具有有限的界面制定效果。
static $OJ_SAE=false; //是否是在新浪的云平台运行web部分
static $OJ_VCODE=true; 是否启用图形登录、注册验证码。
static $OJ_APPENDCODE=false; 是否启用自动添加代码,启用的话,提交时会参考$OJ_DATA对应目录里是否有append.c一类的文件,有的话会把其中代码附加到对应语言的答案之后,巧妙使用可以指定main函数而要求学生编写main部分调用的函数。
static $OJ_MEMCACHE=false;是否使用memcache作为页面缓存,如果不启用则用/cache目录
static $OJ_MEMSERVER="127.0.0.1"; memcached的服务器地址
static $OJ_MEMPORT=11211; memcached的端口
static $OJ_RANK_LOCK_PERCENT=0; //比赛封榜时间的比率,如5小时比赛设为0.2则最后1小时封榜。
static $OJ_SHOW_DIFF=false; //显示WrongAnswer时的对比
复制代码

 lang文件夹

  语言设置文件夹

template文件夹

  OJ主题文件夹,里面的一个文件夹对应的一个不同的风格主题。默认使用的是bs主题。

这里另外要提一下的就是hustoj还有一个core的配置文件judge.conf,默认位置/home/judge/etc

注意core没有识别引号和注释的能力,所以不要自行增加任何引号或注释,否则可能影响judged启动

OJ_HOST_NAME=127.0.0.1 如果用mysql连接读取数据库,数据库的主机地址
OJ_USER_NAME=root 数据库帐号
OJ_PASSWORD=root 数据库密码
OJ_DB_NAME=jol 数据库名称
OJ_PORT_NUMBER=3306 数据库端口
OJ_RUNNING=4 judged会启动judge_client判题,这里规定最多同时运行几个judge_client
OJ_SLEEP_TIME=5 judged通过轮询数据库发现新任务,轮询间隔的休息时间,单位秒
OJ_TOTAL=1 老式并发处理中总的judged数量
OJ_MOD=0 老式并发处理中,本judged负责处理solution_id按照TOTAL取模后余数为几的任务。
OJ_JAVA_TIME_BONUS=2 Java等虚拟机语言获得的额外运行时间。
OJ_JAVA_MEMORY_BONUS=512 Java等虚拟机语言获得的额外内存。
OJ_SIM_ENABLE=0 是否使用sim进行代码相似度的检测
OJ_HTTP_JUDGE=0 是否使用HTTP方式连接数据库,如果启用,则前面的HOST_NAME等设置忽略。
OJ_HTTP_BASEURL=http://127.0.0.1/JudgeOnline 使用HTTP方式连接数据库的基础地址,就是OJ的首页地址。
OJ_HTTP_USERNAME=admin 使用HTTP方式所用的用户帐号(HTTP_JUDGE权限),该帐号登录时不能启用VCODE图形验证码,但可以登录成功后启用。
OJ_HTTP_PASSWORD=admin 密码
OJ_OI_MODE=0 是否启用OI模式,即无论是否出错都继续判剩余的数据,在ACM比赛中一旦出错就停止运行。
OJ_SHM_RUN=0 是否使用/dev/shm的共享内存虚拟磁盘来运行答案,如果启用能提高判题速度,但需要较多内存。
OJ_USE_MAX_TIME=1 是否使用所有测试数据中最大的运行时间作为最后运行时间,如果不启用则以所有测试数据的总时间作为超时判断依据。
OJ_LANG_SET=0,1,2,3,4 #判哪些语言的题目

如果是判题的时候有错就得来看这里。我同学在和我合作的时候就更改了数据库用户,我还花了5大洋进了hustoj作者大神的群。别人一句话就解决了O_o

 

 

若无服务器且访问过多的可以建立分布式判题系统

数据库中

grant all privileges on jol.* to 'judge'@'%' identified by 'judge_pass' with grant option;

 

检查/etc/mysql/my.cnf 确保

bind-address        = 0.0.0.0

高负载的情况下最好设置更多的连接数。

max_connections = 512

 

其次,配置各web程序连接到数据库。
修改include/db_info.inc.php

static  $DB_HOST="数据库服务器ip";
static  $DB_NAME="jol";
static  $DB_USER="judge";
static  $DB_PASS="judge_pass";

 

第三,配置各判题程序连接到数据库,分配任务。

复制代码
OJ_HOST_NAME=数据库服务器ip
OJ_USER_NAME=judge
OJ_PASSWORD=judge_pass
OJ_DB_NAME=jol
...
OJ_TOTAL=判题机总数
OJ_MOD=本机编号,从0开始
...
复制代码

 

两台机器都装

sudo apt-get install ssh

 

第四,复制测试数据目录到各判题机。


从主机向判题机复制

scp -r /home/judge/data  root@判题机ip:/home/judge/

或用同步命令。

rsync -vzrtopg --progress --delete /home/judge/data root@判题机ip:/home/judge/

判题机从主机复制

scp -r root@主机ip:/home/judge/data  /home/judge/

或用同步命令。

rsync -vzrtopg --progress --delete root@主机ip:/home/judge/data /home/judge/

 

重启mysql

sudo /etc/init.d/mysql restart

重启Apache

sudo /etc/init.d/apache2 restart

重启judge

sudo pkill judged&&sudo judged

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:Yii2 初体验

下一篇:修改phpcms中的评论样式