安装LAMP
参考 https://www.linuxidc.com/Linux/2016-12/138757.htm
sudo add-apt-repository ppa:ondrej/apache2
sudo apt update
apt-get -y install apache2 php mysql-server php-mysql libapache2-mod-php lynx
中间遇到错误,
E:could not get lock /var/lib/dpkg/lock -open
原因是:可能是有另外一个程序正在运行,导致资源被锁不可用。而导致资源被锁的原因,可能是上次安装时没正常完成,而导致出现此状况。
解决办法是:
sudo rm /var/cache/apt/archives/lock
sudo rm /var/lib/dpkg/lock
再重新安装即可成功。
另一个错误,
Set the 'ServerName' directive globally
参考 https://www.jianshu.com/p/275b17d6a73e
在/etc/apache2/apache2.conf中添加下面代码:
ServerName localhost
中间安装mysql-server迟迟不能完成,top一下,看到mysql正在运行,
service mysql stop
安装完毕。重启MySQL,Apache,命令是:
sudo service mysql restart
sudo service apache2 restart
验证http服务,
lynx localhost
安装 mantis
但参考:http://www.linuxdiyf.com/linux/29157.html
另外安装,
sudo apt-get install php-mbstring php-xml
配置php时,/etc/php好几个版本,php -v确定当前版本是7.2
安装完后,要重启apathe2,访问192.168.1.26/mantis/admin/install.php配置
这时不知道mysl的用户名,密码,可以进入 /etc/mysql/debian.conf里去找,得知用户名:debian-sys-maint,密码 dST3vD6t5Rp9TmzH
mysql -u debian-sys-maint -p
进入。结果提示错误:Can't connect to local MySQL server through socket
尝试重启mysqld,折腾了一番: service mysqld restart or pkill mysqld 不知为啥就好了。
mysql设置root密码
现在终于被我找到了解决方法,如下(请先测试方法三,谢谢!):
方法一:
# /etc/init.d/mysql stop
# mysqld_safe --user=mysql --skip-grant-tables --skip-networking &
# mysql -u root mysql
mysql> UPDATE user SET Password=PASSWORD('newpassword') where USER='root';
mysql> FLUSH PRIVILEGES;
mysql> quit
# /etc/init.d/mysql restart
# mysql -uroot -p
Enter password: <输入新设的密码newpassword>
mysql>
方法二:
直接使用/etc/mysql/debian.cnf文件中[client]节提供的用户名和密码:
# mysql -udebian-sys-maint -p
Enter password: <输入[client]节的密码>
mysql> UPDATE user SET Password=PASSWORD('newpassword') where USER='root';
mysql> FLUSH PRIVILEGES;
mysql> quit
# mysql -uroot -p
Enter password: <输入新设的密码newpassword>
PHP和邮箱配置
PHP配置类似于:
记得配置php.ini中smtp选项
[mail function]
; For Win32 only.
; http://php.net/smtp
SMTP = smtp.163.com #此处需要配置邮箱smtp服务地址
; http://php.net/smtp-port
smtp_port = 25
邮箱配置:
在/var/www/html/mantis/config/config_inc.php后添加:
$g_phpMailer_method = PHPMAILER_METHOD_SMTP;
$g_smtp_host = 'smtp.21cn.com';
#$g_smtp_host = 'smtp.mxhichina.com';
#$g_smtp_connection_mode = 'ssl';
$g_smtp_port = 25;
$g_smtp_username = 'tangxiaosheng@21cn.com';
$g_smtp_password = 'xxxx';
#$g_smtp_username = 'mantisadmin@estonecn.com';
#$g_smtp_password = 'Mantis1234';
$g_webmaster_email = 'mantisadmin@estonecn.com';
$g_from_name = 'Mantis Bug Tracker';
$g_from_email = 'tangxiaosheng@21cn.com'; #the "From: " field in emails
$g_return_path_email = 'tangxiaosheng@21cn.com'; # the return address for bounced mail
#$g_return_path_email = 'mantisadmin@estonecn.com'; # the return address for bounced mail
$g_email_receive_own = OFF;
$g_email_send_using_cronjob = ON;
$g_enable_email_notification = ON;
之前g_return_path_email = 'tangxiaosheng@21cn.com',填的是 ‘tangjian@estonecn.com’,后来改了以后就可以了。
https://my.oschina.net/yyping/blog/89411 提到:
$g_return_path_email = xxxxxx@souhu.com #将后面的邮件地址改为有效的地址,这一点非常重要,不然将无法正常发送激活注册的邮件.
难道 tangjian@estonecn.com不被认为是有效的邮件地址?事实证明了这点,$g_return_path_email 和 $g_from_email 都不支持estonecn.com (阿里邮箱)。
一遍用 delete from mantis_user_table where username = 'tangjian'; 从数据库里删东西,一边用tangjian这个用户名建新用户。
确保 $g_return_path_email 和 $g_from_email 不用阿里邮箱,仅仅是$g_smtp_username用阿里邮箱,发现也不行。
修改完config_inc.config后,不用重启apache2服务。
用这个sql语句:
select * from mantis_email_table;
可以查询那些邮件没有发出去,一般是空的,因为已经在发送的路上了。如果非空,一般发送回失败。
用命令: php /var/www/html/mantis/scripts/send_emails.php 可以看到发送失败的原因。如果成功,一般就显示:
Sending emails...
Done.
解决Mantis无法发送邮件的问题 这个的价值挺高,之前没有设置 $g_email_send_using_cronjob = ON; 导致其它都设置合理的情况下,邮件发不出去。
但是仅仅把这个设为ON,接收邮件速度还是慢了些。
中间还发现经过管理员设置后,用administrator:root无法登陆。那么重新来,按照 h
按照 centos7.3 安装mantis ,重新建立数据库bugtracker,
>create database bugtracker;
>grant all privileges on bugtracker.* to admin@localhost identified by 'yishi';
>flush privileges;
等等操作。
mantis发送邮件的原理:定时任务中的send_emails.php,会读取数据库的邮件队列表mantis_email_table.获取发送的列表后,依次按照ID的升序发送,发送完毕后清空。等待下次队列,周而复始。
可以把 */1 * * * * root php /var/www/html/mantis/scripts/send_emails.php >/dev/null 加入到/etc/crontab,每分钟都尝试发一次邮件。
提交时超慢的原因和解决办法:
解决方案:
发送表 mantis_email_table中的邮件 ,并及时清理。
检查函数email_send() 中邮件发送和邮件删除功能是否正常,步骤是否都一一走完。
我的体验是,对于总是失败的邮件,可以在表中进行删除。
有人提议:
无法发送邮件,而又不知道如何解决的问题,可以通过以下方法进行调试:
增加调试语句,在文件/core/email_api.php的1032行,增加调试语句:var_dump(LOG_EMAIL);var_dump($t_log_msg . $mail->ErrorInfo);
我加了这个语句。不知道之前发送后打印的错误信息,是否和我加了这个语句有关。
提示不允许使用免费邮件地址
APPLICATION ERROR #1201
It is not allowed to use disposable e-mail addresses.
询问开发者得知,程序中使用了DisposableEmailChecker的插件,用于检测一次性邮箱地址的域。
解决方法为,将
/var/www/html/mantis/vendor/vboctor/disposable_email_checker/data/domains.txt
文件中 qq.com 从文件中移除取可。目前已经处理了21cn,yeah, sohu, qq邮箱。