hustoj在线判题平台详细搭建二开及美化过程(ubuntu20.04 / centos7.9)常见问题解决

服务器配置需求

阿里云 腾讯云 华为云均可,腾讯云目前是最合适的。

腾讯云 2H4G 5M 60GB 轻量应用服务器  承载大约 200~400人使用,经过压力测试,评测并发速度可满足130人左右的在线比赛。
镜像选Ubuntu22.04LTS,物理机安装Ubuntu22.04 Server。

购买链接如下:

【腾讯云】2核2G3M云服务器7.92元/月起,2000元代金券免费领

云服务器购买成功后通过扫码识别登录云控制台:

点击 更多—查看详情

点击 登录 打开 一键登录 窗口 即可在命令行下执行操作   命令前 加入 sudo

一、hustoj部署

ubuntu系统安装:
第一步:

cd /home
sudo wget http://dl.hustoj.com/install.sh 
第二步:
sudo bash install.sh
centos系统安装 :

先上传install-centos7.sh 到home目录下

cd /home
sudo wget http://dl.hustoj.com/install-centos7.sh
sudo bash install-centos7.sh

出现账号和密码。复制记下来,后面要用。

在浏览器里面访问云服务器公网地址例如:101.34.59.x 或者(局域网ip地址 例如192.168.1.x 局域网虚拟机部署)就可以看到主页了。

注册后台管理员

用户名使用 admin。其他按照要求填就行。这个就是管理员账号。

二、hustoj配置


1.大部分功能和选项的开关和参数调整都在配置文件中,安装后几个重要配置文件的位置如下:

/home/judge/etc/judge.conf  #判题judged/judge_client
/home/judge/src/web/include/db_info.inc.php  #Web
/etc/php5/fpm/php.ini 或 /etc/php7.0/fpm/php.ini 或 /etc/php.ini(in Centos7)  #php
/etc/nginx/sites-enabled/default 或 /etc/nginx/nginx.conf(in Centos7)  #nginx

HUSTOJ的两个重要配置文件(judge.conf和db_info.inc.php),互相独立,分别供core和web使用。

core(judged/judge_client)使用的配置文件是judge.conf,内容如下:

OJ_HOST_NAME=127.0.0.1  #用mysql连接读取数据库,数据库的主机地址
OJ_USER_NAME=debian-sys-maint #数据库帐号
OJ_PASSWORD=CM172iAvF10lrrKr #数据库密码
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=64 #Java等虚拟机语言获得的额外内存
OJ_JAVA_XMS=-Xms64M 
OJ_JAVA_XMX=-Xmx128M
OJ_SIM_ENABLE=0 #//是否开启代码相似度比对,开启这个并且同时开启db_info.inc.php中static  $OJ_SIM=false,才能启用OJ查重
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 #使用HTTP方式所用的用户密码
OJ_REDISENABLE=0
OJ_REDISSERVER=127.0.0.1
OJ_REDISPORT=6379
OJ_REDISAUTH=123456
OJ_REDISQNAME=hustoj
OJ_OI_MODE=1 #是否启用OI(信息学奥林匹克竞赛)模式,即无论是否出错都继续判剩余的数据,在ACM比赛中一旦出错就停止运行。
OJ_SHM_RUN=1 #是否使用/dev/shm的共享内存虚拟磁盘来运行答案,如果启用能提高判题速度,但需要较多内存。
OJ_USE_MAX_TIME=1 #是否使用所有测试数据中最大的运行时间作为最后运行时间,如果不启用则以所有测试数据的总时间作为超时判断依据
OJ_LANG_SET=0,1,2,3,4,5,6,7,8,9,10,11 #判题机评测语言,即C、C++、Java、Python......
OJ_COMPILE_CHROOT=0
OJ_TURBO_MODE=0
OJ_CPU_COMPENSATION=0.88
OJ_UDP_ENABLE=1
OJ_UDP_SERVER=127.0.0.1
OJ_UDP_PORT=1536


注意,core没有识别引号和注释的能力,所以不要自行增加任何引号或注释,否则可能影响judged的启动,上面的解释仅做阅读,不能放入配置文件。
web端使用的配置文件是db_info.inc.php,内容如下:

static     $DB_HOST="localhost";  //数据库服务器ip或域名
static     $DB_NAME="jol";   //数据库名
static     $DB_USER="debian-sys-maint";  //数据库账户
static     $DB_PASS="CM172iAvF10lrrKr";  //数据库密码
static     $OJ_NAME="HUSTOJ";  //左上角显示的系统名称
static     $OJ_HOME="./";    //主页目录
static     $OJ_ADMIN="root@localhost";  //管理员email
static     $OJ_DATA="/home/judge/data";  //测试数据目录
static     $OJ_BBS=false;//"bbs" for phpBB3 bridge or "discuss" for mini-forum or false for close any 
static  $OJ_ONLINE=false;  //是否记录在线情况
static  $OJ_LANG="en";  //默认语言
static  $OJ_SIM=false;  //显示相似度
static  $OJ_DICT=false; //显示在线翻译
static  $OJ_LANGMASK=0; //1mC 2mCPP 4mPascal 8mJava 16mRuby 32mBash 1008 for security reason to mask all other language
static  $OJ_EDITE_AREA=true;//true: syntax highlighting is active
static  $OJ_ACE_EDITOR=true;
static  $OJ_AUTO_SHARE=false;//true: One can view all AC submit if he/she has ACed it onece.
static  $OJ_CSS="white.css";
static  $OJ_SAE=false; //using sina application engine
static  $OJ_VCODE=false;  //验证码
static  $OJ_APPENDCODE=false;  // 代码预定模板
static  $OJ_CE_PENALTY=false;  // 编译错误是否罚时
static  $OJ_PRINTER=false;  //启用打印服务
static  $OJ_MAIL=false; //内邮
static  $OJ_MARK="mark"; // "mark" for right "percent" for WA
static  $OJ_MEMCACHE=false;  //使用内存缓存
static  $OJ_MEMSERVER="127.0.0.1";
static  $OJ_MEMPORT=11211;
static  $OJ_UDP=true;   //使用UDP通知
static  $OJ_UDPSERVER="127.0.0.1";
static  $OJ_UDPPORT=1536;
static  $OJ_REDIS=false;   //使用REDIS队列
static  $OJ_REDISSERVER="127.0.0.1";
static  $OJ_REDISPORT=6379;
static  $OJ_REDISQNAME="hustoj";
static  $SAE_STORAGE_ROOT="http://hustoj-web.stor.sinaapp.com/";
static  $OJ_CDN_URL="";  //  http://cdn.hustoj.com/  https://raw.githubusercontent.com/zhblue/hustoj/master/trunk/web/ 
static  $OJ_TEMPLATE="bs3"; //使用的默认模板, [bs3 ie ace sweet sae] work with discuss3, [classic bs] work with discuss
//if(isset($_GET['tp'])) $OJ_TEMPLATE=$_GET['tp'];
static  $OJ_LOGIN_MOD="hustoj";
static  $OJ_REGISTER=true; //允许注册新用户
static  $OJ_REG_NEED_CONFIRM=false; //新注册用户需要审核
static  $OJ_NEED_LOGIN=false; //需要登录才能访问
static  $OJ_RANK_LOCK_PERCENT=0; //比赛封榜时间比例
static  $OJ_SHOW_DIFF=false; //是否显示WA的对比说明
static  $OJ_TEST_RUN=false; //提交界面是否允许测试运行
static  $OJ_BLOCKLY=false; //是否启用Blockly界面
static  $OJ_ENCODE_SUBMIT=false; //是否启用base64编码提交的功能,用来回避WAF防火墙误拦截。
static  $OJ_OI_1_SOLUTION_ONLY=false; //比赛是否采用noip中的仅保留最后一次提交的规则。true则在新提交发生时,将本场比赛该题老的提交计入练习。
static  $OJ_OI_MODE=false;//是否开启OI比赛模式,禁用排名、状态、统计、用户信息、内邮、论坛等。
static  $OJ_SHOW_METAL=true;//榜单上是否按比例显示奖牌
static  $OJ_RANK_LOCK_DELAY=3600;//赛后封榜持续时间,单位秒。根据实际情况调整,在闭幕式颁奖结束后设为0即可立即解封。
static  $OJ_BENCHMARK_MODE=false; //此选项将影响代码提交,不再有提交间隔限制,提交后会返回solution id

//static  $OJ_EXAM_CONTEST_ID=1000; // 启用考试状态,填写考试比赛ID
//static  $OJ_ON_SITE_CONTEST_ID=1000; //启用现场赛状态,填写现场赛比赛ID
/* share code */
static  $OJ_SHARE_CODE = false; // 代码分享功能
/* recent contest */
static  $OJ_RECENT_CONTEST = false;// "http://algcontest.rainng.com/contests.json" ; // 名校联赛
//$OJ_ON_SITE_TEAM_TOTAL用于根据比例的计算奖牌的队伍总数
//CCPC比赛的一种做法是比赛结束后导出终榜看AC至少1题的不打星的队伍数,现场修改此值即可正确计算奖牌
//0表示根据榜单上的出现的队伍总数计算(包含了AC0题的队伍和打星队伍)
static $OJ_ON_SITE_TEAM_TOTAL=0;

2.如果用户量比较大,报50X错误,可能需要修改/etc/nginx/nginx.conf中的设置:

worker_processes 8;    #其中数字8可以取CPU核心数的整数倍。
events {
    worker_connections 2048;
    multi_accept on;
}

3.如果遇到比赛人数多,比赛排名xls文件无法下载,请修改/etc/nginx/sites-enabled/default, 在fastcgi_pass一行的后面增加:

fastcgi_buffer_size 128k;
fastcgi_buffers 32 32k;

4.保存后,重启nginx:

 /usr/sbin/nginx -s reload


三、HUSTOJ的备份与恢复


1.备份
脚本安装的用户,可以使用install目录中的bak.sh进行备份:

sudo bash /home/judge/src/install/bak.sh

2.恢复
如果要恢复,我们需要找到备份的两个压缩包,db_xxxxxxxx.sql.bz2和hustoj_xxxxxxxx.tar.bz2,首先,我们将其解压缩:

tar -jxvf hustoj_20191116.tar.bz2
bzip2 -d db_20191116.sql.bz2


我们解压缩之后会有两个目录(home/、var/)和一个数据库文件(db_xxxxxxxx.sql)。其中home里面存放的是一些数据,而var里面存放的和上面一样是db_xxxxxxxx.sql.bz2数据库文件。
然后,我们就进入新搭建好的HUSTOJ的数据库,将备份的数据库导入进去:

sudo mysql -u root -p -A #登录mysql,这里的root根据你judge.conf而定,接着输入密码
use jol; #进入jol数据库
source /var/backups/db_xxxxxxxx.sql #旧OJ的sql文件路径
最后把home/judge文件夹上传覆盖即可。

四、HUSTOJ的升级


脚本安装的用户,可以使用install目录中的update-hustoj进行升级。

sudo bash /home/judge/src/install/update-hustoj
升级脚本执行后,可能需要登陆web端管理后台,执行一次更新数据库。

五、HUSTOJ的修复


自己不小心改坏了web代码,可以使用install目录中的fixing.sh进行系统修复。

sudo bash /home/judge/src/install/fixing.sh


六、HUSTOJ的美化


1.首先就是OJ最下面的那两个二维码广告:

(1).我们可以通过修改/home/judge/src/web/template/bs3/js.php文件来去除:

sudo  vim /home/judge/src/web/template/bs3/js.php
#或者
#cd /home/judge/src/web/template/bs3/
#sudo vim js.php

(2).找到这两行,将其注释或删除(注释://or/* */):

$("body").append("<div id=footer class=center >GPLv2 licensed by <a href='https://github.com/zhblue/hustoj' >HUSTOJ</a> "+(new Date()).getFullYear()+" </div>");
$("body").append("<div class=center > <img src='http://hustoj.com/wx.jpg' width='120px'><img src='http://hustoj.com/alipay.png' width='120px'><br> 欢迎关注微信公众号onlinejudge</div>");

(3).保存退出:wq,刷新网页,然后我们就可以看到广告消失了。

2.至于上面的广告就是公告了,进入后台管理,把公告删除就行了。

3.当我们发个新闻,新闻的下面会显示:

(1).这个我们可以在/home/judge/src/web/index.php:

vim /home/judge/src/web/index.php

(2).在里面找到:

$view_news .= "</div>";
$view_news .= "<div class='panel-footer'>请到<a target='_blank' href='https://github.com/zhblue/hustoj'> GitHub</a>来,给我们加个星星!&nbsp;Please give us a star on <a target='_bla    nk' href='https://github.com/zhblue/hustoj'>Github</a>!</div>";
$view_news .= "</div>";


(3).将其注释掉或删除。

(4).如果你想去掉新闻标题后面的小尾巴:

(5).我们同样是在index.php文件中修改:

sudo vim /home/judge/src/web/index.php

(6).在里面找到:

$view_news .= "<div class='panel-heading'><big>" . $row[ 'title' ] . /*"</big>-<small>" . $row[ 'user_id' ] .*/ "</small></div>";
(7).将"</big>-<small>" . $row[ 'user_id' ] .注释或删除掉:

4.OJ的评测结果默认是在后面加上一个分数的,例如Accepted100。
(1).如果想要去掉这个分数,我们只需要在/home/judge/src/web/status.php中找到(大概在295行左右):

$view_status[$i][3].= "$mark</a>";
(2).将其注释或删除掉就行了:

七、导入题库

后台导入问题失败
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生效。

  • 3
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
为了美化Ubuntu 20.04,你可以按照以下步骤进行操作: 1. 更改壁纸:右键点击桌面,选择"更改背景",然后选择你喜欢的壁纸。 2. 安装主题:你可以使用GNOME Tweaks工具来安装和切换主题。打开终端,运行以下命令安装GNOME Tweaks: ``` sudo apt install gnome-tweaks ``` 安装完成后,打开GNOME Tweaks,点击"外观"选项卡,然后在"应用程序"、"图标"和"Shell"部分选择你喜欢的主题。 3. 安装图标主题:你可以在GNOME-Look网站上找到各种图标主题。下载喜欢的图标主题,然后打开GNOME Tweaks,点击"外观"选项卡,将下载的图标主题文件拖放到"图标"部分。 4. 安装字体:你可以在GNOME Tweaks中的"字体"选项卡中更改系统字体。如果你想安装其他字体,可以将字体文件复制到`~/.fonts`目录中,然后在GNOME Tweaks中进行配置。 5. 安装扩展:使用GNOME Shell Extensions可以增强桌面功能和外观。你可以在GNOME Extensions网站上找到各种扩展。安装GNOME Shell Extensions插件,并通过该插件安装和管理扩展。 6. 安装Dock:你可以安装一个Dock来增强任务栏的功能和外观。有一些流行的Dock选择,如Plank、Cairo-Dock等。你可以通过软件包管理器或者终端来安装它们。 这些是美化Ubuntu 20.04的一些常见步骤,你可以根据自己的喜好进行调整和定制。记得备份你的系统和文件,以防在美化过程中出现问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

星卯教育tony

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值