OnlineJudgeServer运行

我在这如下这两篇文章都说过青岛OJ相关的

OnlineJudgeFE之前端二次开发

青岛大学开源OJ平台搭建

今天我还是要来讲讲关于这个青岛OJ。

青岛OJ采用的是完全的前后端分离架构。

OnlineJudgeFE相当于是前端,是使用Vue.js+webpack或gulp等打包的一个项目。

而今天所说的OnlineJudgeServer则是它的后端。

前端+后端分离的开发是当下的趋势。

后续我会写一篇关于前后端相关的文章,抱着个人想法+读过的书及其工作和学习上面的实践。

今天的主要话题是如何在本地搭建好Python的环境将青岛OJ的OnlineJudgeServer在windows上跑起来。

一、环境准备

Python3.7或者Python3.6

如果你原来安装Python2.7或者其他版本记得在对应的环境变量中删除。

关于Python安装就不多说了。

常见问题:

Pip命令找不到

一般配置环境变量

C:UserseluzhuAppDataLocalProgramsPythonPython37Scriptspip3.7.exe

如果环境变量无效,原因通常是因为(我个人遇到的)你在原有的用户变量中配置好之前的,通常将之前的python环境删除或者重新编辑成现在的即可。

从这里我们可以看到用户变量优于系统变量。

Django环境:

pip.exe install django

pip.exe install celery

pip.exe install raven

pip.exe install envelopes

其它相关库安装:

安装docker:

https://download.docker.com/win/stable/Docker%20for%20Windows%20Installer.exe

docker安装成功通常会在桌面有如下三个东西

pip.exe install djangorestframework

pip.exe install psycopg2

pip.exe install django==1.11.4

pip.exe install qrcode

pip.exe install otpauth

pip.exe install pillow

pip.exe install xlsxwriter

pip.exe install requests

pip.exe install django_redis

pip.exe install python-dateutil

pip.exe install jsonfield

pip.exe install docker-compose

二、执行环境和安装docker成功

双击运行它:

Docker成功的标志:

 

docker rm -f oj-postgres-dev oj-redis-dev

//通常如果存在oj-redis-dev就删除,不存在的话可以不用删除一般情况下,通过docker ps或者docker ps -a可以查看当前正在使用的容器或者所有容器。

docker run -it -d -e POSTGRES_DB=onlinejudge -e POSTGRES_USER=postgres -e POSTGRES_PASSWORD=1234 -p 127.0.0.1:5432:5432 --name oj-postgres-dev postgres:10

//启动并运行(包括拉取镜像)postgres容器

docker run -it -d -p 127.0.0.1:6380:6379 --name oj-redis-dev redis:4.0-alpine

//启动并运行(包括拉取镜像)redis容器

可能修改的地方:

修改的地方为如下(设置成该命令中的那样)

docker run -it -d -e POSTGRES_DB=onlinejudge -e POSTGRES_USER=postgres -e POSTGRES_PASSWORD=1234 -p 127.0.0.1:5432:5432 --name oj-postgres-dev postgres:10

//这个命令不用运行,之所以列举出来是为了说明为什么修改。:

还有一个secrey.key需要移到这

这个secrey.key可通过命令生成:

在linux上用随机数生成这个文件

echo `cat /dev/urandom | head -1 | md5sum | head -c 32` > data/config/secret.key

 

注意:如果该命令docker run -it -d -e POSTGRES_DB=onlinejudge -e POSTGRES_USER=postgres -e POSTGRES_PASSWORD=1234 -p 127.0.0.1:5432:5432 --name oj-postgres-dev postgres:10

       执行失败的话,请参考后面安装postgresql,手动建立postgresql数据库,库名为onlinejudge,这样问题即可迎刃而解。

三、运行

最后执行python manage.py runserver

出现如图,表示成功:

界面形式:

所需环境资源可以去该地址下载:

链接:https://pan.baidu.com/s/1h_8qIoGi9Cz7rVrqleQO4Q

提取码:bwib

基本下载的软件双击下一步下一步即可。

Postgresql如果要运行的话,参考如下:

最后会弹出这个:

如果要连接,请双击击PostgreSQL11,出现该图:

输入对应的密码即可,进入如下界面,表示成功:

原文地址:https://www.cnblogs.com/youcong/p/10321800.html