最新Linux系統Ubuntu16.04搭建HUSTOJ(LAMP環境)


應該跟着下面的步驟就OK了吧!

1.升級軟件庫,更新軟件

打開終端 輸入

sudo apt-get update

sudo apt-get upgrade

2.安裝mysql5.7

(注意:mysql5.7密碼需要大寫字母和字符,且不少於8位)

sudo apt-get install mysql-server mysql-client

安裝的過程會有一個框,輸入sql密碼,按TAB切換到ok

3.安裝apache2

sudo apt-get install apache2

這里要說明一下的就是ubuntu下的apache默認網頁執行文件夾在/var/www/下面,配置文件在/etc/apache2/apache2.conf,配置文件子目錄在/etc/apache2/下
進入瀏覽器,鍵入http://localhost,出現It works!代表安裝成功.

4.安裝php7.0

sudo apt-get install php7.0 libapache2-mod-php7.0

重啟apache,輸入/etc/init.d/apache2 restart

5.測試LAMP環境

在終端上先輸入cd /var/www/html

再輸入 sudo gedit info.php(這個文件是新增的,所以打開是空白頁)

然后就會打開,輸入一下內容
<?php phpinfo();?>

保存然后再關閉


然后在瀏覽器輸入
http://localhost/info.php
出現php的一系列屬性,LAMP環境就完成了。

6.安裝hust oj

執行如下命令:

sudo apt-get update 
sudo apt-get install subversion 
sudo svn co https://github.com/zhblue/hustoj/branches/php7/trunk/install hustoj 
cd hustoj 
sudo bash install-interactive.sh

7.運行JudgeOnline

瀏覽器輸入http://localhost/JudgeOnline或者http://127.0.0.1/JudgeOnline即可。(截圖軟件:Screenshot)

就會出現下面這個頁面:

 

此時hustoj已經干裝完畢,當然沒有帳號登錄,可在http://127.0.0.1/JudgeOnline/registerpage.php 注冊一個普通帳號如admin。
此時admin為普通用戶,不能對hustoj進行任何操作, 這時要將admin設置為OJ管理員,設置是在數據庫里設置,因為所有信息都存儲在數據庫里,只更改數據庫就可以了。

打開MySQL 方式:

mysql -u root -p

此方式為數據庫管理員權限進入,當初直接進入數據庫怎么也無法將我自己的賬號設置成管理員,之后才明白,只有是數據庫的管理員才能將OJ的賬戶設置成管理員,當然在網頁也可以,第一個管理員可不能在網頁設置。

進入數據庫后鍵入

show databases;

(要有分號) (顯示數據庫)之后會出現一個已有的數據庫列表。

 

jol這個數據庫就是OJ所用的庫,要對OJ操作在這里操作便是。

use jol;

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


admin 作為需要加管理員權限的帳號,此后blank可對OJ進行任何操作。

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

注意:重新操作OJ輸入以下命令就好:

cd hustoj
sudo bash install-interactive.sh

 

8.配置文件

hustoj有兩個配置文件,互相獨立,分別供core和web使用。

 

core(judged/judge_client)使用的配置文件是judge.conf,默認位置/home/judge/etc,內容如下:

【遇到了文件權限問題,輸入“sudo chmod -R 777 (文件名)“即可解決】
(注意: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/html/JudgeOnline/include/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時的對比

 

 

接下來修改的配置文件是php.ini,默認位置/etc/php/7.0/apache2

sudo gedit /etc/php/7.0/apache2/php.ini
open_basedir =/home/judge/data:/var/www/html/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便可直接應用了。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM