我有一个docker映像,它有hadoop、mesos、marathon和zookeeper。为了运行该图像,我编写了一个docker compose,其中包括zookeeper、mesos和marathon三个服务。我使用weave\u cidr在compose文件中创建weave ip。我为三个服务定义了相同的ip编织。当我运行compose文件时,zookeeper运行得很好,但是由于重复的ip编织,我收到了运行mesos的错误。因此,我尝试将三个服务合并到一个服务中,以便对其中三个使用一个ip编织。我的新 Docker 组成如下:
version: '3.7'
services:
zookeeper:
image: hadoop_marathon_mesos_flink_2
command: bash -c "echo zookeeper;
/home/zookeeper-3.4.14/bin/zkServer.sh restart;echo mesos;
sleep 30;/home/mesos-1.7.2/build/bin/mesos-master.sh;
echo marathon;/home/marathon-1.7.189-48bfd6000/bin/marathon"
privileged: true
network_mode: "bridge"
environment:
ZOOKEEPER_SERVER_ID: 1
ZOOKEEPER_CLIENT_PORT: 2181
ZOOKEEPER_TICK_TIME: 2000
ZOOKEEPER_INIT_LIMIT: 10
ZOOKEEPER_SYNC_LIMIT: 5
WEAVE_CIDR: 10.32.0.1/12
ZOOKEEPER_SERVERS: 10.32.0.1:2888:3888
MESOS_CLUSTER: MMM
LIBPROCESS_IP: 10.32.0.1
MESOS_QUORUM: 1
MESOS_LOG_DIR: /var/log/mesos
MESOS_WORK_DIR: /var/run/mesos
MESOS_EXECUTOR_REGISTRATION_TIMEOUT: 5mins
HOSTNAME: 10.32.0.1
MARATHON_ZK: zk://10.32.0.1:2181/marathon
MARATHON_MASTER: zk://10.32.0.1:2181/mesos
MESOS_NATIVE_JAVA_LIBRARY: /usr/local/lib/libmesos.so
MARATHON_HTTP_PORT: 8080
Mesos_HTTP_PORT: 5050
expose:
- 2181
- 2888
- 3888
- 5050
- 4040
- 7077
- 8080
ports:
- 2181:2181
- 2888:2888
- 3888:3888
- 5050:5050
- 4040:4040
- 7077:7077
- 8080:8080
networks:
default:
external:
name: weave
当我运行docker compose时,zookeeper和mesos运行正常;但马拉松不是跑步。我想在梅索斯之后再跑马拉松,但事实并非如此。有人告诉我我做错了什么吗?
任何帮助都将不胜感激。
1条答案
按热度按时间dy2hfwbg1#
问题解决了。我在主节点中使用了这个docker compose文件。运行docker前要小心编写run weave expose在三个节点中打开marathon和mesos ui。
另外,我在从属节点中运行了这个docker compose:
希望有用。