最近需要一个简单快速的bug追踪工具,考虑到系统环境以及学习成本,决定采用bugzilla。不试不知道,原来这里面还有这么多的坑需要一个个踩平~,遂随笔一下以备后用。
我采用的系统组成是debian+mysql+nginx+bugzilla,使用centos的亲可能需要注意nginx的安装方式和配置文件位置不一样,需要灵活变通;至于使用apache的同学,请参考其它文章设置转发部分。
不同于apache使用的cgi方式,nginx采用fcgi来调度php、perl等编程语言。所以我们需要安装并配置perl的fpm。
aptitude install nginx libfcgi-perl mysql-server
我本来想通过下载编译的方式安装fcgi(https://metacpan.org/pod/FCGI)不料安到一半发现发行版里竟然有!于是乎瞬间采用更好的方案解决了。发行版里找不到这个包的同学可以自行下载安装(nginx也是一个道理)
安装完后发现,这个lib没有启停脚本,于是上网上找了两个脚本安上去:
wget http://nginxlibrary.com/downloads/perl-fcgi/fastcgi-wrapper -O /usr/bin/fastcgi-wrapper.pl wget http://nginxlibrary.com/downloads/perl-fcgi/perl-fcgi -O /etc/init.d/perl-fcgi chmod +x /usr/bin/fastcgi-wrapper.pl chmod +x /etc/init.d/perl-fcgi update-rc.d perl-fcgi defaults insserv perl-fcgi
执行完上述脚本后,我们在/etc/init.d/里面安装了一个服务perl-fcgi,它将在开机后自动运行/usr/bin/fastcgi-wrapper.pl
fastcgi-wrapper.pl调用libfcgi-perl并监听socket端口,nginx将通过该端口与之通信。默认地址为127.0.0.1:9000。为了提升性能,我将其改为命名管道方式:
vim /usr/bin/fastcgi-wrapper.pl
找到原来的启动监听语句将其修改为:
$socket = FCGI::OpenSocket( "/tmp/perl-fcgi.sock", 10 );
保存后,启动perl-fcgi
service perl-fcgi start
如果启动失败,提示`account not available`,可能是www-data用户被禁止登陆,执行以下命令:
usermod -s /bin/sh www-data
进入nginx的配置目录,创建配置文件:
cd /etc/nginx/sites-available
vim bugzilla
配置文件如下(将域名和端口替换成你的访问地址):
server { listen 8008; # listening port server_name bugzilla.example.com; # server name root /var/www/bugzilla; # installation path
location /skin/ {}
location /js/ {}
location / { include fastcgi_params; fastcgi_pass unix:/tmp/perl-fcgi.sock; fastcgi_index index.cgi; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; } }
接下来,将配置文件链接到sites-enabled目录中,并启动应用(如果之前nginx已经启动,调用reload重载入配置文件):
cd ../sites-enabled/ ln -s ../sites-available/bugzilla .
service nginx start
mysql的安装与配置在网上相当多,在此不再赘述。
搞定了基础环境,接下来开始正式安装bugzilla
从bugzilla.org下载并解压到/var/www
mkdir -p /var/www cd /var/www chown -R www-data . wget http://ftp.mozilla.org/pub/mozilla.org/webtools/bugzilla-4.4.5.tar.gz tar zxf bugzilla-4.4.5.tar.gz mv bugzilla-4.4.5 bugzilla cd bugzilla
接下来需要对bugzilla进行配置。bugzilla依赖某些perl组件本机可能没有安装,而我在使用其自带的安装脚本时始终无法成功安装,网上搜索后找到一个解决方案是使用cpanm来安装。
下载并安装cpanm:
sudo curl -L http://cpanmin.us | perl - --sudo App::cpanminus
接下来我们执行checksetup.pl来进行配置。配置过程中checksetup.pl需要执行若干次以完成环境检查。第一次执行后,可能会提示有模块未安装,按照未安装的模块列表使用cpanm命令进行安装即可
perl checksetup.pl cpanm YAML cpanm DateTime ...
安装完成后,再次执行checksetup.pl,此时依赖模块应该都检查通过。如果有模块已安装但检查不到,可以尝试强制重新安装,如:
cpanm DateTime -f
模块检查通过后,checksetup.pl会提示mysql连接失败,我们现在进入mysql配置用户与数据库:
CREATE database bugs default charset utf8 collate utf8_bin; CREATE user bugs@localhost identified by 'bugs'; grant all on bugs.* to bugs@localhost; flush privileges;
修改数据库配置:
vim localconfig
找到并修改以下项:
$webservergroup = 'www-data'; $db_pass = 'bugs';
注:如果使用远程数据库等,请自行进行配置用户名、密码等
至此,我们完成了所有的配置。再次执行checkconfig.pl,会提示输入管理员邮箱和密码,并保存配置到数据库。
尝试打开你配置的访问地址(如:http://bugzilla.example.com:8008/),如果能打开并排版显示正确,就表明可以访问了。