简体   繁体   English

Docker-组成猫鼬

[英]Docker-compose mongoose

I'm new to Docker, and I'm trying the simplest of setups with docker-compose, but don't succeed to connect to Mongodb. 我是Docker的新手,我正在尝试使用docker-compose进行最简单的设置,但是没有成功连接到Mongodb。

My docker-compose.local.yaml file: 我的docker-compose.local.yaml文件:

version: "2"
services:
  posts-api:
    build:
      dockerfile: Dockerfile.local
      context: ./
    volumes:
      - ".:/app"
    ports:
      - "6820:6820"
    depends_on:
      - mongodb
  mongodb:
    image: mongo:3.5
    ports:
      - "27018:27018"
    command: mongod --port 27018

My Docker file: 我的Docker文件:

FROM node:7.8.0
MAINTAINER Livefeed 'project.livefeed@gmail.com'

RUN mkdir /app
VOLUME /app
WORKDIR /app

ADD package.json yarn.lock ./
RUN eval rm -rf node_modules && \
yarn

ADD server.js .
RUN mkdir config src
ADD config config/
ADD src src/

EXPOSE 6820
EXPOSE 27018

CMD yarn run local

In server.js I try to connect with: 在server.js中我尝试连接:

mongoose.connect('mongodb://localhost:27018');

I also tried: 我也尝试过:

mongoose.connect('mongodb://mongodb:27018');

To run docker-compose: 要运行docker-compose:

docker-compose -f docker-compose.local.yaml up --build 

And I receive the error: 我收到错误:

connection error: { MongoError: failed to connect to server [localhost:27018] on first connect [MongoError: connect ECONNREFUSED 127.0.0.1:27018]

What am I missing? 我错过了什么?

In server.js use mongodb instead of localhost : 在server.js中使用mongodb而不是localhost

mongoose.connect('mongodb://mongodb:27018');

Because containers in the same network can communicate using their service name. 因为同一网络中的容器可以使用其服务名称进行通信。

Bear in mind that each container and your host have their own localhost. 请记住,每个容器和主机都有自己的localhost。 Each localhost is a different host : container A, container B, your host (each one has its own network interface). 每个localhost都是不同的host :容器A,容器B,主机(每个主机都有自己的网络接口)。


Edit: 编辑:

Be sure to get your mongo up: 一定要搞定你的mongo:

docker-compose logs mongodb
docker-compose ps

Sometimes it doesn't get up because of disk space. 有时它因磁盘空间而无法启动。


Edit 2: 编辑2:

With newer versions of mongo, you need to specify to listen to all interfaces too: 对于较新版本的mongo,您还需要指定监听所有接口:

command: mongod --port 27018 --bind_ip_all

I think, that you should add links option in your config. 我想,您应该在配置中添加links选项。 Like this: 像这样:

ports:
  - "6820:6820"
depends_on:
  - mongodb
links:
  - mongodb

update 更新

As I promised 正如我所承诺的那样

version: '2.1'
services:
    pm2:
      image: keymetrics/pm2-docker-alpine:6
      restart: always
      container_name: pm2
      volumes:
        - ./pm2:/app
      links:
        - redis_db
        - db
      environment:
        REDIS_CONNECTION_STRING: redis://redis_db:6379

    nginx:
      image: firesh/nginx-lua
      restart: always
      volumes:
        - ./nginx:/etc/nginx
        - /var/run/docker.sock:/tmp/docker.sock:ro
      ports:
        - 80:80
      links:
        - pm2

        s3: # mock for development
      image: lphoward/fake-s3:latest

    redis_db:
      container_name: redis_db
      image: redis
      ports:
        - 6379:6379

    db: # for scorebig-syncer
      image: mysql:5.7
      ports:
        - 3306:3306

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM