专属域名
文档搜索
轩辕助手
Run助手
邀请有礼
返回顶部
快速返回页面顶部
收起
收起工具栏
轩辕镜像 官方专业版
轩辕镜像 官方专业版轩辕镜像 官方专业版官方专业版
首页个人中心搜索镜像

交易
充值流量我的订单
工具
提交工单镜像收录一键安装
Npm 源Pip 源Homebrew 源
帮助
常见问题
其他
关于我们网站地图

官方QQ群: 1072982923

domjudge/domjudge-contributor Docker 镜像 - 轩辕镜像

domjudge-contributor
domjudge/domjudge-contributor
domjudge
DOMjudge贡献者镜像,为DOMjudge项目贡献者提供开发、测试及构建环境,支持参与项目开发与维护。
2 收藏0 次下载
🙃 代码没问题,结果发布失败在拉镜像
中文简介版本下载
🙃 代码没问题,结果发布失败在拉镜像

DOMjudge 贡献者 Docker 镜像

镜像概述和主要用途

该镜像适用于希望为 DOMjudge 项目做贡献但不想配置完整安装环境的开发者。它提供了一个预配置的开发环境,使贡献者能够专注于代码开发而非环境配置。

核心功能和特性

包含组件
  • 自动安装脚本,可:
    • 从挂载卷设置 DOMjudge 维护者安装环境
    • 设置或更新数据库
    • 配置 Web 服务器
    • 创建 chroot 环境
  • PHP-FPM 和 Nginx,用于运行 Web 界面
  • 两个使用 chroot 的运行中的 judgedaemon
  • Web 服务器和 judgedaemon 日志文件读取脚本
  • 创建虚拟 DOMjudge 用户并提交所有测试提交的脚本
  • 启用和禁用 Xdebug 的脚本
不包含组件
  • MySQL / MariaDB:推荐使用官方 MariaDB Docker 容器
  • DOMjudge 源代码:需要在目标机器上克隆 DOMjudge 仓库 并创建相应的卷挂载

使用场景和适用范围

该镜像专为 DOMjudge 项目贡献者设计,适用于:

  • DOMjudge 核心功能开发
  • 新特性测试和验证
  • 问题调试和修复
  • 本地开发和测试环境搭建

详细的使用方法和配置说明

镜像获取

该镜像可在 Docker Hub 获取,镜像名称为 domjudge/domjudge-contributor。

前置准备
1. 启动 MariaDB 容器

在启动 DOMjudge 容器前,需要准备 MySQL / MariaDB 数据库。最简单的方法是使用 MariaDB Docker 容器:

bash
docker run -it --name dj-mariadb -e MYSQL_ROOT_PASSWORD=rootpw -e MYSQL_USER=domjudge -e MYSQL_PASSWORD=djpw -e MYSQL_DATABASE=domjudge -p ***:3306 mariadb --max-connections=1000

此命令会启动一个 MariaDB 容器,设置:

  • root 密码为 rootpw
  • 创建名为 domjudge 的用户,密码为 djpw
  • 创建名为 domjudge 的空数据库
  • 在本地机器的 *** 端口暴露服务

若需在容器删除后保留 MySQL 数据,请参考 MariaDB Docker Hub 页面的说明。

2. 启用 cgroups(仅 Linux)

Linux 用户需要确保启用了 cgroups。具体设置方法请参考 DOMjudge 文档中关于 judgehost 配置的部分。Windows 和 macOS 上的 Docker 已在其 Linux 虚拟机中预设了这些选项。

运行 DOMjudge 容器
bash
docker run -v [本地DOMjudge代码路径]:/domjudge -v /sys/fs/cgroup:/sys/fs/cgroup:ro --link dj-mariadb:mariadb -it -e MYSQL_HOST=mariadb -e MYSQL_USER=domjudge -e MYSQL_DATABASE=domjudge -e MYSQL_PASSWORD=djpw -e MYSQL_ROOT_PASSWORD=rootpw -p ***:80 --name domjudge --privileged domjudge/domjudge-contributor

参数说明:

  • 将 [本地DOMjudge代码路径] 替换为你本地克隆的 DOMjudge 仓库路径
  • 在最新的 macOS 和 Windows Docker 版本上,建议在 /domjudge 卷后添加 :cached 参数以提高 Web 服务器性能,如:-v [本地DOMjudge代码路径]:/domjudge:cached

容器启动后,会自动设置 DOMjudge 维护者安装环境、配置数据库、创建 chroot 环境,然后启动 nginx、PHP-FPM 和两个 judgedaemon。

访问 Web 界面

Web 界面可通过 http://localhost:***/ 访问。使用用户名 admin 和 etc/initial_admin_password.secret 文件中的密码登录。

注意:DOMjudge 6.0.0 及以上版本的 Web 服务器配置默认使用调试前端控制器。

加载示例数据

默认不加载示例数据,可通过以下命令手动加载:

bash
bin/dj_setup_database install-examples
环境变量

容器支持以下环境变量:

环境变量默认值说明
CONTAINER_TIMEZONEEurope/Amsterdam容器内时区设置
MYSQL_HOSTmariadbMySQL 主机地址
MYSQL_USERdomjudgeMySQL 用户名
MYSQL_PASSWORDdomjudgeMySQL 用户密码
MYSQL_ROOT_PASSWORDdomjudgeMySQL root 用户密码
MYSQL_DATABASEdomjudge数据库名称
FPM_MAX_CHILDREN40PHP FPM 最大子进程数
DJ_SKIP_MAKE0设置为 1 可跳过维护者安装和编译命令,加快容器启动速度
通过文件设置密码

为避免通过环境变量传递敏感信息,可使用 MYSQL_PASSWORD_FILE 和 MYSQL_ROOT_PASSWORD_FILE 变量指定包含密码的文件路径。这适用于与 Docker Compose 的 secrets 功能配合使用:

yaml
services:
    domjudge-contributor:
        image: domjudge/domjudge-contributor:${DOMJUDGE_VERSION}
        secrets:
            - domjudge-mysql-pw
        environment:
            MYSQL_PASSWORD_FILE: /run/secrets/domjudge-mysql-pw
可用命令

可通过以下语法在容器内执行命令:

bash
docker exec -it domjudge [command]
日志查看命令
  • nginx-access-log: 查看 nginx 访问日志
  • nginx-error-log: 查看 nginx 错误日志
  • judgedaemon-log 0 和 judgedaemon-log 1: 查看第一个/第二个 judgeaemon 的日志
  • symfony-log: 查看 Symfony 日志(适用于 DOMjudge 6.x 及以上版本)
开发辅助命令
  • submit-test-programs: 提交所有测试程序(在 DOMjudge 安装的 tests 目录中执行 make check test-stress),会自动创建 dummy 用户,密码为 dummy
  • xdebug-enable: 启用 Xdebug 调试
  • xdebug-disable: 禁用 Xdebug 调试
服务管理

获取 bash shell:

bash
docker exec -it domjudge bash

重启服务:

bash
docker exec -it domjudge supervisorctl restart [service]

其中 [service] 可以是 nginx、php、judgedaemon0 或 judgedaemon1。

Xdebug 配置

Xdebug 默认未启用,因为它会显著降低请求处理速度。可通过以下命令启用和禁用:

bash
docker exec -it domjudge xdebug-enable
docker exec -it domjudge xdebug-disable

Xdebug 配置如下:

  • xdebug.remote_autostart=1: 无需设置 cookie 或 GET 参数即可启动调试
  • xdebug.remote_enable=1: 启用远程调试
  • xdebug.remote_host=host.docker.internal: 连接到 Docker 主机进行调试
  • xdebug.idekey=IDE: IDE 密钥,需在 IDE 中设置相同的值
访问评测结果

由于 chroot 脚本会将一些特殊设备复制到每个用于评测的 chroot 中,而 Docker 不支持在卷上使用这些特殊设备,因此为 /domjudge/output/judgings 创建了绑定挂载。要访问此目录内容,需通过以下命令进入容器:

bash
docker exec -it domjudge bash

然后导航到该目录。

Docker Compose 部署示例

创建 docker-compose.yml 文件:

yaml
version: '3'

services:
  mariadb:
    image: mariadb
    container_name: dj-mariadb
    environment:
      MYSQL_ROOT_PASSWORD: rootpw
      MYSQL_USER: domjudge
      MYSQL_PASSWORD: djpw
      MYSQL_DATABASE: domjudge
    ports:
      - "***:3306"
    command: --max-connections=1000
    restart: unless-stopped

  domjudge:
    image: domjudge/domjudge-contributor
    container_name: domjudge
    volumes:
      - [本地DOMjudge代码路径]:/domjudge
      - /sys/fs/cgroup:/sys/fs/cgroup:ro
    environment:
      MYSQL_HOST: mariadb
      MYSQL_USER: domjudge
      MYSQL_PASSWORD: djpw
      MYSQL_ROOT_PASSWORD: rootpw
      MYSQL_DATABASE: domjudge
    ports:
      - "***:80"
    privileged: true
    depends_on:
      - mariadb
    restart: unless-stopped

启动服务:

bash
docker-compose up -d

镜像源代码

该镜像的源代码可在 domjudge-packaging GitHub 项目 中找到。

查看更多 domjudge-contributor 相关镜像 →
domjudge/gitlabci logo
domjudge/gitlabci
暂无描述
100K+ pulls
上次更新:未知
domjudge/domserver logo
domjudge/domserver
DOMjudge服务器镜像,与judgehost镜像配合使用,用于通过Docker部署DOMjudge在线判题系统,提供竞赛管理、题目提交和判题结果展示的Web界面及后台服务。
14100K+ pulls
上次更新:未知
domjudge/judgehost logo
domjudge/judgehost
DOMjudge server镜像,与judgehost镜像配合使用,通过Docker运行DOMjudge编程竞赛评判系统,需搭配MariaDB数据库,提供竞赛管理、题目提交和自动评判功能。
950K+ pulls
上次更新:未知

轩辕镜像配置手册

探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式

登录仓库拉取

通过 Docker 登录认证访问私有仓库

Linux

在 Linux 系统配置镜像服务

Windows/Mac

在 Docker Desktop 配置镜像

Docker Compose

Docker Compose 项目配置

K8s Containerd

Kubernetes 集群配置 Containerd

K3s

K3s 轻量级 Kubernetes 镜像加速

Dev Containers

VS Code Dev Containers 配置

MacOS OrbStack

MacOS OrbStack 容器配置

宝塔面板

在宝塔面板一键配置镜像

群晖

Synology 群晖 NAS 配置

飞牛

飞牛 fnOS 系统配置镜像

极空间

极空间 NAS 系统配置服务

爱快路由

爱快 iKuai 路由系统配置

绿联

绿联 NAS 系统配置镜像

威联通

QNAP 威联通 NAS 配置

Podman

Podman 容器引擎配置

Singularity/Apptainer

HPC 科学计算容器配置

其他仓库配置

ghcr、Quay、nvcr 等镜像仓库

专属域名拉取

无需登录使用专属域名

需要其他帮助?请查看我们的 常见问题Docker 镜像访问常见问题解答 或 提交工单

镜像拉取常见问题

轩辕镜像免费版与专业版有什么区别?

免费版仅支持 Docker Hub 访问,不承诺可用性和速度;专业版支持更多镜像源,保证可用性和稳定速度,提供优先客服响应。

轩辕镜像支持哪些镜像仓库?

专业版支持 docker.io、gcr.io、ghcr.io、registry.k8s.io、nvcr.io、quay.io、mcr.microsoft.com、docker.elastic.co 等;免费版仅支持 docker.io。

流量耗尽错误提示

当返回 402 Payment Required 错误时,表示流量已耗尽,需要充值流量包以恢复服务。

410 错误问题

通常由 Docker 版本过低导致,需要升级到 20.x 或更高版本以支持 V2 协议。

manifest unknown 错误

先检查 Docker 版本,版本过低则升级;版本正常则验证镜像信息是否正确。

镜像拉取成功后,如何去掉轩辕镜像域名前缀?

使用 docker tag 命令为镜像打上新标签,去掉域名前缀,使镜像名称更简洁。

查看全部问题→

用户好评

来自真实用户的反馈,见证轩辕镜像的优质服务

用户头像

oldzhang

运维工程师

Linux服务器

5

"Docker访问体验非常流畅,大镜像也能快速完成下载。"

轩辕镜像
镜像详情
...
domjudge/domjudge-contributor
官方博客Docker 镜像使用技巧与技术博客
热门镜像查看热门 Docker 镜像推荐
一键安装一键安装 Docker 并配置镜像源
咨询镜像拉取问题请 提交工单,官方技术交流群:1072982923
轩辕镜像面向开发者与科研用户,提供开源镜像的搜索和访问支持。所有镜像均来源于原始仓库,本站不存储、不修改、不传播任何镜像内容。
咨询镜像拉取问题请提交工单,官方技术交流群:
轩辕镜像面向开发者与科研用户,提供开源镜像的搜索和访问支持。所有镜像均来源于原始仓库,本站不存储、不修改、不传播任何镜像内容。
官方邮箱:点击复制邮箱
©2024-2026 源码跳动
官方邮箱:点击复制邮箱Copyright © 2024-2026 杭州源码跳动科技有限公司. All rights reserved.