从docker compose导入mongodb上的数据

从docker compose导入mongodb上的数据,mongodb,docker,docker-compose,Mongodb,Docker,Docker Compose,我想用docker compose导入mongodb数据库中的数据,但没有找到解决方案。这是一个想法,我得到某处,但这是行不通的。如果有人看到更好的解决方案或只是修复此解决方案,我会:)。谢谢 ./docker-compose.yml db: image: mongo ports: - 27018:27017 dbseed: build: ./dbseed links: - db app: build: . links: - db:db por

我想用docker compose导入mongodb数据库中的数据,但没有找到解决方案。这是一个想法,我得到某处,但这是行不通的。如果有人看到更好的解决方案或只是修复此解决方案,我会:)。谢谢

./docker-compose.yml

db:
  image: mongo
  ports:
   - 27018:27017

dbseed:
  build: ./dbseed
  links:
    - db

app:
  build: .
  links:
   - db:db
  ports:
   -8080:8080
   -8181:8181
dbseed/new_climat_final.json

[
  {
    "name": "Joe Smith",
    "email": "jsmith@gmail.com",
    "age": 40,
    "admin": false
  },
  {
    "name": "Jen Ford",
    "email": "jford@gmail.com",
    "age": 45,
    "admin": true
  }
]
dbseed/Dockerfile

FROM mongo

COPY new_climat_final.json /new_climat_final.json

CMD mongoimport --host db --db hpApiDev --collection coll --type json --file /new_climat_final.json --jsonArray
我的mongodb数据库中没有错误但没有数据:/

Cf:docker编写日志

Attaching to dockernode_db_1, dockernode_dbseed_1
db_1     | 2015-12-22T00:57:46.629+0000 I CONTROL  [initandlisten] MongoDB starting : pid=1 port=27017 dbpath=/data/db 64-bit host=d48c97fd7ca5
dbseed_1 | 2015-12-21T17:42:46.609+0000 Failed: open /new_climat_final.json: no such file or directory
db_1     | 2015-12-22T00:57:46.629+0000 I CONTROL  [initandlisten] db version v3.2.0
dbseed_1 | 2015-12-21T17:42:46.609+0000 imported 0 documents
db_1     | 2015-12-22T00:57:46.629+0000 I CONTROL  [initandlisten] git version: 45d947729a0315accb6d4f15a6b06be6d9c19fe7
db_1     | 2015-12-22T00:57:46.629+0000 I CONTROL  [initandlisten] OpenSSL version: OpenSSL 1.0.1e 11 Feb 2013
db_1     | 2015-12-22T00:57:46.629+0000 I CONTROL  [initandlisten] allocator: tcmalloc
db_1     | 2015-12-22T00:57:46.629+0000 I CONTROL  [initandlisten] modules: none
db_1     | 2015-12-22T00:57:46.629+0000 I CONTROL  [initandlisten] build environment:
db_1     | 2015-12-22T00:57:46.630+0000 I CONTROL  [initandlisten]     distmod: debian71
db_1     | 2015-12-22T00:57:46.630+0000 I CONTROL  [initandlisten]     distarch: x86_64
db_1     | 2015-12-22T00:57:46.630+0000 I CONTROL  [initandlisten]     target_arch: x86_64
db_1     | 2015-12-22T00:57:46.630+0000 I CONTROL  [initandlisten] options: {}
db_1     | 2015-12-22T00:57:46.642+0000 I -        [initandlisten] Detected data files in /data/db created by the 'wiredTiger' storage engine, so setting the active storage engine to 'wiredTiger'.
db_1     | 2015-12-22T00:57:46.643+0000 I STORAGE  [initandlisten] wiredtiger_open config: create,cache_size=1G,session_max=20000,eviction=(threads_max=4),config_base=false,statistics=(fast),log=(enabled=true,archive=true,path=journal,compressor=snappy),file_manager=(close_idle_time=100000),checkpoint=(wait=60,log_size=2GB),statistics_log=(wait=0),
db_1     | 2015-12-22T00:57:47.829+0000 I CONTROL  [initandlisten] 
db_1     | 2015-12-22T00:57:47.830+0000 I CONTROL  [initandlisten] ** WARNING: /sys/kernel/mm/transparent_hugepage/enabled is 'always'.
db_1     | 2015-12-22T00:57:47.830+0000 I CONTROL  [initandlisten] **        We suggest setting it to 'never'
db_1     | 2015-12-22T00:57:47.830+0000 I CONTROL  [initandlisten] 
db_1     | 2015-12-22T00:57:47.830+0000 I CONTROL  [initandlisten] ** WARNING: /sys/kernel/mm/transparent_hugepage/defrag is 'always'.
db_1     | 2015-12-22T00:57:47.830+0000 I CONTROL  [initandlisten] **        We suggest setting it to 'never'
db_1     | 2015-12-22T00:57:47.830+0000 I CONTROL  [initandlisten] 
db_1     | 2015-12-22T00:57:47.833+0000 I FTDC     [initandlisten] Initializing full-time diagnostic data capture with directory '/data/db/diagnostic.data'
db_1     | 2015-12-22T00:57:47.833+0000 I NETWORK  [HostnameCanonicalizationWorker] Starting hostname canonicalization worker
db_1     | 2015-12-22T00:57:47.835+0000 I NETWORK  [initandlisten] waiting for connections on port 27017

编辑完整路径:
build:/path/to/dbseed

我不知道为什么它找不到
/new\u climat\u final.json
文件。 错误:

dbseed|1 | 2015-12-21T17:42:46.609+0000失败:打开 /new_climat_final.json:没有这样的文件或目录

但您可以在运行时指定端口


CMD:CMD mongoimport--host db--port 27018--db hpApiDev--coll-coll-type json--file/new\u climat\u final.json--jsonArray

docker compose日志中是否有任何内容?在尝试运行import.CMD mongoimport--host db--db hpApiDev--collection coll--type json--file/new_climat_final.json--jsonArray&&sleep 5之前,您可能需要在dbseed命令中等待以确保mongo已准备好接受连接?是否允许在插入过程中等待?我想它不会等5秒钟才完成。有关日志,请查看原始帖子中的“我的编辑:)。谢谢好的,我以前没看过,但是如果我明白的话,它找不到我的文件了?但是为什么它找不到文件呢?我的问题是confit很好,因为它不是
--端口27018
,而是
--端口27017
,事实上,我想到达端口27017:)如果有人知道,我如何在每次都不删除的情况下重建,我想要:)。我试过:
docker编写kill;docker编写rm-f;docker组合构建但不起作用。谢谢,两个小时前我才明白,只是构建没有改变……事实上,数据库是创建的,但里面没有集合?在docker compose日志中,我看到我的180000个文档被导入,但我的集合是空的,为什么?导入似乎是即时的,所以很奇怪,因为有很多数据。对不起,我以为我的问题解决了