我正在使用 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'