6

我正在使用 dockerfiles 构建一个简单的容器。这是Dockerfile

FROM XXXXXXX:5003/base-java

MAINTAINER XXXXX

ADD pubsub/ /opt/pubsub/

CMD ["/opt/pubsub/run.sh"]

内容run.sh如下:

#!/bin/bash
nohup java -jar /opt/pubsub/publish.jar &
nohup java -jar /opt/pubsub/subscribe.jar &

这是一个简单的 java 应用程序pub/sub

现在我有另一个运行 rabbitmq 的容器,我正在链接 2 个容器,但是我的每次尝试都失败了,我的pub/sub容器没有启动。有人可以建议如何调试这个问题吗?不知何故 docker logs 没有任何东西。

这是我链接容器的方式:sudo docker run -d -P --name pub_sub --link rabbitmq:rabbitmq1 image_pub_sub

这是我在pub/sub代码中使用别名的方式

factory = new ConnectionFactory(); 
factory.setHost("rabbitmq1"); 
try { connection = factory.newConnection(); 
channel = connection.createChannel(); 
channel.queueDeclare("pub", true, false, false, null); 
} 
catch (IOException e) { // TODO Auto-generated catch block 
e.printStackTrace(); }

我期待我的发布代码将在 rabbitmq 容器中创建一个队列并开始推送消息。我的订阅者代码基本上会连接到同一个 rabbitmq 并开始阅读消息。

当我运行命令时没有任何反应,它只是打印新容器的长 id 并退出。当我运行sudo docker ps -a时,我可以看到以下内容:

e8a50d5aefa5     image_pub_sub:latest     "/opt/pubsub/run.sh"     32 minutes ago     Exited (0) 32 minutes ago     pub_sub

所以这意味着我的容器没有运行。

刚才我通过/etc/hosts使用以下命令启动新容器来更新sudo docker run -i -t image_pub_sub /bin/bash. 修改了/etc/hosts这个新容器并添加了以下条目<IP_ADDRESS> rabbitmq1并运行了我的脚本/opt/pubsub/run.sh,它在 nohup 文件中附加了以下消息:

Message Sent
 [x] Received 'Hello'
Message Sent
Message Sent
 [x] Received 'Hello'
4

2 回答 2

7

Docker 容器将在其主进程完成时停止。在您的情况下,这意味着两个 Java 应用程序将被分叉到后台(因为nohup调用),然后脚本将立即完成并且容器将退出。

有几个解决方案:

  • 最快和最简单的解决方案是nohup第二个java 调用中删除调用。这样脚本在第二个 Java 应用程序退出之前不会退出。
  • 使用诸如 runit 或 supervisord 之类的流程管理器来管理流程。
  • 将罐子放在单独的容器中并直接调用Java(这对我来说似乎是最好的解决方案)。
于 2015-02-19T16:47:53.747 回答
0

可以使用 tail -f /dev/null 或 tail 你的日志

于 2018-06-28T07:44:30.933 回答