今天公司安排我搭建一个禅道,作为开发岗实习生的我只能搭建一个能跑的动的系统,下面记录一下搭建禅道的过程。
需求: 在服务器这中搭建禅道项目管理软件。 要求: 不能用禅道自带的数据库,要使用自己的MySQL数据库。 前提: CentOS 服务器一台,MySQL5数据库(MySQL 一定是 5 一定是 5,经测试 MySQL8 是跑不起来的)。
MySQL8 跑不起来可能是跟 allowPublicKeyRetroeval 有关。现在要打工,干活要紧,有空再研究这个。
-
下载禅道开源代码 源码可以在 禅道官网 处下载。 下载你对应系统的版本我的服务器是CentOS 8的,我下载如图的版本。 为了方便我直接只用 wget 命令下载,如果没有wget命令的可以通过yum进行安装。 yum install -y wget wget 命令下载禅道源码 wget https://dl.cnezsoft.com/zentao/16.5/ZenTaoPMS.16.5.zbox_64.tar.gz 解压源码到 /opt 下 tar -zxvf ZenTaoPMS.16.5.zbox_64.tar.gz -C /opt/ 注意一定要解压到/opt下,并且需要直接解压到/opt下,否则会发生奇奇怪怪的错误。 -
准备禅道所需的数据库 因为我需要使用我自己安装的数据库运行禅道系统,所以先使用禅道自带的数据库运行,导出自带数据库的sql文件,再将这个sql文件导入自己的数据库中。 修改禅道服务的端口、修改禅道自带数据库的端口(如果当前服务器已经安装了MySQL,那么一定要修改禅道自带数据库的端口,不然启动会出错的) /opt/zbox/zbox -ap 8080 -mp 3307 8080 是禅道服务的端口、3307是惨到自带数据库的端口。 修改网页登录数据库系统的登录密码 /opt/zbox/auth/adduser.sh 输入用户名 输入密码 这里是待会我们登录页面需要用到的用户名和密码,我输入的用户名和密码都是root 启动禅道 /opt/zbox/zbox start 上面我们设置了禅道服务的端口为8080,我们需要开放这个端口 firewall-cmd --zone=public --add-port=8080/tcp --permanent systemctl restart firewalld 如果是云服务器那么就在安全组放行8080端口。 访问 服务器ip:8080 就可以看到禅道页面了,下面进入禅道自带的数据库,点击页面的数据库管理 输入刚刚设置的账号和密码,我设置账号密码都是root 在服务器中输入:127.0.0.1:3307 (一定要加上端口,3306端口也要加上) 用户名:root 密码:123456 数据库:zentao 在左侧点击导出,输出选择保存,最后点击导出 这时候我们就得到了源数据库的sql文件,将这个sql文件导入我们自己的数据库中。我是创建了一个名为zentao 的数据库。 -
去除禅道自带的数据库功能 先停止禅道服务 /opt/zbox/zbox stop 在禅道的启动脚本中,会自动启动禅道自带的数据库,我们需求修改这个脚本。 cd /opt/zbox/bin/ cp zbox.php zbox.php.copy vim /opt/zbox/bin/zbox.php 将有关MySQL的指令删除,修改后的脚本如下:
<?php
array_shift($argv);
$flipArgv = array_flip($argv);
$basePath = dirname(dirname(__FILE__));
if($basePath != '/opt/zbox') die("Run it in path /opt/zbox/\n");
if(empty($argv) or isset($flipArgv['--help']) or isset($flipArgv['-h']))
{
echo <<<EOD
Usage: zbox.php {start|stop|restart|status}
Options:
-h --help Show help.
-ap --aport Apache port, default 80.
-mp --mport Mysql port, default 3306.
EOD;
exit;
}
if(is_dir("$basePath/app/zentao/"))
{
`chmod -R 777 $basePath/app/zentao/tmp`;
`chmod -R 777 $basePath/app/zentao/www/data`;
`chmod 777 $basePath/app/zentao/www/`;
`chmod 777 $basePath/app/zentao/config/`;
`chmod -R a+rx $basePath/app/zentao/bin/*`;
}
if(is_dir("$basePath/app/zentaopro/"))
{
`chmod -R 777 $basePath/app/zentaopro/tmp`;
`chmod -R 777 $basePath/app/zentaopro/www/data`;
`chmod 777 $basePath/app/zentaopro/www/`;
`chmod 777 $basePath/app/zentaopro/config/`;
`chmod -R a+rx $basePath/app/zentaopro/bin/*`;
}
if(is_dir("$basePath/app/zentaoep/"))
{
`chmod -R 777 $basePath/app/zentaoep/tmp`;
`chmod -R 777 $basePath/app/zentaoep/www/data`;
`chmod 777 $basePath/app/zentaoep/www/`;
`chmod 777 $basePath/app/zentaoep/config/`;
`chmod -R a+rx $basePath/app/zentaoep/bin/*`;
}
/* Process argv. */
$params = array();
foreach($flipArgv as $key => $val)
{
if(strpos($key, '-') !== 0) continue;
if($key == '--aport') $key = '-ap';
if($key == '--mport') $key = '-mp';
if(isset($argv[$val + 1]) and is_numeric($argv[$val + 1]))
{
$params[$key] = $argv[$val + 1];
unset($argv[$val]);
unset($argv[$val + 1]);
}
}
if(isset($params['-ap'])) changePort($basePath . '/etc/apache/httpd.conf', $params['-ap'], array('^Listen +([0-9]+)', '<VirtualHost +.*:([0-9]+)>'));
if(isset($params['-mp']))
{
changePort($basePath . '/etc/mysql/my.cnf', $params['-mp'], '^port *= *([0-9]+)');
changePort($basePath . '/app/htdocs/index.php', $params['-mp'], 'localhost\:([0-9]+)\&');
$myReg = '^\$config->db->port *= *.([0-9]+)..*;';
if(file_exists("$basePath/app/zentao/config/my.php"))
{
`chmod 777 $basePath/app/zentao/config/my.php`;
$myFile = "$basePath/app/zentao/config/my.php";
changePort($myFile, $params['-mp'], $myReg);
}
if(file_exists("$basePath/app/zentaopro/config/my.php"))
{
`chmod 777 $basePath/app/zentaopro/config/my.php`;
$myFile = "$basePath/app/zentaopro/config/my.php";
changePort($myFile, $params['-mp'], $myReg);
}
if(file_exists("$basePath/app/zentaoep/config/my.php"))
{
`chmod 777 $basePath/app/zentaoep/config/my.php`;
$myFile = "$basePath/app/zentaoep/config/my.php";
changePort($myFile, $params['-mp'], $myReg);
}
}
if(!empty($argv)) $params['-k'] = reset($argv);
if(isset($params['-k']))
{
if(strpos(file_get_contents('/etc/group'), 'nogroup') === false) echo `groupadd nogroup`;
if(strpos(file_get_contents('/etc/passwd'), 'nobody') === false) echo `useradd nobody`;
`chmod -R 777 $basePath/tmp`;
`chmod -R 777 $basePath/logs`;
`chown -R nobody $basePath/data/mysql`;
switch($params['-k'])
{
case 'start':
$httpd = `ps aux|grep '\/opt\/zbox\/run\/apache\/httpd '`;
if($httpd)
{
echo "Apache is running\n";
}
else
{
echo `$basePath/run/apache/apachectl start`;
sleep(2);
$httpd = `ps aux|grep '\/opt\/zbox\/run\/apache\/httpd '`;
echo empty($httpd) ? "Start Apache fail. You can see the log /opt/zbox/logs/apache_error.log\n" : "Start Apache success\n";
}
break;
case 'stop':
$httpd = `ps aux|grep '\/opt\/zbox\/run\/apache\/httpd '`;
if($httpd)
{
echo `$basePath/run/apache/apachectl stop`;
sleep(2);
$httpd = `ps aux|grep '\/opt\/zbox\/run\/apache\/httpd '`;
echo empty($httpd) ? "Stop Apache success\n" : "Stop Apache fail. You can see the log /opt/zbox/logs/apache_error.log\n";
}
else
{
echo "Apache is not running\n";
}
break;
case 'restart':
echo `$basePath/run/apache/apachectl restart`;
sleep(2);
$httpd = `ps aux|grep '\/opt\/zbox\/run\/apache\/httpd '`;
echo empty($httpd) ? "Restart Apache fail. You can see the log /opt/zbox/logs/apache_error.log\n" : "Restart Apache success\n";
break;
case 'status':
$httpd = `ps aux|grep '\/opt\/zbox\/run\/apache\/httpd '`;
echo empty($httpd) ? "Apache is not running\n" : "Apache is running\n";
}
}
function changePort($file, $port, $regs)
{
if(!is_array($regs)) $regs = array($regs);
$lines = file($file);
foreach($lines as $i => $line)
{
foreach($regs as $reg)
{
if(preg_match("/$reg/", $line, $matches)) $lines[$i] = str_replace($matches[1], $port, $line);
}
}
file_put_contents($file, join($lines));
}
修改连接MySQL的数据 vim /opt/zbox/app/zentao/config/my.php
-
启动禅道服务并加入开机自启 开启服务 /opt/zbox/zbox start 此时就已经可以使用禅道了,并且没有使用的是我们自己的数据库,禅道自带的数据库没有运行。 将禅道设置成开机自启 chmod +x /etc/rc.d/rc.local vim /etc/rc.d/rc.local 在尾部添加禅道的启动语句 /opt/zbox/zbox start
禅道服务默认登录账号为root,密码为:123456 登录之后按照提示操作就可以使用禅道了
|