應該跟着下面的步驟就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便可直接應用了。
