感觉去各大oj上刷题有点麻烦,搭建一个oj感觉没有那个需要,考虑到virtual judge的方便,准备搭建一个个人vjudge,网上的资料不多,泛滥的大量博文中,信息相当杂,精品相当少 大多数都是转载来转载去,内容相同还没有营养,搭建Vjudge方面的博文更是稀少,但是最后还是折腾出来了.
1. 前期准备工作
1.1 一个Linux系统
因为现场赛的缘故,我一直使用的都是乌邦图。
这里我测试用的是ubuntu14.04 Desktop 64bit ,当然选择Server会更好一些.
系统的安装不再赘述,作为服务器请选用Server版本。
1.2 更新源及其他
在搭建环境之前,请确保你的源是有效的,速度是给力的,
建议选择一个国内的源14.04 LTS 更新源
sudo gedit /etc/apt/sources.list 将原来的源覆盖并保存 最后执行 sudo apt-get update sudo apt-get upgrade
1.3 必要文件准备
我们需要下载这几个文件(部分链接需要翻墙才能访问):
<span class="lit">1</span><span class="pun">.*.</span><span class="pln">sql https</span><span class="pun">:</span><span class="com">//gist.github.com/trcnkq/a3cf7004759d41d79eb7</span>
<span class="lit">2</span><span class="pun">.</span><span class="pln">http_client</span><span class="pun">.</span><span class="pln">json https</span><span class="pun">:</span><span class="com">//gist.github.com/trcnkq/7a5deff639ff99475138</span>
<span class="lit">3</span><span class="pun">.</span><span class="pln">remote_accounts</span><span class="pun">.</span><span class="pln">json https</span><span class="pun">:</span><span class="com">//gist.github.com/trcnkq/e9dac7eea72d2b781949</span>
<span class="lit">4</span><span class="pun">.</span><span class="kwd">virtual</span><span class="pln"> judge</span><span class="pun">源文件</span><span class="pln"> https</span><span class="pun">:</span><span class="com">//github.com/trcnkq/virtual-judge</span>
如果无法翻墙或者链接失效,请用我的百度云链接: Vjudge搭建 (这里面包含了之后会用到的一系列文件,嫌麻烦可以都下载下来)
1.4 先决环境搭建(针对新手)
sudo apt-get install gcc sudo apt-get install cpp sudo apt-get install make //以上是为了能正常make sudo apt-get install vsftpd //安装ftp方便本地上传某些脚本,配置方法百度一下一大把 sudo apt-get install git //git clone 大家都懂 sudo apt-get install vim //编辑器
2. 必要环境搭建
2.1 Mysql的安装
sudo apt-get install mysql-server -y 安装过程中会要求你输入数据库的密码,这里我直接用的123456,连续输入两次即可。 进入数据库测试一下 mysql -u root -p
mysql -u root -p create database vhoj; exit;
2.1.0 额外配置
//以下内容根据需要安装(crontab定时备份数据库并发送到邮箱): //mysqldump应该在安装mysql的时候一并安装了,请查看/usr/bin/mysqldump sudo mkdir /home/backup //存放备份文件 //邮件发送配置 sudo apt-get -y install msmtp sudo apt-get install mutt //建立配置文件 具体配置请查看我的另外一篇文章 [链接](http://jingwei.site/msmtp-mutt/)
touch mysql_databak.sh //创建备份文件 sudo vim mysql_databak.sh //脚本内容
#!/bin/sh DUMP=/usr/bin/mysqldump OUT_DIR=/home/backup LINUX_USER=root DB_NAME=vhoj DB_USER=root DB_PASS=123456 DAYS=7 cd $OUT_DIR DATE=`date +%Y%m%d%H%M` OUT_SQL=$DATE.sql TAR_SQL="mysqldata_bak_$DATE.tar.gz" $DUMP -u$DB_USER -p$DB_PASS $DB_NAME --default-character-set=gbk --opt -Q -R --skip-lock-tables>$OUT_SQL tar -czf $TAR_SQL ./$OUT_SQL rm $OUT_SQL chown $LINUX_USER:$LINUX_USER $OUT_DIR/$TAR_SQL find $OUT_DIR -name "mysqldata_bak*" -type f -mtime +$DAYS -exec rm {} ; /usr/bin/mutt -s "Backup file for database." 123456789@qq.com -a $OUT_DIR/$TAR_SQL <$OUT_DIR/mysql_datamail.txt 代码解释: #!/bin/sh DUMP=/usr/bin/mysqldump #mysqldump备份程序执行路径 OUT_DIR=/home/mysql_data #备份文件存放路径 LINUX_USER=root #系统用户名 DB_NAME=jqg2 #要备份的数据库名字 DB_USER=root #数据库账号 注意:非root用户要使用备份参数 --skip-lock-tables,否则可能会报错 DB_PASS=123456 #数据库密码 DAYS=7 #DAYS=7代表要删除7天前的备份,即只保留最近7天的备份 cd $OUT_DIR #进入备份存放的目录 DATE=`date +%Y%m%d%H%M` #获取当前系统的时间,注意:date写法 OUT_SQL=$DATE.sql #备份数据库的文件名 TAR_SQL="mysqldata_bak_$DATE.tar.gz" #最终保存的数据库备份文件名 $DUMP -u$DB_USER -p$DB_PASS $DB_NAME --default-character-set=gbk --opt -Q -R --skip-lock-tables>$OUT_SQL #执行备份命令 tar -czf $TAR_SQL ./$OUT_SQL #压缩为备份数据库文件为.tar.gz格式 rm $OUT_SQL #删除.sql格式的备份文件 chown $LINUX_USER:$LINUX_USER $OUT_DIR/$TAR_SQL #更改备份数据库文件的所有者 find $OUT_DIR -name "mysqldata_bak*" -type f -mtime +$DAYS -exec rm {} ; #删除7天前的备份文件,注意:{} ;中间有空格:wq 保存退出 /usr/bin/mutt -s "Backup file for database." 123456789@qq.com -a $OUT_DIR/$TAR_SQL <$OUT_DIR/mysql_datamail.txt 用mutt发送到你自己的邮箱
//修改文件属性,使其可执行 sudo chmod +x /home/mysql_data/mysql_databak.sh 安装crontab并配置脚本自动执行:[链接](http://jingwei.site/%e5%9c%a8ubuntu-14-04%e4%bd%bf%e7%94%a8cron%e5%ae%9e%e7%8e%b0%e4%bd%9c%e4%b8%9a%e8%87%aa%e5%8a%a8%e5%8c%96/)
2.2 Redis的安装和配置
1.) 下载安装Redis: wget http://download.redis.io/releases/redis-2.8.9.tar.gz tar xvzf redis-2.8.9.tar.gz cd redis-2.8.9/ make //建议make test,在make test之前sudo sudo make install 2.) 配置init脚本: wget https://github.com/ijonas/dotfiles/raw/master/etc/init.d/redis-server wget https://github.com/ijonas/dotfiles/raw/master/etc/redis.conf sudo mv redis-server /etc/init.d/redis-server sudo chmod +x /etc/init.d/redis-server sudo mv redis.conf /etc/redis.conf 3.) 初始化用户和日志路径 第一次启动Redis前,建议为Redis单独建立一个用户,并新建data和日志文件夹 sudo useradd redis sudo mkdir -p /var/lib/redis sudo mkdir -p /var/log/redis sudo chown redis.redis /var/lib/redis sudo chown redis.redis /var/log/redis 4.) 设置开机自动启动,关机自动关闭 update-rc.d redis-server defaults 5.) 启动Redis: /etc/init.d/redis-server start
2.3 Maven3的安装和配置
1.) 通过apt-get安装Maven3 ubuntu12.04之后,可直接用apt-get来获得 sudo apt-get install maven -y
安装完后,sudo su 进入root
用 mvn –v 查看一下Maven的版本,如下图:
因为Maven3安装的同时把openjdk也一并安装了。
2.3.1 JDK的安装和配置
首先需要下载JDK,地址:https://jdk7.java.net/download.html (之前的云盘链接内有64位的,请认准这个jdk版本)
注意系统是32位还是64位
<span class="lit">1.</span><span class="pun">)</span> <span class="pun">解压下载的文件</span>
tar -xzvf jdk1.7.0_80
2.) 移动文件夹到指定目录下
sudo mkdir /usr/lib/jvm sudo mv jdk1.7.0_80/ /usr/lib/jvm/
3.) 设置环境变量
sudo vi /etc/profile //在本篇文章中,建议用vi或者vim编辑文档,用gedit会报错(虽然好像没什么影响...)
在文件最后加入如下内容:
export JAVA_HOME=/usr/lib/jvm/jdk1.7.0_80 export JRE_HOME=${JAVA_HOME}/jre export CLASSPATH=.:${JAVA_HOME}/lib:${JRE_HOME}/lib export PATH=${JAVA_HOME}/bin:$PATH
4.) 使修改生效:
sudo source /etc/profile //如果提示source command not found //请执行以下两步: //sudo -s //source /etc/profile
这时候在终端输入 java –version 查看当前 JDK 版本
至此,JDK 配置完成
2.) 修改系统默认的jdk update-alternatives --install /usr/bin/java java /usr/lib/jvm/jdk1.7.0_80/bin/java 300 update-alternatives --install /usr/bin/javac javac /usr/lib/jvm/jdk1.7.0_80/bin/javac 300 update-alternatives --config java //请选择jdk1.7.0_80版本的jdk update-alternatives --config javac
使用java -version或者mvn -v再次查看,JDK版本已更改
2.4
2.4 Tomcat7的安装和配置
1.) apt-get安装tomcat7: sudo apt-get install tomcat7 -y tomcat7默认会被安装在目录/var/lib/tomcat7/下, 安装完之后在浏览器下输入localhost:8080查看是否安装成功 如果出现下图,即为安装成功
2.) 安装tomcat7-admin 安装成后,我们还需要安装一个tomcat7-admin sudo apt-get install tomcat7-admin
3.) 修改账户: 安装完毕之后,我们进入tomcat7的conf目录下修改tomcat-users.xml文件 cd /var/lib/tomcat7/conf/ vim tomcat-users.xml 我这里用的是 <role rolename="manager-gui"/> <role rolename="admin-gui"/> <user username="tomcat" password="tomcat" roles="manager-gui,admin-gui"/>
4.) 重启tomcat: sudo /etc/init.d/tomcat7 restart
重新在浏览器打开tomcat界面
点击manager webapp,用刚才我们建立的用户登陆
<span class="lit">5.</span><span class="pun">)</span> <span class="pun">修改</span><span class="pln">JDK</span><span class="pun">默认的</span><span class="pln">JDK</span><span class="pun">版本</span>
<span class="pun">检查</span><span class="pln"> tomcat7 </span><span class="pun">的</span> <span class="typ">Server</span> <span class="typ">Information</span><span class="pun">,版本可能不是我们自己的</span><span class="pln">jdk</span><span class="pun">版本。</span>
<span class="pun">这里我们要修改</span><span class="pln">tomcat</span><span class="pun">使用的</span><span class="pln">JDK</span><span class="pun">版本,这步很重要,否则会出现很多问题</span>
sudo gedit /etc/default/tomcat7 加入如下内容: JAVA_HOME=/usr/lib/jvm/jdk1.7.0_80 再次重启tomcat7: sudo /etc/init.d/tomcat7 restart
OK, tomcat7的JDK版本修改完毕。
至此,搭建 Virtual Judge 所需的所有环境,都已搭建完毕!
3. 工程代码实施
准备好四个文件,就是一开始下载的那四个:
3.1 Vjudge的打包
进入virtual-judge-master 目录: cd virtual-judge-master/ 用 Maven 将 Virtual Judge 打包: mvn clean package
里面会有一个vjudge.war文件,就是我们打包完成的 Virtual Judge。
把这个war文件拷到tomcat7的webapps目录下。
打包的过程可能会相当长,特别是网络不好的情况下,万一掉包了,非常蛋疼,如果你不想等待太久,可以直接下载此文件,在文章开头的百度云网盘链接里.
放到webapps目录后,会自动生成一个vjudge文件夹,如果没有生成,你也可以自行解压。
3.2 remote_accounts.json文件的编辑
把各个OJ的提交账号添加到remote_accounts.json里。
3.3 config.properties文件的编辑
如不需要代理或VPN访问国外OJ,保留http_client.json里面的[“direct”]即可。
3.4 vjudge的简单部署
把 remote_accounts.json 和 http_client.json 两个文件放在指定的文件夹下
这里我放在 /var/lib/tomcat7/webapps/vjudge/ 目录下
sudo mv http_client.json /var/lib/tomcat7/webapps/vjudge/ sudo mv remote_accounts.json /var/lib/tomcat7/webapps/vjudge/
更改/webapps/vjudge/WEB-INF/classes/的目录下config.properties文件
将remote_accounts.json和http_client.json的绝对路径改为正确的路径
cd /var/lib/tomcat7/webapps/vjudge/WEB-INF/classes/ sudo vim config.properties
PS:如果你的数据库密码不是123456,那么上面的root密码你也需要修改,默认为123456
3.5 vhoj数据库的导入
表vhoj_20141109.sql导入(可能我的版本略微旧了点)。
mysql -h localhost -u root -p vhoj < vhoj_20141109.sql
sudo /etc/init.d/tomcat7 restart
最后,重启tomcat7,进入manager
查看Application,可以看到vjudge已经处于running状态了。
4. 大功告成的Vjudge
在地址栏输入localhost:8080/vjudge,进入搭建成功的vjudge:
到此为止,Virtual Judge 终于搭建成功,just enjoy it!