使用 Monit 监控 apache tomcat 服务器的问题

使用 Monit 监控 apache tomcat 服务器的问题

我已经在 Ubuntu Linux 12.04.1 服务器中使用以下命令安装了 Monit

sudo apt-get install monit

我使用 Monit 的主要目的是当 MySQL 和 Apache tomcat 服务被终止/停止时自动重新启动它们。

#Check and restart mysql service
check process mysqld with pidfile "/run/mysqld/mysqld.pid"
group database
start program = "/etc/init.d/mysql start"
stop program = "/etc/init.d/mysql stop"
if failed host 127.0.0.1 port 3306 protocol mysql then restart
if 5 restarts within 5 cycles then timeout

上述代码运行完美,并且 Monit 重新启动 MySQL 服务(当其被终止/停止时)。

我实际上已经按如下方式配置了 tomcat: - 下载了 tomcat zip 并解压到特定位置 - 将其配置为我的守护进程服务(并且我的 tomcat 服务器正常运行)。

由于我没有此 tomcat 设置的 pid 文件,因此我计划检查 tomcat 的状态并使用以下代码启动它:

#Check and restart tomcat service
check host tomcat with address 127.0.0.1
stop program = "/etc/init.d/tomcat stop"
start program = "/etc/init.d/tomcat start"
if failed port 8080 and protocol http
then start

但是,我无法成功启动 tomcat(当它被杀死时)。在调查 Monit 日志时,我发现了以下消息:

[UTC Dec 24 12:08:23] error    : 'tomcat' failed, cannot open a connection to INET[127.0.0.1:8080] via TCP
[UTC Dec 24 12:08:23] info     : 'tomcat' start: /etc/init.d/tomcat

通过以上日志,我发现 Monit 会尝试在特定时间自动启动 tomcat(当它发现 tomcat 服务被终止时)。但是,一些内部冲突阻止了这一操作!

其他信息:

Tomcat服务器正常运行,使用8080端口:

netstat -an | grep 8080
tcp6       0      0 :::8080                 :::*                    LISTEN     
tcp6       0      0 127.0.0.1:8080          127.0.0.1:53582         TIME_WAIT  


ps -ef|grep tomcat
root     16237     1  9 12:10 ?        00:00:37 /usr/lib/jvm/java-6-oracle/bin/java -Djava.util.logging.config.file=/usr/share/apache-tomcat-7.0.40/conf/logging.properties -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager -Djava.awt.headless=true -Dfile.encoding=UTF-8 -server -Xms1024m -Xmx1530m -XX:NewSize=512m -XX:MaxNewSize=1024m -XX:PermSize=512m -XX:MaxPermSize=1024m -Djava.endorsed.dirs=/usr/share/apache-tomcat-7.0.40/endorsed -classpath /usr/share/apache-tomcat-7.0.40/bin/bootstrap.jar:/usr/share/apache-tomcat-7.0.40/bin/tomcat-juli.jar -Dcatalina.base=/usr/share/apache-tomcat-7.0.40 -Dcatalina.home=/usr/share/apache-tomcat-7.0.40 -Djava.io.tmpdir=/usr/share/apache-tomcat-7.0.40/temp org.apache.catalina.startup.Bootstrap start
root     16851 16847  0 12:17 ?        00:00:00 sh -c su root -c ps\ \-ef\|grep\ tomcat 2>&1 2>/dev/null
root     16852 16851  0 12:17 ?        00:00:00 su root -c ps -ef|grep tomcat
root     16853 16852  0 12:17 ?        00:00:00 bash -c ps -ef|grep tomcat
root     16855 16853  0 12:17 ?        00:00:00 grep tomcat

在 catalina.sh 文件中添加 preferIPv4Addresses 和 preferIPv4Stack:

JAVA_OPTS="-Djava.awt.headless=true -Dfile.encoding=UTF-8 -server -Xms1024m -Xmx1530m
-XX:NewSize=512m -XX:MaxNewSize=1024m -XX:PermSize=512m -XX:MaxPermSize=1024m -Djava.net.preferIPv4Stack=true -Djava.net.preferIPv4Addresses=true"

监控日志:

[UTC Dec 24 12:48:39] error    : 'tomcat' failed protocol test [HTTP] at INET[127.0.0.1:8080] via TCP -- HTTP: Error receiving data -- Resource temporarily unavailable

有人可以指导我吗?

谢谢。

答案1

似乎 Tomcat 将自身绑定到 127.0.0.1 的 ipv6 地址。

您可以尝试使用Java 选项中的preferIPv4Stack=true指令preferIPv4Addresses=true绑定到 ipv4 地址

编辑catalina.shTomcat 启动脚本并添加以下内容:

JAVA_OPTS="$JAVA_OPTS -Djava.net.preferIPv4Stack=true -Djava.net.preferIPv4Addresses=true"

相关内容