在CentOS上安装Bugzilla

hfight 2011-07-31

这几天一直在折腾Bugzilla,原以为应该挺简单的,却也是一波三折。下面是“被虐”的过程:

一、下载

由于不太习惯Linux的命令行下载方式,就先在本地的下载了当前最新的稳定版本Bugzilla3.6.1 ,然后通过scp上传到服务器上。解压至/usr/local/bugzilla。同时

在/var/www/html目录中创建一个symbolic link:

# ln -s /var/local/bugzilla bugzilla

为httpd的用户分配该文件夹的访问权限

# chown apache.apache -R bugzilla  

二、安装和配置

     注:以下操作都在root权限下完成。

     完成解压后,自然就按照官网上的指南 (以下称指南 ),一步步开始安装。

     1、之前Perl、MySQL、Apache Httpd都已经安装,并且版本符合要求。不过为了安全期间,还是运行了一下

     # yum install perl

     果真还是有不少内容更新。

     2、切换到/var/www/html/bugzilla下,检查环境配置:

     # ./checksetup.pl --check-modules

     很多没有安装的模块都列了出来,指南上说可以用下面的命令安装缺少的模块:

     # perl install-module.pl <modulename>

     但是运行上条命令是给出了更加简便的方式:

     # ./install-module.pl --all

     然后运行

     # ./checksetup.pl

     注意这次没有后面的--check-modules选项,至此一切还都是按照指南上的说明顺利进行。可是接下来就踏上了痛苦“旅程”。

     上面命令的运行结果并没有产生localconfig文件,而是提示有些模块仍然没有安装,尤其是DBD::mysql,还有几个可选的模块,GD、Chart、GDGraph等。当时就想,单独安装一下试试,于是:

      # ./install-module.pl GD

      没有成功,错误:

      Can't call method "cpan_version" on an undefined value at /usr/local/bugzilla/Bugzilla/Install/CPAN.pm line 96.

      第一反应当然就是去Google,可是搜到的结果只有区区四条,还有两个是一个页面。难道这个问题只有我碰到?难道别人都那么顺利?

把看起来关联程度最高的读完了,终于发现了一句话说是可能需要把之前的cpan删了,重新安装。有解决方案就行,试一下。就到root下面把.cpan目录删了。殊不知这下麻烦可大了。然后再次运行命令安装,从输出信息中看到需要安装cpan,可是死活连不上默认的两个ftp服务器,一直提示Connection:refused 。可是两个ftp在pc上访问都没有问题,顿时着急上火。怎么办?还是采用笨方法,先下载到本地,然后按照目录复制过去。实施起来才知道,这个想法太幼稚,cpan的目录结构虽然不太复杂,但是光下载文件,也要不断的时间,这个时间我可浪费不起。纠结呀!!

       (总不能在一棵树上吊死吧,还有Mantis可以用,转投Mantis,还真是好用,很快就装好了。虽然也有一点小插曲,是因为自己没有看清楚说明,填错了数据库的用户名密码。)

        一天后,心里还是不服,真的只能这样了吗?不行,继续来。既然这个办法不行,看看是不是因为代理的问题。于是就找系统可以设置代理的地方,无功而返。那就沉下心来(唉,知名的弱点,有时候太心急)研究下cpan吧,原来可以直接设置代理。以前都是直接跳过了。

       # cpan

       cpan> o conf init

       提示是否需要手动配置时,直接回车,默认是yes。中间略过n多选项,到了ftp_proxy和http_proxy按照本地pc上的配置填写。最后一步步过去。退出cpan,重新开始安装。看起来好像有效果,可是连接proxy一直超时。看来是因为防火墙的原因,ftp出不去,那么看看有没有使用http的协议镜像,还真找到了http://www.perl.org/CPAN/ (如此明显的地址,看来是我以前的方向错了。)

      重启配置cpan,去掉ftp_proxy和http_proxy的值,在最后一项提示输入另外一个URL时,将上面地址填入。终于解决了CPAN重新安装的问题。 

      这次没有安装DBD::mysql,而是尝试了GD,

      # ./install-module.pl GD

      得到了另外一个错误:

      Could not find gdlib-config in the search path. Please install libgd 2.0.28 or higher.

      检查发现libgd已经安装,并且版本符合要求,有人说是因为gdlib-config不存在,于是下载gd ,然后编译,将产生的gdlib-config复制到/usr/bin/下面,并且添加权限:

      # ./config

      # cp gdlib-config /usr/bin

      # chmod 774 gdlib-config  

      再次安装,这次错误有了变化:

      GD.xs:7:16: error: gd.h: No such file or directory
      GD.xs:8:21: error: gdfontg.h: No such file or directory

      这个是因为只安装了gd,还需要安装gd-devel包:

      # yum install gd-devel

      然后GD顺利完成。 

      接下来安装DBD::mysql,这次出现了的错误和上面的类似:

      In file included from dbdimp.c:20:
      dbdimp.h:22:49: error: mysql.h: No such file or directory
      dbdimp.h:23:45: error: mysqld_error.h: No such file or directory

      那就重新安装mysql和mysql-devel

      # yum install mysql mysql-devel

      DBD::mysql完成安装。 

      一切都安装完毕了,再次运行checksetup.pl,生成了localconfig。下面就按照指南开始配置:mysql和apache。数据库的配置很简单,顺利完成。

      Apache的配置,指南中提供了两种方式,一个是cgi运行,一个mod_perl。我想既然安装那么多perl相关的东西,那就用后者吧。(不知道我是不是对指南的理解有误?)在/etc/httpd/conf.d/perl.conf中添加了: 

  1. PerlSwitches -I/var/www/html/bugzilla -I/var/www/html/bugzilla/lib -w -T  
  2. PerlConfigRequire /var/www/html/bugzilla/mod_perl.pl  

     看起来一切都完成了。那就重启httpd服务吧。

     # service httpd restart

     启动时发生错误:

     Can't locate Template/Config.pm

     除了上面信息以外,还有几个的类似的。解决方法比较简单,使用cpan重新安装即可。

     # cpan Template 

     有时候运行下面的命令,再用cpan运行一次:

     # ./install-module.pl <modulename>

     经过几次反复,终于启动了httpd服务。在浏览器看到了Bugzilla的尊容,可是还没有来得及高兴,发现输入用户名和密码后不能登陆,提示500 Internal Error。赶紧查看apache的error_log,发现里面还有一个:

     Can't locate Digest/SHA.pm in @INC (@INC contains: . lib /var/www/html/bugzilla

      还是采用上面的方法,安装缺少的Digest。

     安装成功,还是提交不成功,仍然是500 Internal Error。仔细观察地址栏中的地址,显示的是index.cgi,不是采用perl方式吗,难道还要用CGI??(恳请高手指点!)

     看来还要打开CGI。没办法,就先把perl.conf中那两行注释掉。再编辑/etc/httpd/conf/httpd.conf:

     将下面这行前面的注释去掉:

     AddHandler cgi-script .cgi

     然后,添加下面内容:

  1. <Directory /var/www/html/bugzilla>  
  2.     Options Indexes FollowSymLinks ExecCGI  
  3.     AllowOverride Limit  
  4.     DirectoryIndex index.cgi index.html  
  5.     Order allow,deny  
  6.     Allow from all  
  7. </Directory>  

     重新启动httpd服务,bugzilla终于可以正常使用了。 

三、后记

     按说我应该珍惜这来之不易的劳动成果,可是实在不习惯进去后还要自己搜索bug的做法(可能这就是先入为主吧,因为之前使用近三年的mantis),同时也习惯bug的管理方式,感觉有点乱。

相关推荐