HUSTOJ的安装与配置

2024-06-24 03:32
文章标签 配置 安装 hustoj

本文主要是介绍HUSTOJ的安装与配置,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

之前HustOJ源码挂在了code.google上了,由于某些原因上不去。现在官方把源码又挂在了GitHub上,具体操作流程见官方教程:https://github.com/zhblue/hustoj




----------------------------------下面是老方法不用看了------------------------------

本文转载自小白学长博客。


官方给出的安装方法:https://code.google.com/p/hustoj/wiki/README

本教程适用于Ubuntu各版本,CentOS/Debian/Redhad用户请按官方说明自行尝试安装。

系统如何安装,应该不用说,作为计算机人不会装系统就太说不过去了。
安装好的Ubuntu是没有超级管理员密码的 所以要自己设置。
为什么设置——在操作过程中会很频繁用的管理员权限 不如直接以超级管理员的身份运行, 用超级管理员权限的话会比较方便,至少我觉得会很方便。
打开终端键入sudo passwd后设置superuser密码。

第一步
打开终端键入

sudo apt-get update

 上调命令 升级软件库(之前提到过可直接以超级管理员身份运行,在终端键入su - 后输入密码即可,以超级管理员身份操作命令前sudo可省去)


之后键入

sudo apt-get install subversion

安装subversion

 

(svn checkout http://hustoj.googlecode.com/svn/trunk/install hustoj )
改成:
sudo svn co https://github.com/zhblue/hustoj/trunk/trunk/install hustoj

从svn获取hustoj

 

cd hustoj

进入hustoj目录


提示上说要编辑install.sh和web/include/db_info.inc.php到现在这一步仍不会设置,不清楚是干什么的,但是不影响安装,因为我也没找到db_info.inc.php,找到了install.sh也不知道怎么设置,不设置与之后操作无影响。

之后直接

(sudo ./install.sh)
改成:
sudo bash install-interactive.sh

 执行安装


在安装期间会提示设置数据库密码,root即可。
之后会自动安装。

安装完OJ后,会发现在系统登录的时候会多出一个judge的账户,一开始我一直以为是用judge这个账户登录,便一直在网上搜索默认的密码是多少,可是后来发现,用自己原来的账户登录即可,可以完全无视judge这个账户。

 

第二步
此时hustoj已经干装完毕,当然没有帐号登录,可在http://127.0.0.1/JudgeOnline/registerpage.php 注册一个普通帐号如blank
此时blank为普通用户,不能对hustoj进行任何操作, 这时要将blank设置为OJ管理员,设置是在数据库里设置,因为所有信息都存储在数据库里,只更改数据库就可以。
打开mysql 方式:

mysql -u root -p

此方式为数据库管理员权限进入,当初直接进入数据库怎么也无法将我自己的账号设置成管理员,之后才明白,只有是数据库的管理员才能将OJ的账户设置成管理员,当然在网页也可以,第一个管理员可不能在网页设置。


进入数据库后键入

show databases;

(要有分号) (显示数据库)之后会出现一个已有的数据库列表。

 

jol这个数据库就是OJ所用的库,要对OJ操作在这里操作便是。

 use jol;

 选择jol。

insert into privilege(user_id,rightstr) values('blank','administrator');

 blank 作为需要加管理员权限的帐号,此后blank可对OJ进行任何操作


地址:http://127.0.0.1/JudgeOnline/admin/

 

第三步
配置文件
hustoj有两个配置文件,互相独立,分别供core和web使用。
core(judged/judge_client)使用的配置文件是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 #判哪些语言的题目
复制代码

 

web使用的配置文件是db_info.inc.php,默认位置/var/www/JudgeOnline/include/,以管理员权限进入方可进行操作,内容如下

复制代码
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时的对比
复制代码

 

接下来修改的配置文件是php.ini,默认位置/etc/php5/apache2

复制代码
sudo gedit /etc/php5/apache2/php.ini 
open_basedir =/home/judge/data:/var/www/JudgeOnline:/tmp 
max_execution_time = 300    ;Maximum execution time of each script, in seconds
max_input_time = 600
memory_limit = 128M    ;Maximum amount of memory a script may consume (16MB)
post_max_size = 128M
upload_tmp_dir =/tmp
upload_max_filesize = 128M
复制代码

 

 在这修改完之后OJ便可直接应用了。

 

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

 

数据库中

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

这篇关于HUSTOJ的安装与配置的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/1089048

相关文章

Spring Boot配置和使用两个数据源的实现步骤

《SpringBoot配置和使用两个数据源的实现步骤》本文详解SpringBoot配置双数据源方法,包含配置文件设置、Bean创建、事务管理器配置及@Qualifier注解使用,强调主数据源标记、代... 目录Spring Boot配置和使用两个数据源技术背景实现步骤1. 配置数据源信息2. 创建数据源Be

Spring Boot Maven 插件如何构建可执行 JAR 的核心配置

《SpringBootMaven插件如何构建可执行JAR的核心配置》SpringBoot核心Maven插件,用于生成可执行JAR/WAR,内置服务器简化部署,支持热部署、多环境配置及依赖管理... 目录前言一、插件的核心功能与目标1.1 插件的定位1.2 插件的 Goals(目标)1.3 插件定位1.4 核

虚拟机Centos7安装MySQL数据库实践

《虚拟机Centos7安装MySQL数据库实践》用户分享在虚拟机安装MySQL的全过程及常见问题解决方案,包括处理GPG密钥、修改密码策略、配置远程访问权限及防火墙设置,最终通过关闭防火墙和停止Net... 目录安装mysql数据库下载wget命令下载MySQL安装包安装MySQL安装MySQL服务安装完成

RabbitMQ消息总线方式刷新配置服务全过程

《RabbitMQ消息总线方式刷新配置服务全过程》SpringCloudBus通过消息总线与MQ实现微服务配置统一刷新,结合GitWebhooks自动触发更新,避免手动重启,提升效率与可靠性,适用于配... 目录前言介绍环境准备代码示例测试验证总结前言介绍在微服务架构中,为了更方便的向微服务实例广播消息,

JAVA中安装多个JDK的方法

《JAVA中安装多个JDK的方法》文章介绍了在Windows系统上安装多个JDK版本的方法,包括下载、安装路径修改、环境变量配置(JAVA_HOME和Path),并说明如何通过调整JAVA_HOME在... 首先去oracle官网下载好两个版本不同的jdk(需要登录Oracle账号,没有可以免费注册)下载完

nginx 负载均衡配置及如何解决重复登录问题

《nginx负载均衡配置及如何解决重复登录问题》文章详解Nginx源码安装与Docker部署,介绍四层/七层代理区别及负载均衡策略,通过ip_hash解决重复登录问题,对nginx负载均衡配置及如何... 目录一:源码安装:1.配置编译参数2.编译3.编译安装 二,四层代理和七层代理区别1.二者混合使用举例

Java JDK1.8 安装和环境配置教程详解

《JavaJDK1.8安装和环境配置教程详解》文章简要介绍了JDK1.8的安装流程,包括官网下载对应系统版本、安装时选择非系统盘路径、配置JAVA_HOME、CLASSPATH和Path环境变量,... 目录1.下载JDK2.安装JDK3.配置环境变量4.检验JDK官网下载地址:Java Downloads

SQL server数据库如何下载和安装

《SQLserver数据库如何下载和安装》本文指导如何下载安装SQLServer2022评估版及SSMS工具,涵盖安装配置、连接字符串设置、C#连接数据库方法和安全注意事项,如混合验证、参数化查... 目录第一步:打开官网下载对应文件第二步:程序安装配置第三部:安装工具SQL Server Manageme

Linux下进程的CPU配置与线程绑定过程

《Linux下进程的CPU配置与线程绑定过程》本文介绍Linux系统中基于进程和线程的CPU配置方法,通过taskset命令和pthread库调整亲和力,将进程/线程绑定到特定CPU核心以优化资源分配... 目录1 基于进程的CPU配置1.1 对CPU亲和力的配置1.2 绑定进程到指定CPU核上运行2 基于

Spring Boot spring-boot-maven-plugin 参数配置详解(最新推荐)

《SpringBootspring-boot-maven-plugin参数配置详解(最新推荐)》文章介绍了SpringBootMaven插件的5个核心目标(repackage、run、start... 目录一 spring-boot-maven-plugin 插件的5个Goals二 应用场景1 重新打包应用