将 cloudera 与 docker-compose 一起使用

use cloudera with docker-compose

当我像那样将 cloudera 与 docker 一起使用时:

docker run -it cloudera/quickstart:latest /usr/bin/docker-quickstart

一切正常,我无法使用它,并通过 DOCKER_IP:50070

访问 ui

但是,如果我想将 cloudera 添加到 docker-compose 文件,就像那样:

version: '2'
services:
  cloudera:
    image: cloudera/quickstart:latest
    command: /usr/bin/docker-quickstart
    ports:
      - "8020:8020"
      - "8022:22"     # ssh
      - "7180:7180"   # Cloudera Manager
      - "8888:8888"   # HUE
      - "11000:11000" # Oozie
      - "50070:50070" # HDFS REST Namenode
      - "2181:2181"
      - "11443:11443"
      - "9090:9090"
      - "8088:8088"
      - "19888:19888"
      - "9092:9092"
      - "8983:8983"
      - "16000:16000"
      - "16001:16001"
      - "42222:22"
      - "8042:8042"
      - "60010:60010"
      - "8080:8080"
      - "7077:7077"

没有任何效果,容器在启动后直接停止。 这里只是信息堆栈跟踪的结尾:

cloudera_1  | Starting Solr server daemon:[  OK  ]
cloudera_1  | Existing PID file found during start.
cloudera_1  | Removing/clearing stale PID file.
cloudera_1  | Started Impala Catalog Server (catalogd) :[  OK  ]
cloudera_1  | Started Impala Server (impalad):[  OK  ]
hadoopmongokafka_cloudera_1 exited with code 0

我做错了什么?

我认为这个问题与此非常相似one

你能检查一下将 tty: true 字段添加到你的 docker-compose 问题是否解决了吗?

version: '2'
services:
  cloudera:
    image: cloudera/quickstart:latest
    command: /usr/bin/docker-quickstart
    tty: true
    ports:
      - "8020:8020"
      ...

也添加这个:

version: "2"
services:
  cloudera:
    image: cloudera/quickstart:latest
    command: /usr/bin/docker-quickstart
    privileged: true
    hostname: quickstart.cloudera