主頁 > 軟體設計 > domjudge安裝筆記

domjudge安裝筆記

2020-10-17 22:28:25 軟體設計

domjudge安裝筆記 by markcoder 2020/10/15

  • 故事的開始
    • 緣起
    • 意外
    • 結果
  • 安裝環境
  • domjudge組成
  • domjudge安裝
    • 下載
    • domserver
      • 依賴軟體
      • 檢查是否滿足安裝環境
      • 開始安裝
      • 配置資料庫
      • web服務器配置
      • 檢查安裝是否成功
    • judgehost
      • 依賴軟體
      • 安裝
      • 添加user
      • 配置sudoer權限
      • 安裝chroot環境
      • 配置cgroups
        • 添加cgroups開機自啟
      • 修改 rest 檔案
      • 啟動judgedaemon
  • domjudge配置
    • 檢查配置
    • Mysql配置
    • php配置
  • 題目上傳
    • topc2020比賽資料
      • checker
        • 關于批改的執行
  • 尾記
  • 搭建完成的網址:
  • 參考:

故事的開始

緣起

剛剛參加完TOPC比賽2020 ICPC Asia Taiwan Online Programming Contest,賽前豪言壯語,“什么他娘的國立大學,老子打得就是國立” ,賽后再一次被虐的懷疑人生,
比賽時使用的domjudge平臺,賽后主辦方公開了比賽測資,故想著自己搭建一個domjudge平臺,供自己和其他同校選手復盤使用,

意外

前前后后一共從頭開始了四次,作為一個一邊查linux指令一邊摸索著安裝的弱雞,一度想要放棄,
第一次安裝:突然停電,檔案損壞,一切歸零~~(臺灣用愛發電名不虛傳 )~~ ,
第二次安裝:發生了包依賴錯誤,想著卸載出現錯誤的軟體重裝,就下了autoremove命令,然后就看到一個個圖示逐漸消失,最后連記事本也沒剩下…(安裝十年功,卸載十秒鐘! )
第三次安裝:再一次停電~~(祭央乂的用愛發電大隊?! ),~~
經過三次血淚歷程,老老實實使用虛擬機快照,大家切記要備份,都是血與淚的教訓,
第四次安裝:卡在建立judgehost的chroot環境,最后發現是ubuntu版本的問題,重新換了ubuntu 18.04之后解決,

結果

花了7天的時間,終于搭建完domjudge,感謝導師對我的全力幫助和教導!

安裝環境

virtual box 4GB記憶體 50GB硬碟
ubuntu 18.04 LTS
domjudge 7.3

一開始本著用新不用舊的原則,使用了ubuntu20.04,結果卡在judgehost的chroot環境的安裝,
在安裝chroot環境時會出現包依賴錯誤,翻閱很多了debootstrap和domjudge的相關資料,未找到具體原因,

w: Failure while configuring base packages .This will be re-attempted up to five times .w: See /chroot/ domjudge 1 debootstr ap/ debootstrap.log for details (possibly the package dconf-service is at fault )

W: Failure while configur ing base packages.This will be re- attempted up to five times.w: See /chroot 1 domjudge/ deboots tr ap/debootstrap.log for details (possibly the package dconf-service is at fault)

w: Failure while configuring base packages .This will be re-attempted up to five times.w: See /chroot 1 domjudge/ deboots tr ap/debootstrap.log for details (possibly the package dconf-service is at fault )

W: Failure while conf iguring base packages. This will be re- attempted up to f ive times .w: See /chroot/ domjudge 1 debootstr ap/ debootstrap.log for details (possibly the package dconf-service is at fault)

W: Failure while configuring base packages .This will be re-attempted up to five times .W: See /chroot/ domjudge/ debootstrap /debootstrap.log for details (possibly the package dconf-service is at fault )
4 dpkg: error processing package sof tware- proper ties-common ( --configure):
5 dependency problems - leaving unconf igured
бЕггог? wеrе еnсоuntеrеd wh?lе рrосе???ng:
7 dconf -service
8 dconf - gsettings- backend : amd64
9 gsettings desktop- schemas
0 glib- networking: amd64
.libsoup2 4- 1: amd64
2 libapps tr eam4 : amd64
3 packagekit
software -proper ties - common

解決:judgedaemon啟動時會呼叫chroot-startstop.sh來check chroot是否安裝完整,經試驗,直接把check中的驗證改成true,可以成功進入chroot環境,嘗試submit了一道題目(使用C++),也可以成功批改,但因為chroot沒有安裝完整,需要手動進入chroot環境補上所有剩下的安裝,
最終解決辦法:改使用ubuntu18.04,安裝一切順利,未出現問題,

domjudge組成

domjudge主要由domserver和judgehost組成
judgehost負責選手們提交的代碼的執行,并且會運行在chroot環境中,
如果CPU有多個核心,同一個主機可以啟動多個judgehost并系結不同的核心,
judgehost也可以裝在多臺主機上,通過http(s)來訪問domserver,

domjudge安裝

下載

https://www.domjudge.org/download
在官網下載安裝包并解壓出來

domserver

依賴軟體

先安裝官網給出的軟體串列

sudo apt install acl zip unzip mariadb-server apache2 \
      php php-fpm php-gd php-cli php-intl php-mbstring php-mysql \
      php-curl php-json php-xml php-zip composer ntp

檢查是否滿足安裝環境

可以先執行如下腳本,

./configure && make && make install

一般會還有幾項缺少的軟體,按照提示,缺哪個裝哪個即可,

開始安裝

./configure --prefix=$HOME/domjudge
make domserver
sudo make install-domserver

$HOME/domjudge可以換成自己想安裝的路徑,
注意linux的路徑名是區分大小寫的,HOME要大寫,(微軟罪惡滔天)
./configure 可以加上引數

--with-base-url=http://xxx.xxx.xxx.xxx/

配置資料庫

執行 bin/dj_setup_database

dj_setup_database genpass
sudo dj_setup_database -u root -p install

web服務器配置

我使用了apache,使用nginx請查閱官網的配置說明,

ln -s $HOME/domjudge/domserver/etc/apache.conf /etc/apache2/conf-available/domjudge.conf
ln -s $HOME/domjudge/domserver/etc/domjudge-fpm.conf /etc/php/7.3/fpm/pool.d/domjudge.conf
a2enmod proxy_fcgi setenvif rewrite
a2enconf php7.3-fpm domjudge
service php7.3-fpm reload
service apache2 reload

$HOME/domjudge/domserver是我們domserver的安裝目錄,注意自行替換,
另,注意查看php的版本,并替換上面的7.3,

檢查安裝是否成功

我們現在可以在瀏覽器中輸入localhost/domjudge/pulic進入domjudge的web,
domserver的安裝目錄下etc/initial_admin_password.secret檔案中有admin的初始密碼,

judgehost

依賴軟體

sudo apt install make sudo debootstrap libcgroup-dev lsof \
      php-cli php-curl php-json php-xml php-zip procps \
      gcc g++ default-jre-headless default-jdk-headless \
      ghc fp-compiler

先跑官網給出的串列,不夠等下再補,

安裝

./configure --prefix=$HOME/domjudge
make judgehost
sudo make install-judgehost

添加user

domjudge-run用來執行選手提交的代碼,所有只需要最少的權限,

sudo useradd -d /nonexistent -U -M -s /bin/false domjudge-run

多個judgehost似乎需要添加多個user,請自行翻閱官方檔案,

配置sudoer權限

將judgehost安裝目錄下的檔案etc/sudoers-domjudge,復制到根目錄下的/etc/sudoers.d/的路徑即可,

sudo cp etc/sudoers-domjudge /etc/sudoers.d/

可以先進入judgehost的安裝路徑,然后執行上面的bash腳本,

安裝chroot環境

執行judgehost安裝目錄下的 bin/dj_make_chroot

sudo bin/dj_make_chroot -d chroot/domjudge

-d chroot/domjudge可以省略,默認就是此路徑,
安裝完成后可以通過 lib/judge/chroot-startstop.sh check來檢查是否安裝完整,
可以執行bin/dj_run_chroot來進入chroot環境,(似乎直接執行chroot命令也是一樣,)

配置cgroups

sudo gedit /etc/default/grub

打開grub檔案,找到GRUB_CMDLINE_LINUX_DEFAULT出現的一行,修改位"quiet cgroup_enable=memory swapaccount=1",
保存并執行update-grub并重啟系統,
可以在judgehost安裝路徑下執行 judge/create_cgroups來啟動cgroups,

添加cgroups開機自啟

首先要把service檔案復制到系統目錄下去,
否則會出現類似的錯誤提示,

Failed to enable unit: Unit file create-cgroups.service dose not exist.

奇怪的是官方的安裝檔案沒有給出這個步驟,在我查閱了很多資料之后,自己悟到了,(官方或許覺得這個步驟就和開機一樣大家都會不需要寫)
首先進入domjudge的安裝目錄下,找到lib檔案夾,
把lib檔案夾下的lib/systemd/sytem/下兩個service檔案復制到系統根目錄,(還有一個service檔案是后面judgedaemon要用到的,這里就先一并復制,)

sudo cp lib/systemd/system/* /lib/systemd/system/

然后啟動服務

sudo systemctl enable create-cgroups --now

之后開機就會自動啟用cgroups,不需要每次都手動去執行judge/create_cgroups,

修改 rest 檔案

因為judgehost通過http訪問到judgeserver,所以我們需要產生一個judgehost的賬號密碼,找到domserver安裝目錄下的etc/restapi.secret檔案,使得domhost安裝目錄下etc/restapi.secret檔案與它相同即可,如果需要添加多個judgehost,具體步驟請翻閱官方檔案,

啟動judgedaemon

執行 bin/judgedaemon

sudo systemctl enable domjudge-judgehost
sudo systemctl start  domjudge-judgehost

也可以通過上面的腳本啟動服務,可以讓daemon開機自啟,
//如果只有一臺judgehost,并且之前添加的user名稱是domjudge-run,需要自行修改domjudge-judgehost.service檔案,將start一行后面的0刪掉,

到這里我們已經完成了domjudge的安裝,下面我們需要使用admin賬號登陸localhost/domjudge/pulic,去完成剩下的配置,

domjudge配置

檢查配置

在登陸后點網頁左上角的DOMjudge標志,接著在Administrator欄找到config check,
也可以直接輸入網址localhost/domjudge/jury/config/check,
在configuration check頁面下,綠色的代表已經配置ok,
黃色代表warning,比如題目沒有設定氣球顏色之類的,不改也沒大問題,
紅色代表配置不合理或者不正確,這里我挑幾個我遇到的配置項在下面簡單介紹,

Mysql配置

打開/etc/mysql/conf.d/mysql.cnf檔案

sudo gedit /etc/mysql/conf.d/mysql.cnf

復制下面的內容
[mysqld]
max_connections = 1000
max_allowed_packet = 20MB
innodb_log_file_size = 90MB
這幾項配置會因為實際題目的不同(如測資大小,測資筆數)有不同的要求,
所以建議再添加完成題目之后,再回到config check頁面檢查一遍,按照給出的要求修改即可,

因為我是用的是MariaDB,所以還需要修改/etc/mysql/mariadb.conf.d/50-server.cnf檔案中的max_allowed_packet值,

sudo systemctl restart mysql

保存退出,重啟mysql服務,

php配置

可以再configuration check頁面的右邊 system information一欄中,找到PHP:所在的一行,后面有一個藍色的i,
點擊進入頁面找到Loaded configuration File一欄可以看到php.ini組態檔所在的位置,
我這邊的路徑為/etc/php/7.2/apache2/php.ini

我們根據config check給出的要求修改以下的幾項即可,
max_file_uploads 100
upload_max_filesize 128M
post_max_size 128M
memory_limit 512M
(依實際情況不同,建議用gedit打開直接ctrl+F搜索需要修改的key,如果是在terminal中,使用vim可以直接輸入 /加內容查找,)

sudo systemctl restart apache2

然后保存檔案并重啟php

題目上傳

在web端,進入到problems下,直接上傳各個題目的zip檔即可,
檔案的格式可以參考官方檔案,

topc2020比賽資料

這里有topc2020比賽的測資,可以供大家試驗,
https://drive.google.com/drive/folders/1q9I8o1v_HEY_-rzy_boflOL_jNx7ODF9?fbclid=IwAR3EhoJBXBijyg0Ecx9yHzQjzVJ7uVASP4CIHg7N5eA_GfWXy1j0jrDt96Q

checker

topc2020中有三題是動態批改,可以在web找到executales中上傳,并選擇type為compare,
然后回到題目的配置中來,將這三題的compare修改為對應的compare,

關于批改的執行

三個verifyer檔案使用了kotlin語言,所以還需要安裝kotlin,
本以為這個程序是運行在judgehost的chroot環境里,去在chroot下安裝kotlin,折騰了很久,
翻閱了官方檔案,只有學生繳交的代碼會放到chroot中執行,并且編譯也是在外面的環境中執行的,編譯完之后才會丟去隔離環境跑,(很合理,裁判自己寫的verifyer沒必要丟去隔離環境,)
為了使用這幾個checker,我們只需要在真實環境中安裝kotlin就行了(當然你可以選自己用C或者其他語言重寫checer),

最后,如果使用snap安裝kotlin會出現權限錯誤,具體原因沒找到,換sdkman安裝kotlin之后問題解決,
安裝完kotlin之后,還需要自己動手修改checker檔案中的環境變數PATH,

尾記

附上安裝成功后的圖片
在這里插入圖片描述
在這里插入圖片描述
在這里插入圖片描述
再次感謝老師對我的幫助!

搭建完成的網址:

http://www.mjudge.net/domjudge/public
//因為搭建在google cloud上,大陸可能需要科學上網,

參考:

https://www.domjudge.org/docs/manual/7.3/index.html
https://www.runoob.com/linux/linux-tutorial.html

轉載請註明出處,本文鏈接:https://www.uj5u.com/ruanti/176864.html

標籤:其他

上一篇:Nginx 回應過濾模塊 ngx_http_addition_module

下一篇:[網路安全]SSH遠程連接

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 面試突擊第一季,第二季,第三季

    第一季必考 https://www.bilibili.com/video/BV1FE411y79Y?from=search&seid=15921726601957489746 第二季分布式 https://www.bilibili.com/video/BV13f4y127ee/?spm_id_fro ......

    uj5u.com 2020-09-10 05:35:24 more
  • 第三單元作業總結

    1.前言 這應該是本學期最后一次寫作業總結了吧。總體來說,對作業的節奏也差不多掌握了,作業做起來的效率也更高了。雖然和之前的作業一樣,作業中都要用到新的知識,但是相比之前,更加懂得了如何利用工具以及資料。雖然之間卡過殼,但總體而言,這幾次作業還算完成的比較好。 2.作業程序總結 相比前兩個單元,此單 ......

    uj5u.com 2020-09-10 05:35:41 more
  • 北航OO(2020)第四單元博客作業暨課程總結博客

    北航OO(2020)第四單元博客作業暨課程總結博客 本單元作業的架構設計 在本單元中,由于UML圖具有比較清晰的樹形結構,因此我對其中需要進行查詢操作的元素進行了包裝,在樹的父節點中存盤所有孩子的參考。考慮到性能問題,我采用了快取機制,一次查詢后盡可能快取已經遍歷過的資訊,以減少遍歷次數。 本單元我 ......

    uj5u.com 2020-09-10 05:35:48 more
  • BUAA_OO_第四單元

    一、UML決議器設計 ? 先看下題目:第四單元實作一個基于JDK 8帶有效性檢查的UML(Unified Modeling Language)類圖,順序圖,狀態圖分析器 MyUmlInteraction,實際上我們要建立一個有向圖模型,UML中的物件(元素)可能與同級元素連接,也可與低級元素相連形成 ......

    uj5u.com 2020-09-10 05:35:54 more
  • 6.1邏輯運算子

    邏輯運算子 1. && 短路與 運算式1 && 運算式2 01.運算式1為true并且運算式2也為true 整體回傳為true 02.運算式1為false,將不會執行運算式2 整體回傳為false 03.只要有一個運算式為false 整體回傳為false 2. || 短路或 運算式1 || 運算式2 ......

    uj5u.com 2020-09-10 05:35:56 more
  • BUAAOO 第四單元 & 課程總結

    1. 第四單元:StarUml檔案決議 本單元采用了圖模型決議UML。 UML檔案可以抽象為圖、子圖、邊的邏輯結構。 在實作中,圖的節點包括類、介面、屬性,子圖包括狀態圖、順序圖等。 采用了三次遍歷UML元素的方法建圖,第一遍遍歷建點,第二、三次遍歷設定屬性、連邊,實作圖物件的初始化。這里借鑒了一些 ......

    uj5u.com 2020-09-10 05:36:06 more
  • 談談我對C# 多型的理解

    面向物件三要素:封裝、繼承、多型。 封裝和繼承,這兩個比較好理解,但要理解多型的話,可就稍微有點難度了。今天,我們就來講講多型的理解。 我們應該經常會看到面試題目:請談談對多型的理解。 其實呢,多型非常簡單,就一句話:呼叫同一種方法產生了不同的結果。 具體實作方式有三種。 一、多載 多載很簡單。 p ......

    uj5u.com 2020-09-10 05:36:09 more
  • Python 資料驅動工具:DDT

    背景 python 的unittest 沒有自帶資料驅動功能。 所以如果使用unittest,同時又想使用資料驅動,那么就可以使用DDT來完成。 DDT是 “Data-Driven Tests”的縮寫。 資料:http://ddt.readthedocs.io/en/latest/ 使用方法 dd. ......

    uj5u.com 2020-09-10 05:36:13 more
  • Python里面的xlrd模塊詳解

    那我就一下面積個問題對xlrd模塊進行學習一下: 1.什么是xlrd模塊? 2.為什么使用xlrd模塊? 3.怎樣使用xlrd模塊? 1.什么是xlrd模塊? ?python操作excel主要用到xlrd和xlwt這兩個庫,即xlrd是讀excel,xlwt是寫excel的庫。 今天就先來說一下xl ......

    uj5u.com 2020-09-10 05:36:28 more
  • 當我們創建HashMap時,底層到底做了什么?

    jdk1.7中的底層實作程序(底層基于陣列+鏈表) 在我們new HashMap()時,底層創建了默認長度為16的一維陣列Entry[ ] table。當我們呼叫map.put(key1,value1)方法向HashMap里添加資料的時候: 首先,呼叫key1所在類的hashCode()計算key1 ......

    uj5u.com 2020-09-10 05:36:38 more
最新发布
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:20:47 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:20:25 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:20:17 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:20:10 more
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:19:44 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:19:07 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:18:57 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:18:49 more
  • 05單件模式

    #經典的單件模式 public class Singleton { private static Singleton uniqueInstance; //一個靜態變數持有Singleton類的唯一實體。 // 其他有用的實體變數寫在這里 //構造器宣告為私有,只有Singleton可以實體化這個類! ......

    uj5u.com 2023-04-19 08:42:51 more
  • 【架構與設計】常見微服務分層架構的區別和落地實踐

    軟體工程的方方面面都遵循一個最基本的道理:沒有銀彈,架構分層模型更是如此,每一種都有各自優缺點,所以請根據不同的業務場景,并遵循簡單、可演進這兩個重要的架構原則選擇合適的架構分層模型即可。 ......

    uj5u.com 2023-04-19 08:42:41 more