声明

本文档非官方文档,为我试坑的经验总结。

本文编写时间 2019.11.04 ,并不一定会随UOJ更新而更新。

由于UOJ需要用SVN传题,并不那么方便。于是我选择转用UOJ社区版。但是UOJ社区版并没有关于如何安装多个Judger的文档。本文是我通过部分UOJ和UOJ社区版的源码,经实践得到。

注意我并不清楚UOJ的具体架构与实现,同时也并不那么熟悉 Docker 。过程中可能有许多不合理的地方,还请谅解。如果有更好的方法或是使用心得,可以与我交流。

在同一台机器上安装

1

首先需要建起一个 judger ,并且让这个 judger 知道 main_server 在哪里。

你需要基于 main_judger 的 conf.json 写一个新的 conf.json :

运行 docker cp <uoj container id>:/opt/uoj/judger/.conf.json ./conf.json 将 main_judger 的 configure 拷贝到当前目录。其中 <uoj container id> 表示 uoj 容器的 id 。

如果你不知道 uoj 容器的 id ,可以 docker ps 来查看正在运行的容器,或是 docker ps -a 来看所有的容器。

然后修改 conf.json 里这个几个值:

  • "uoj_host" : 改为你 uoj 的 ip (注意不是你主机的ip,而是那个容器的ip);
  • "judger_name" : 起一个新名字,如 judger1 ;
  • "judger_password" : 密码,如 H3b01oSP2Y5KzL4l1GYrA37jpgeQQLuS (我随的)

你可以这样获取一个docker容器的ip:

docker inspect --format '{{ .NetworkSettings.IPAddress }}' <container-id>

记住你修改的这些东西。

2

然后根据UOJ社区版的 Dockerfile ,建立一个 judger 的 image 。

这是 UOJ-System 那个 git 中的 judger 安装文件。

FROM ubuntu:18.04
MAINTAINER MascoSkray <MascoSkray@gmail.com>
ARG CLONE_ADDFLAG WORKDIR /opt
#Update apt and install git
RUN apt-get update && apt-get install -y git
#Clone the latest UOJ Community verison to local
RUN git clone https://github.com/UniversalOJ/UOJ-System.git --depth 1 --single-branch ${CLONE_ADDFLAG} uoj
#Install environment and set startup script
RUN cd uoj/install/judger && sh install.sh -p && echo "\
#!/bin/sh\n\
if [ ! -f \"/opt/uoj/judger/.conf.json\" ]; then\n\
cd /opt/uoj/install/judger && sh install.sh -i\n\
fi\n\
service ntp start\n\
su judger -c \"/opt/uoj/judger/judge_client start\"\n\
exec bash\n" >/opt/up && chmod +x /opt/up ENV LANG=C.UTF-8 TZ=Asia/Shanghai
EXPOSE 2333
CMD /opt/up

我们需要在 Install && Set Startup 之前加上一句话:

COPY conf.json /opt/uoj/judger/.conf.json

这是把配置放到 judger 里面。

然后构建这个镜像:

docker build -f Dockerfile .

Dockerfile 就是你更改之后的文件,同时不要漏掉那个点。

等待一会儿 ,如果构建成功,你能看到 Successfully built ...

3

运行 judger : docker run -it --cap-add SYS_PTRACE <image id>

其中 <image id> 是你刚刚构建的 judger 镜像 id 。这样是直接进入docker 终端,你可以看看有没有报错。或者 docker run -dit --cap-add SYS_PTRACE <image id> 让它直接在后台运行。

如果你在最后测试的时候遇到新加的评测机 judgement failed ,并且 fail to show details ,那么多半是忘记加 --cap-add SYS_PTRACE

4

最后你要在 main_server 上操作一下,让它知道又有一个 judger 了。

首先 docker exec -it uoj /bin/bash 来进入容器。

执行 mysql -p app_uoj233 来进入数据库。默认密码为 root

运行 insert into judger_info (judger_name, password, ip) values ('<judger_name>', '<password>', '<ip>');

其中 <judger_name> 是刚才新 Judger 的名字, <password> 是新 judger 的密码, <ip> 是新 judger 的 IP(同样是容器的ip)。最后的命令可能是这样的:

insert into judger_info (judger_name, password, ip) values ('judger1', 'H3b01oSP2Y5KzL4l1GYrA37jpgeQQLuS', '172.17.0.3');

你应该能在网页上 你的账号->系统管理->评测机管理 里面看到这个评测机了。

然后随便 rejudge 一道题看看评测机正不正常?

在不同机子上安装

我决定先

坑着

UOJ社区版安装多个Judger的更多相关文章

  1. 【Git】 GitLab服务器社区版安装与配置

    GitLab简介 GitLab 是一个用于仓库管理系统的开源项目,使用Git作为代码管理工具,并在此基础上搭建起来的web服务 GitLab系统架构 当~git在图片中引用时,它表示git用户的主目录 ...

  2. MYSQL社区版安装手册

    https://www.jb51.net/article/140412.htm 在本教程中使用MySQL最新的MySQL服务8.0.11的社区绿色版本进行安装,绿色版为zip格式的包,安装分为以下四步 ...

  3. OpenAcc社区版安装教程(Linux版)(更新版)

    官方安装过程如下图所示 1.安装前 下载OpenAcc社区版 1,目前为止的最新版,平台是Linux,选择Linux x86-64. 我的服务器系统是CentOs 下载地址链接:https://www ...

  4. MySQL 社区版 安装小记

    根据刘铁猛老师的教程,自己折腾一下 1. 安装包准备 在Windows10 64bit上安装,故需要准备vc++ 2013和2015的Redistributable的包,搜索即有,无需细说. 示例数据 ...

  5. pycharm社区版安装及遇到的问题

    1. 在官网上下载pycharm社区版安装包. 2. 按照该教程进行安装: https://jingyan.baidu.com/article/f00622286e92f4fbd2f0c855.htm ...

  6. 002.MongoDB社区版安装

    一 前期准备 1.1 相关软件包介绍 包裹名字 描述 mongodb-org 一个将自动安装以下四个组件包的组合包. mongodb-org-server 包含mongod守护程序,关联的init脚本 ...

  7. Gitlab 社区版安装部署和维护指南

    因为我的个人网站 restran.net 已经启用,博客园的内容已经不再更新.这篇文章是在 Gitlab 7.4 的环境下配置的,相关内容可能已经过时. 后续做了一次迁移,将 Gitlab 升级到了 ...

  8. win10 Ubuntu子系统安装&odoo10社区版安装

    参考文档: http://www.cnblogs.com/odoouse/p/5995603.html https://www.jianshu.com/p/58090215bda8 一.win10 U ...

  9. Ubuntu 16.04 (官方命令行)安装MongoDB 3.6.2(社区版)

    概述 使用本教程从 .deb 包在LTS Ubuntu Linux系统上安装MongoDB Community Edition. 虽然Ubuntu包含自己的MongoDB包,但官方的MongoDB社区 ...

随机推荐

  1. Java多线程(十):BlockingQueue实现生产者消费者模型

    BlockingQueue BlockingQueue.解决了多线程中,如何高效安全"传输"数据的问题.程序员无需关心什么时候阻塞线程,什么时候唤醒线程,该唤醒哪个线程. 方法介绍 ...

  2. hdu 6058 思维

    题目:http://acm.hdu.edu.cn/showproblem.php?pid=6058 分析题目的时候,由于枚举的区间很多,而第k大的值范围小,应该要想到去枚举第k大的值然后找到这个值对答 ...

  3. ASP.NET Core中间件实现分布式 Session(转载)

    ASP.NET Core中间件实现分布式 Session 1. ASP.NET Core中间件详解 1.1. 中间件原理 1.1.1. 什么是中间件 1.1.2. 中间件执行过程 1.1.3. 中间件 ...

  4. dev gridview 单元格值拖拽替换

    public class GridViewDropCell { //dvginfo根据鼠标点击的x.y坐标获取该点的相关信息 private GridHitInfo downHitInfo; priv ...

  5. 微信小程序修改radio和checkbox的默认样式和图标

    wxml: <view class="body"> <view class="body-content"> 第1题:企业的价值观是 ? ...

  6. luogu1731生日蛋糕题解--恶心剪枝

    题目链接 https://www.luogu.org/problemnew/show/P1731 分析 这题真[哔]恶心,加了一堆奇奇怪怪的优化 首先明确一点,半径和高都必须是正整数,意味着它们最小为 ...

  7. vue + echarts 实现中国地图 展示城市

    Demo 安装依赖 vue中安装echarts npm install echarts -S 在main.js中引用 import echarts from 'echarts'Vue.prototyp ...

  8. vue-cli之加载ico文件

    vue-cli之加载ico文件 vue-cli加载ico文件需要在vue.config.js设置ico加载,代码如下: module.exports = { publicPath: process.e ...

  9. SQL学习——IN运算符

    IN的作用 IN运算符允许您在WHERE子句中指定多个值. IN运算符是多个OR条件的简写. IN的语法 SELECT column_name(s) FROM table_name WHERE col ...

  10. 2.SpringMVC执行流程

    SpringMVC 执行流程: 执行流程简单分析: 1.浏览器提交请求到中央调度器 2.中央调度器直接将请求转给处理器映射器 3.处理器映射器会根据请求,找到处理该请求的处理器,并将其封装为处理器执行 ...