采用的是前端Vue和后端DataBackup在本地部署
JudgeServer判题服务、GoJudge判题机、数据库和Nacos在云服务器部署
Redis在虚拟机部署(可在本地,可在服务器)
项目拉取地址:
https://gitee.com/himitzh0730/hoj.git
包结构解读:
hoj-vue包为项目前端Vue
sandbox包为沙箱判题机,使用的是go-judge
sqlAndsetting包为数据库文件和nacos配置文件
Nacos部署在本地会出现一系列问题,后面会将nacos部署在云服务器,操作过程类似
运行nacos.sql文件创建好naos数据库后,在数据库的users表中修改nacos的用户名和密码,由于nacos密码为加密后的密码,下面给出字符串“nacos”的加密后对应的字符串
$2a$10$EuWPZHzz32dJN7jexM34MOeYirDdFAZm2kuWj7VEOJhhZkDrxfvUu
修改nacos的配置文件,在conf文件夹内的application.properties里解开对应行的注释
配置完成后访问点击Console连接,按住Ctrl可以点击进去,账号密码均为nacos。
出现以上内容为配置成功
修改application-prod.yml中的judge-token。将nacos中的judge-token配置copy到application-prod.yml中,否则会自动生成
不修改会出现上传题目错误
出现以下信息为启动成功
https://nodejs.org/zh-cn/download/
查看node.js版本
node -v
1)npm项目依赖组件安装
cmd进入前端vue项目的根目录(hoj/hoj-vue),输入命令
cnpm install
会根据前端项目的依赖关系下载好相关的组件,存在项目目录的node_modules文件夹下。
注意:一般git库会gitignore依赖组件,没有node_modules文件夹,这个文件夹太大,一般不push
2)npm项目编译
第一次启动需要编译,后续再启动,只需要进行第三步启动项目
cmd进入前端vue项目的根目录(hoj/hoj-vue),输入命令
npm run build
此时会对根目录下的package.json对build命令的定义进行编译,一般"build" = “webpack -p”。
3)启动项目:
cmd进入前端vue项目的根目录(hoj/hoj-vue),输入命令
npm run serve
出现以上内容,为启动成功
注意使用校园网的话,Xshell会连不上的云服务器的,校园网屏蔽了一系列端口,包括20端口。
使用校园网可以将20端口改成别的。使用宝塔或VNC连接没问题
sudo apt-get update
sudo apt-get install yum
cd /usr/local/
#下载安装包
wget https://studygolang.com/dl/golang/go1.14.1.linux-amd64.tar.gz
#解压安装包
tar -zxvf go1.14.1.linux-amd64.tar.gz
#建立工作目录
mkdir -p /home/go/bin /home/go/pkg /home/go/src
配置环境变量:
#打开配置
vi /etc/profile
#在最下面添加
export GOROOT=/usr/local/go
export GOPATH=/home/go
export PATH=$PATH:$GOROOT/bin:$GOPATH/bin
#保存退出
:wq
#配置生效
source /etc/profile
#查看Go版本
go version
#查看配置
go env
sudo apt-get update
sudo apt-get install \
apt-transport-https \
ca-certificates \
curl \
gnupg \
lsb-release
curl -fsSL https://mirrors.aliyun.com/docker-ce/linux/ubuntu/gpg | sudo gpg --dearmor -o /usr/share/keyrings/docker-archive-keyring.gpg
echo \
"deb [arch=amd64 signed-by=/usr/share/keyrings/docker-archive-keyring.gpg] https://mirrors.aliyun.com/docker-ce/linux/ubuntu \
$(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null
sudo apt-get update
sudo apt-get install docker-ce docker-ce-cli containerd.io
sudo apt-get install git
sudo apt-get update
git clone https://github.com/criyle/go-judge.git
docker build -f ./Dockerfile.exec -t go-Judge
docker run -d -it --rm --privileged --shm-size=256m -p 5050:5050 -p 5051:5051 criyle/executorserver -enable-grpc
查看进程是否存在
netstat -anp | grep 5050
netstat -anp | grep 5051
查看容器名
docker ps
进入容器
docker exec -it [容器名] /bin/bash
容器内安装gcc/g++ 编译环境
# 更新安装 apt
apt-get update
apt update
apt install gcc
apt install g++
把JudgeServer部署在本地会出现一系列问题:
题目上传到本地testcase文件夹里 而判题要在服务器里读testcase里的测试数据,路径不一致。
解决方案就是:将JudgeServer和GoJudge都部署在云服务器
先修改SandBoxRun中的SANBOX_BASE_URL
sudo apt install openjdk-8-jre-headless
sudo apt install openjdk-8-jdk-headless
输入:java,javac 检验是否安装成功
vim /etc/profile
进入后在文件末尾添加以下内容
export JAVA_HOME=/usr/lib/jvm/java-8-openjdk-amd64
export JRE_HOME=${JAVA_HOME}/jre
export CLASSPATH=.:${JAVA_HOME}/lib:${JRE_HOME}/lib
export PATH=.:${JAVA_HOME}/bin:$PATH
source /etc/profile
重新加载配置文件
1)使用Maven工具进行打包,打包前进行clean,后点击package
打包过程中会出现
Failed to execute goal org.springframework.boot:spring-boot-maven-plugin:3.0.5:
repackage (default) on project hoj-judgeServer:
Execution default of goal
org.springframework.boot:spring-boot-maven-plugin:3.0.5:
repackage failed: Unable to load the mojo 'repackage'
in the plugin 'org.springframework.boot:spring-boot-maven-plugin:3.0.5' due to an API incompatibility:
org.codehaus.plexus.component.repository.exception.ComponentLookupException:
org/springframework/boot/maven/RepackageMojo has been compiled by
a more recent version of the Java Runtime (class file version 61.0),
this version of the Java Runtime only recognizes class file versions up to 52.0
这样一个错误,原因是:在spring-boot-maven-plugin:3.0.0-M1这个版本中没有goal这个api了
所以在pom.xml中添加spring-boot-maven-plugin的版本号即可
2.3.3.RELEASE
2)在需要部署判题服务的云服务器上创建文件夹来存储jar包和沙盒文件,同时还要判题过程中需要的文件夹
# 存放jar包与安全判题沙盒的目录
mkdir -p /hoj/server
# 存放用户提交的源代码
mkdir -p /hoj/run
# 存放题目的特殊判题源代码
mkdir -p /hoj/spj
# 判题过程中的日志文件夹
mkdir -p /hoj/log
# 存放题目的测试数据
mkdir -p /hoj/testcase
将打好的jar包放在/hoj/server
使用宝塔Java项目一键部署工具进行部署
自定义参数 --server.port=8088的前面要添加一个空格
要不然系统以为我们要运行的文件是xxx.jar–server.port=xxx 而不是 xxx.jar
(我们运行jar会执行java-jar xxx.jar --server.port=xxxx)
如果将Nacos部署在本地,DataBackup部署在本地。JudgeServer和GoJudge部署在云服务器。会导致JudgeServer无法访问私有ip的nacos,所以将nacos也需要部署在云服务器。
1)宝塔的docker拉取镜像和创建容器很方便,从仓库中拉取镜像,输入镜像名后自动拉取到本地
跟本地镜像添加容器就可以了
由于我的服务器内容很小,如果在创建容器的时候不限制内存,守护线程oom killer杀掉了nacos线程。
所以一定在添加容器的时候限制内容!!!
docker run --name nacos-standalone -e MODE=standalone -e JVM_XMS=64m -e JVM_XMX=64m -e JVM_XMN=16m -p 8848:8848 -d nacos/nacos-server
2)利用Navicat连接云服务器的数据库,导入nacos.sql和hoj.sql
连接云服务器可能会出现一直连接不上的情况,大多是因为root的登录权限不够,只限于本地登录,不可远程访问, 更改ip登录权限
mysql -u root -p
use mysql;
select user,host from user;
# 查看自己root对应的host字段值是否是“%”,默认一般是localhost,则需要将localhost改为%,输入下面mysql指令更改:
update user set host = "%" where user = "root";
flush privileges;
3)修改nacos中users表的登录信息
4)修改nacos的配置文件
与本地部署类似,不再赘述。
1)重启的时候注意要把项目中的所有**@Value(“${hoj.judge.token}”)**注释掉,否则读取不到(可以通过debug的方式找到所有)。
2)启动成功后,访问部署在云服务器的Nacos控制台,会出现以下配置
修改application-prod.yml中的judge-token。将nacos中的judge-token配置copy到application-prod.yml中,否则会自动生成