0%

CentOS7设置tomcat开机自启动

安装tomcat

首先参考《全平台安装JDK》,安装配置好JDK,然后按照下面的流程安装tomcat。

1、下载tomcat8.0.50
wget http://www-eu.apache.org/dist/tomcat/tomcat-8/v8.0.50/bin/apache-tomcat-8.0.50.tar.gz

2、解压tomcat到/opt目录
tar -xzvf apache-tomcat-8.0.50.tar.gz -C /opt

3、启动tomcat
cd /opt/apache-tomcat-8.0.50/bin/

./startup.sh

4、测试访问
curl localhost:8080
至此,遇到一个大坑。curl命令卡在那里不动了,浏览器访问也是一直转圈,转啊转,十几分钟了还在转。。。莫非,tomcat版本有问题?换了8.5.29,不行;换了7.0.85,不行。莫非是jdk版本有问题?毕竟第一次是使用yum命令安装的。换了1.8.0_161,依然不行。

好在,最终找到了答案:Centos7+Tomcat8配置javaweb环境,tomcat启动巨慢的问题,安装rng服务。

(1)安装熵服务
yum install rng-tools
(2)启动服务
systemctl start rngd
然后,tomcat就启动成功了。
(3)赶紧把rng服务放进开机自启动
systemctl enable rngd

5、关闭tomcat。
./shutdown.sh

设置开机自启动

参考《在CentOS7中设置Tomcat开机自启动》,设置步骤如下:

假设tomcat目录为/opt/apache-tomcat-8.0.50

1、为Tomcat添加启动参数

catalina.sh在执行的时候会调用同级路径下的setenv.sh来设置额外的环境变量,因此在/opt/tomcat/bin路径下创建setenv.sh文件,内容如下:

1
2
3
4
5
6
7
8
9
10
11
12
# 设置JAVA_HOME
export JAVA_HOME=/usr/lib/jvm/jdk1.8.0_161
export JRE_HOME=$JAVA_HOME/jre
export CLASSPATH=$JAVA_HOME/lib:$JRE_HOME/lib:$CLASSPATH
export PATH=$JAVA_HOME/bin:$JRE_HOME/bin:$PATH

export CATALINA_HOME=/opt/apache-tomcat-8.0.50
export CATALINA_BASE=/opt/apache-tomcat-8.0.50
# 设置Tomcat的PID文件
CATALINA_PID="$CATALINA_BASE/tomcat.pid"
# 添加JVM选项
JAVA_OPTS="-server -XX:PermSize=256M -XX:MaxPermSize=1024m -Xms512M -Xmx1024M -XX:MaxNewSize=256m"

2、在/usr/lib/systemd/system路径下添加tomcat.service文件,内容如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
[Unit]
Description=tomcat
After=syslog.target network.target remote-fs.target nss-lookup.target

[Service]
Type=forking
PIDFile=/opt/apache-tomcat-8.0.50/tomcat.pid
ExecStart=/opt/apache-tomcat-8.0.50/bin/startup.sh
ExecReload=/bin/kill -s HUP $MAINPID
ExecStop=/bin/kill -s QUIT $MAINPID
PrivateTmp=true

[Install]
WantedBy=multi-user.target

3、把tomcat加入开机自启动
systemctl enable tomcat.service

4、重启服务器
reboot

5、再次连接后,查看服务状态
systemctl status tomcat.service

看到tomcat已经启动,正想着大功告成,却发现浏览器访问又开始转圈了。检查rng服务,启动正常。
直接使用./startup.sh启动正常,而使用systemctl start tomcat就转圈,还能是什么原因?
参照《CentOS7下Tomcat启动慢的原因及解决方案》一文,修改java.security,无效;修改catalina.sh,无效。
是不是tomcat.service写的有问题,参照其他配置方案修改,依然无效。
想到《Dockerfile使用Supervisor管理Tomcat》一文中,supervisor启动tomcat也会有些问题。那么,修改startup.sh呢?依然无效。

万万没想到,最后一步还有这么个深坑,沉思良久,莫非,要换init.d方法来设置启动?目前看来,只能这样了。

删除开机自启动

1、删除tomcat.service
find / -name "tomcat*"
rm /usr/lib/systemd/system/tomcat.service
rm /etc/systemd/system/multi-user.target.wants/tomcat.service
rm /etc/selinux/targeted/active/modules/100/tomcat

2、测试启动
systemctl daemon-reload
systemctl start tomcat.service
出现提示Failed to start tomcat.service: Unit not found.说明删除成功。

设置开机自启动之init.d

1、在/etc/init.d下创建服务脚本
vim /etc/init.d/tomcat
写入内容如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
#!/bin/bash
#
# tomcat startup script for the Tomcat server
#
#
# chkconfig: 345 80 20
# description: start the tomcat deamon
#
# Source function library
. /etc/rc.d/init.d/functions

prog=tomcat
# 根据自己的路径改写JAVA_HOME
JAVA_HOME=/usr/lib/jvm/jdk1.8.0_161/
export JAVA_HOME
# 根据自己的路径改写CATALANA_HOME
CATALANA_HOME=/opt/apache-tomcat-8.0.50/
export CATALINA_HOME

case "$1" in
start)
echo "Starting Tomcat..."
$CATALANA_HOME/bin/startup.sh
;;

stop)
echo "Stopping Tomcat..."
$CATALANA_HOME/bin/shutdown.sh
;;

restart)
echo "Stopping Tomcat..."
$CATALANA_HOME/bin/shutdown.sh
sleep 2
echo
echo "Starting Tomcat..."
$CATALANA_HOME/bin/startup.sh
;;

*)
echo "Usage: $prog {start|stop|restart}"
;;
esac
exit 0

2、更改权限
chmod a+x /etc/init.d/tomcat

3、测试启动
service tomcat start
启动成功,然而,还是转圈。。。

实际上,init.d方法添加的自启动服务,也会加入到systemctl的管理。因为,这时也可以用systemctl start tomcat来启动服务。

无奈,决定换成supervisor来设置自启动。

设置开机自启动之supervisor

开始设置前最好先删除init.d方法设置的自启动文件,虽然不影响使用,但是看着闹心。
参考《CentOS安装配置Supervisor》,安装配置好supervisor。

1、在/etc/supervisor中新建tomcat.conf文件

1
2
3
4
5
6
7
8
9
[program:tomcat]
directory=/opt/apache-tomcat-8.0.50
command=/opt/apache-tomcat-8.0.50/bin/catalina.sh run
environment=JAVA_HOME="/usr/lib/jvm/jdk1.8.0_161",JAVA_BIN="/usr/lib/jvm/jdk1.8.0_161/bin"
user=root
autostart=true
autorestart=true
stdout_logfile=/var/log/supervisor/%(program_name)s.log
stderr_logfile=/var/log/supervisor/%(program_name)s.log

2、重启supervisor
systemctl retart supervisord

3、重启tomcat
supervisorctl -c /etc/supervisord.conf restart tomcat

4、测试访问
curl localhost:8080,成功。浏览器访问,成功。
换了三种自启动方式,总算成功了,不容易。。。

5、重启
reboot

6、二次测试
重启后执行supervisorctl status,tomcat正常运行。
curl命令和浏览器测试,正常。至此,tomcat自启动配置成功。其实,systemd和init.d两种方法,理论上也是可以成功的,访问转圈的锅肯定是机器和系统的。嗯,就是这样。

  • 本文作者: 好好学习的郝
  • 本文链接: https://www.voidking.com/dev-centos-tomcat-autostart/
  • 版权声明: 本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!源站会及时更新知识点及修正错误,阅读体验也更好。欢迎分享,欢迎收藏~