难以将我的快速Docker容器暴露给世界

时间:2018-11-08 18:09:23

标签: node.js express docker docker-compose dockerfile

我有一个使用express运行的节点应用程序,以在docker容器中运行Web服务器。我的节点应用看起来像这样:

'use strict'
const childProcess = require('child_process');
const express = require('express');
... // so many requires


const main = async () => {
  var app = express();

  app.get('/status', function (req, res) {
    res.send('Hello World')
  });

  app.listen(8080,'0.0.0.0');

  ... // so much more code

}

main().catch((err) => {
  console.error(err);
});

我不认为我的节点应用程序有什么问题,因为当我使用以下命令登录我的Docker容器时: docker exec -it blacklist-service_blacklist-service_run_1 / bin / bash

并运行: curl localhost:8080 / status

它返回 Hello World

因此,它使我相信我的docker配置有问题,例如当我从主机上运行 curl localhost:8080 / status 时,我收到: curl: (7)无法连接到本地主机端口8080:连接被拒绝

所以...我的Dockerfile看起来像这样:

FROM ubuntu:bionic

RUN apt-get update && apt-get -qq install \
  curl \
  git \
  gnupg2 \
  locales \
  netcat \
  python3-pip

RUN locale-gen en_US.UTF-8
ENV LANG en_US.UTF-8
ENV LANGUAGE en_US:en
ENV LC_ALL en_US.UTF-8

RUN pip3 install abydos \
    num2words \
    simplejson \
    unidecode

RUN curl -sL https://deb.nodesource.com/setup_10.x | bash
RUN apt-get -qq install nodejs
RUN npm install npm@latest -g

RUN mkdir -p /usr/src/app
WORKDIR /usr/src/app

RUN npm install -g \
  Eficode/wait-for

RUN npm install \
    express \
    googleapis \
    uuid

COPY src/ .
COPY bin/ ./bin

EXPOSE 8080

ENTRYPOINT /usr/lib/node_modules/wait-for/wait-for ${WAIT_FOR} -t 20 -- node server.js

(我知道,我知道,但这是使用ubuntu作为我们的docker映像的要求)

然后我有一个docker-compose文件,如下所示:

version: "3.6"

services:
  rabbitmq:
    image: "rabbitmq:latest"
    ports:
      - "15672:15672"
      - "5672:5672"
    volumes:
      - "./enabled_plugins:/etc/rabbitmq/enabled_plugins"
  blacklist-service:
    environment:
      NODE_ENV: development
    image: ${DOCKER_REGISTRY}unicorn/blacklist-service:${DOCKER_IMAGE_LABEL:-latest}
    build:
      context: .
      dockerfile: ./debugging/Dockerfile
    ports:
      - "0.0.0.0:8080:8080"
    depends_on:
      - rabbitmq
    environment:
      - WAIT_FOR=rabbitmq:5672
      - AMQP_SHARED_HOST=rabbitmq
      - AMQP_USERNAME=guest
      - AMQP_PASSWORD
      - AMQP_EXCHANGE=amq.topic
      - AMQP_TOPIC=topic
      - AMQP_JOB=state51::Job::RunQAForFormat
      - AMQP_QUEUE
      - AMQP_PATTERN=#
      - AMQP_SHARED_PORT=5672
      - AMQP_SEND_EXCHANGE=firehose
      - BLACKLIST_SERVICE_SECRET
      - GOOGLE_PRIVATE_KEY
      - GOOGLE_CLIENT_EMAIL
      - GOOGLE_CLIENT_ID
      - GOOGLE_API_KEY

./ debugging / Dockerfile 指的是我上面列出的Dockerfile。

然后我通过以下方式构建映像: docker-compose -f docker-compose.local.yml build 并使用以下命令运行它: docker-compose -f docker-compose.local.yml运行blacklist-service (其中 docker-compose.local.yml 是上述docker-compose文件的名称)。

那么我暴露服务器的地方出了什么问题?运行Docker社区:我的Mac上的版本18.06.1-ce-mac73(26764)

1 个答案:

答案 0 :(得分:1)

使用--service-ports时,我需要添加参数docker-compose run [service-name]

正确的命令是:docker-compose -f docker-compose.local.yml run --service-ports blacklist-service,它使我可以卷曲到 localhost:8080 / status 并获得我期望的响应。