node.js - Docker-compose Nodejs Mongodb 不成功

标签 node.js mongodb docker docker-compose

我正在本地 Mac OS 上使用 docker-compose 测试 NodeJS + MongoDB,但是 NodeJSMongoDB无法连接成功。

<小时/>

如果我没有通过下面的代码为 MongoDB 设置 --auth,一切正常。

代码如下:

Mongoose 连接

mongodb://mongodb:27017/myprojectdatabase

docker-compose.yml

version: "3"
services:
  web:
    build: .
    restart: always
    ports:
    - "8080:8080"
    depends_on:
    - mongodb
    volumes:
     - .:/mycode
  mongodb:
    image: mongo:latest
    ports:
      - "27017:27017"
<小时/>

然后我想为 MongoDB 启动 --auth ,如下所示,但出现错误。

docker-compose.yml

version: "3"
services:
  web:
    build: .
    restart: always
    ports:
    - "8080:8080"
    depends_on:
    - mongodb
    volumes:
     - .:/mycode
    # environment:
    #  - NODE_ENV=production
  mongodb:
    image: mongo:latest
    command: [--auth]
    environment:
      MONGO_INITDB_ROOT_USERNAME: my_admin
      MONGO_INITDB_ROOT_PASSWORD: my2019
      MONGO_INITDB_DATABASE: myprojectdatabase
    ports:
      - "27017:27017"
    volumes:
      - ./mydata:/data/db

然后我就跑

docker-compose down -v && docker-compose up --build 

我得到了输出:

mongodb_1  | 2019-03-01T10:54:09.847+0000 I CONTROL  [main] Automatically disabling TLS 1.0, to force-enable TLS 1.0 specify --sslDisabledProtocols 'none'
mongodb_1  | 2019-03-01T10:54:09.869+0000 I CONTROL  [initandlisten] MongoDB starting : pid=1 port=27017 dbpath=/data/db 64-bit host=9554854909b1
mongodb_1  | 2019-03-01T10:54:09.869+0000 I CONTROL  [initandlisten] db version v4.0.4
mongodb_1  | 2019-03-01T10:54:09.869+0000 I CONTROL  [initandlisten] git version: f288a3bdf201007f3693c58e140056adf8b04839
mongodb_1  | 2019-03-01T10:54:09.869+0000 I CONTROL  [initandlisten] OpenSSL version: OpenSSL 1.0.2g  1 Mar 2016
mongodb_1  | 2019-03-01T10:54:09.869+0000 I CONTROL  [initandlisten] allocator: tcmalloc
mongodb_1  | 2019-03-01T10:54:09.869+0000 I CONTROL  [initandlisten] modules: none
mongodb_1  | 2019-03-01T10:54:09.869+0000 I CONTROL  [initandlisten] build environment:
mongodb_1  | 2019-03-01T10:54:09.869+0000 I CONTROL  [initandlisten]     distmod: ubuntu1604
mongodb_1  | 2019-03-01T10:54:09.869+0000 I CONTROL  [initandlisten]     distarch: x86_64
mongodb_1  | 2019-03-01T10:54:09.869+0000 I CONTROL  [initandlisten]     target_arch: x86_64
mongodb_1  | 2019-03-01T10:54:09.869+0000 I CONTROL  [initandlisten] options: { net: { bindIpAll: true }, security: { authorization: "enabled" } }
mongodb_1  | 2019-03-01T10:54:09.873+0000 W STORAGE  [initandlisten] Detected unclean shutdown - /data/db/mongod.lock is not empty.
mongodb_1  | 2019-03-01T10:54:09.876+0000 I STORAGE  [initandlisten] Detected data files in /data/db created by the 'wiredTiger' storage engine, so setting the active storage engine to 'wiredTiger'.
mongodb_1  | 2019-03-01T10:54:09.878+0000 W STORAGE  [initandlisten] Recovering data from the last clean checkpoint.
mongodb_1  | 2019-03-01T10:54:09.879+0000 I STORAGE  [initandlisten] wiredtiger_open config: create,cache_size=487M,session_max=20000,eviction=(threads_min=4,threads_max=4),config_base=false,statistics=(fast),log=(enabled=true,archive=true,path=journal,compressor=snappy),file_manager=(close_idle_time=100000),statistics_log=(wait=0),verbose=(recovery_progress),    
web_1      | connection error: { MongoNetworkError: failed to connect to server [mongodb:27017] on first connect [MongoNetworkError: connect ECONNREFUSED 192.168.160.2:27017]
    web_1      |     at Pool.<anonymous> (/usr/src/app/node_modules/mongodb-core/lib/topologies/server.js:505:11)
    web_1      |     at emitOne (events.js:116:13)

有时我可以看到日志包含用户创建的信息,有时却看不到。

 2019-03-01T10:38:50.323+0000 I STORAGE  [conn2] createCollection: admin.system.users with generated UUID: 6b3b88f9-e77c-4094-a1c7-153816202a9e
mongodb_1  | Successfully added user: {
mongodb_1  |    "user" : "my_admin",
mongodb_1  |    "roles" : [
mongodb_1  |        {
mongodb_1  |            "role" : "root",
mongodb_1  |            "db" : "admin"
mongodb_1  |        }
mongodb_1  |    ]
mongodb_1  | }
mongodb_1  | 2019-03-01T10:38:50.340+0000 E -        [main] Error saving history file: FileOpenFailed: Unable to open() file /home/mongodb/.dbshell: Unknown error

我是 docker 的新手。我猜主要问题是 web 无法与 mongodb 建立连接。在这个问题上花费太长时间。

有什么帮助吗?谢谢!

最佳答案

确保您不会访问 Web 容器的本地主机。将容器视为单独的机器:一个容器中的本地主机不与另一个容器共享。这就是为什么在连接字符串中包含 mongodb:27017 而不是 localhost:27017,因为默认 docker 网络中的 mongodb 的 DNS 名称为带有 mongo 的容器。您在第一种(成功)情况下使用此连接字符串,请确保在第二种情况下具有有效的 DNS 名称。

还要确保在连接字符串中包含您的数据库凭据(用户名:密码)。

关于node.js - Docker-compose Nodejs Mongodb 不成功,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54943249/

相关文章:

javascript - 为什么 BST(英国夏令时/夏令时)被添加到我的 Node 日期时间中?

php - Mongo 中的多对多关系

windows - 如何在Windows上使用Boot2Docker构建镜像?

node.js - 为什么有时可以使用 NodeJS 缓冲区连接音频数据,而有时却不能?

angularjs - 使用 Morgan 进行日志记录仅显示 :remote-addr in nodejs 的 127.0.0.1

java - MongoDB:查找所有字段和值(_id 除外)都等于给定文档的文档?

mongodb - Mongo 中使用什么模式来存储和检索记录审计跟踪?

docker - 从 windows 主机访问 dockerized redis

docker - 我无法在docker容器中安装yum

node.js - 如何在nodejs中将变量名称作为mongo db的集合名称传递