转自:http://369369.blog.51cto.com/319630/787723

Mantis迁移实录




名词解释
Mantis:  开源的BUG管理平台Mantis,也做MantisBT。
          同档次产品有EasyBUG,QC,BugFree,Bugzila。
Xampp:   原名叫LAMPP。windows,linux下apache,mysql,php,perl集成安装包。
          同档次产品有EasyPHP。
虚拟中心:用VM esxi4.1搭建。
          同档次的产品有KVM,XEN,HV。

前言
    因为公司软件测试部mantis服务器放在一台pc机上,集团的电力又不稳定,经常掉电,造成pc服务器,老是重起,所以应他们强烈要求,把pc上的mantis迁移至机房的服务器上,机房的服务器接了ups,相对会好很多,一个mantis简单应用,要用一个至强服务器,那太牵强了,所以计划把它架设到虚拟平台里,最开始想把目前的mantis迁移至linux下,后来发现迁移至linux下,全乱码,是mysql字符集的问题,调了许多,也没调好,所以还是把它迁移至windows 2003算了,PHP环境就用xampp。
Xampp下载
    百度了一下,找到官网www.apachefriends.org,简单看了下介绍,下载windows版本的xampp,,目前版本是1.7.7,本人下的是installer安装版,具体地址为:http://www.apachefriends.org/download.php?xampp-win32-1.7.7-VC9-installer.exe
    如果喜欢绿色版的朋友,请下载zip或7zip版,选择哪个版本都无所谓,关键是在有限的时间内完成任务,就是好的工作方法。
 

安装XAMPP
     双击xampp-win32-1.7.7-VC9-installer.exe,一路点next就行了,其中有提示安装apache,mysql等为系统服务(as service),我是打勾的。
 

解决apache无法启动
     安装完毕,发现apache报错,无法起来,点“start”,提示“Busy…”。只能百度了,第一次用这个XAMPP。到网上找了找,都说是80或443端口被占用了,所以要修改apache的监听端口,我在DOS下输入netstat –ant查了下,这两个端口没有被占用,不得其解,又百度之,终于在一个网友的博客上找到了解决办法。原因是windows 2003缺少Microsoft.VC90.CRT,所以去下载一个Microsoft Visual C++ 2008 Redistributable,把它装上,点“start”按钮,发现apache已正常起来了,问题解决。软件下载地址为:http://download.microsoft.com/download/9/7/7/977B481A-7BA6-4E30-AC40-ED51EB2028F2/vcredist_x86.exe。这个错误,其实可以看windows的事件查看器,就可以知道。

备份老环境的mantis数据库,mantis程序目录
查看原平台mantis业务配置文件(config_inc.php)是怎么连接数据库的

在老平台上把mantis数据库备份出来
    C:\xampp\mysql\bin\mysqldump –uroot –pmttang mantis >c:\mantis0223.sql。把mantis程序目录打成zip包,并把mantis0223.sql和mantis.zip拷贝到新服务器上。

在新平台上修改配置文件
在新服务器上建立mysql库c:\xampp\mysql\bin\mysql –uroot
Mysql>create database mantis;     //创建mantis库
Mysql>show databases;           //查看一下
 
在新平台把数据库恢复
Mysql>use mantis;
Mysql>source c:\mantis0223.sql;
Mysql>show tables;


表都过来了,恢复正常。
修改新平台的mysql数据库root密码为XXXXXX
C:\xampp\mysql\bin\mysqladmin –uroot password xxxxxx
    修改apache配置文件,把c:\mantis站点包含至apache中,在httpd.conf最后添加mantis别名。
 

打开浏览器,测试一下192.168.133.200,报403禁止访问

    修改apache目录下的扩展目录extra下的httpd-xampp.conf文件,把“Deny from all”用“#”注释掉,总共有三处。


在浏览器中输入mantis的地址,看页面正常不?

http://192.168.133.200/mantis

完成

给开发部测试组同事发邮件,启用新平台的mantis业务。