tomcat启动一会后自动关闭_RocketMQ生产环境启动后进程自动退出原因

背景

公司核心交易链路业务使用RocketMQ承载,集群规模为NameSrv 2台,Broker 集群2组 为2主2从同时在线,异步刷盘,异步复制,打开写堆外内存。

起因

生产环境使用AWS日本云实例,RocketMQ B组Master节点所在物理机突然宕机,在处理过程中B组Master A节点在恢复服务不久后进程Crash导致离线(时间不等)。

过程

  • 生产环境AWS宕机
  • 切换RocketMQ B套Slave节点为Master恢复服务
  • 控制台重启B套Master所在云实例
  • 原B套Master节点修改为Slave节点
  • 启动
  • 运行一段时间后发现B套Slave(原Master)自动离线

分析

SSH终端进入机器后查看发现进程消失

a1cacf28e2f6aee72e276bedfc43f52c.png

查看日志发现无法分配内存。

b61e457bf107c78ce2143682c75488d5.png

查看GC log,期间运维多次重启。

34bbb633862ba8c9473f21bc2150a253.png

查看GC log发现并无异常。

e90fa48f260c3a4a68207c7905ea857f.png

经排查,JVM分配内存并未超过实例内存总数,并且该节点机基本无其他进程。

cat /proc/<pid>/status
cat /proc/<pid>/maps |wc -l

查看后发现VM映射超限

cat /proc/sys/vm/max_map_count
65530

本实例max_map_count为65530,查询其余3个节点均为655360。

原因

sudo sysctl -w vm.max_map_count=655360

os.sh内核参数调优脚本中:sysctl -w参数为临时生效,重启后失效。

解决

执行os.sh或手动修改参数生效。

相关

事后在RocketMQ Issue发现同样问题。

Issue:https://github.com/apache/rocketmq/issues/1100

调优脚本链接:https://github.com/apache/rocketmq/blob/master/distribution/bin/os.sh

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 如果Docker启动Tomcat镜像后自动退出,可能是由于以下几个原因引起的: 1. Tomcat容器没有持久化数据:Docker容器默认是无状态的,当容器停止时,容器内部的所有数据都会丢失。要保持Tomcat容器的数据持久化,可以通过挂载宿主机上的目录到容器中,例如使用`docker run -v /path/on/host:/path/on/container`来启动容器。 2. Tomcat启动失败:可能是由于Tomcat配置文件错误、端口冲突等原因导致Tomcat启动失败。可以查看容器的日志输出,使用`docker logs <container_name>`命令查看具体的错误信息,然后相应地解决问题。 3. 容器资源不足:如果Docker宿主机的资源(内存、CPU等)不足,可能会导致容器启动后立即退出。可以检查宿主机的资源占用情况,确保足够的资源供Tomcat容器使用。 4. Tomcat镜像本身的问题:有时候Tomcat镜像本身可能存在问题,导致启动后立即退出。可以尝试使用其他版本的Tomcat镜像或自定义构建Tomcat镜像来解决问题。 总之,要解决Docker启动Tomcat镜像启动自动退出的问题,我们需要仔细检查容器的配置和日志输出,确保容器具有足够的资源和正确的配置,以及保证Tomcat容器的数据持久化。 ### 回答2: 当Docker启动Tomcat镜像后立即退出原因可能有以下几种: 1. 没有指定正确的启动命令:在运行Docker容器时,我们需要通过`docker run`命令指定正确的启动命令,以确保Tomcat能够成功启动并保持运行。例如,正确的启动命令可以是`docker run -d -p 8080:8080 tomcat`,其中`-d`表示以守护进程的方式后台运行容器,`-p`表示将宿主机的8080端口映射到容器的8080端口上,`tomcat`表示所使用的Tomcat镜像。如果启动命令有误或者缺失关键参数,Tomcat可能会启动失败并导致容器自动退出。 2. Tomcat的配置文件有错误:Tomcat的配置文件,如`server.xml`、`web.xml`等,如果存在错误配置,可能会导致Tomcat启动时出现异常。这些错误可能包括端口冲突、无效的路径、无效的XML配置等。当Tomcat启动失败时,Docker容器可能会因为Tomcat的异常退出关闭。 3. 容器内存不足:如果给Tomcat容器分配的内存不足,Tomcat启动过程中可能会因为无法分配足够的资源而导致异常退出。因此,我们需要适当地调整Docker容器的内存分配,以满足Tomcat的运行需求。 4. Tomcat镜像的问题:有时,所使用的Tomcat镜像本身可能存在问题。这可能是由于不稳定的构建过程、错误的配置或其他问题导致的。如果这是问题的根本原因,建议尝试使用另一个Tomcat镜像或检查是否存在更新版本,以解决启动自动退出的问题。 综上所述,当Docker启动Tomcat镜像后自动退出时,我们需要检查启动命令、Tomcat配置、容器内存和镜像本身等方面的问题,以找到并解决导致退出原因。 ### 回答3: docker启动tomcat镜像后自动退出原因可能有多种。 首先,可能是由于在Dockerfile中定义了CMD或ENTRYPOINT指令,但没有指定后台运行选项。若没有使用-d或--detach参数来运行容器,则容器会在启动后立即退出。解决办法是在docker run命令中添加-d选项,将容器以后台模式运行,例如: ``` docker run -d tomcat ``` 其次,可能是由于容器内的进程启动失败或异常导致。可以通过查看容器的日志来了解具体的错误信息。可以使用docker logs命令来查看容器的日志输出,例如: ``` docker logs <container_id> ``` 解决该问题的方法通常是检查容器的配置文件、环境变量和依赖项是否正确设置,并确保容器所需的端口没有被其他进程占用。 另外,如果tomcat镜像是在运行时需要绑定宿主机的目录或文件的,可能是由于宿主机上对应的目录或文件不存在或权限不足而导致容器启动后立即退出。可以通过docker run命令的-v选项来映射宿主机的目录或文件到容器中,确保目录或文件存在且具有足够的访问权限。 总结起来,要解决容器启动自动退出的问题,首先要检查容器的运行模式是否为后台模式,然后查看容器的日志以了解具体的错误信息,并确保容器的配置、环境和依赖项正确设置,并确保相关的目录或文件存在且具有足够的权限。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值