zoukankan      html  css  js  c++  java
  • 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,出现该图:

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

  • 相关阅读:
    vr这么火我来看看there.js
    简明现代魔法博客图书馆之php学习记录
    ecshop学习记录
    mysql学习笔记
    linux服务器自动备份mysql数据库
    thinkphp分页及分页样式
    php手册学习(2)
    非常不错的ajax原理总结
    最全的HTTP头部信息分析
    利用curl并发来提高页面访问速度
  • 原文地址:https://www.cnblogs.com/youcong/p/10321800.html
Copyright © 2011-2022 走看看