我在macOS 10.12上。
mongod --version
db version v3.2.8
git version: ed70e33130c977bda0024c125b56d159573dbaf0
OpenSSL version: OpenSSL 1.0.2h 3 May 2016
allocator: system
modules: none
build environment:
distarch: x86_64
target_arch: x86_64
当我使用mongorestore时:
mongorestore --drop --db mydatabase /path/to/mongodump
导入开始但是90%的时间崩溃了:
fatal error: unexpected signal during runtime execution
[signal 0xb code=0x1 addr=0x697d5fa61ae3 pc=0x40d9e00]
goroutine 46 [running]:
runtime.throw(0x4683ea0, 0x2a)
/usr/local/Cellar/go/1.6.2/libexec/src/runtime/panic.go:547 +0x90 fp=0xc822235790 sp=0xc822235778
runtime.sigpanic()
/usr/local/Cellar/go/1.6.2/libexec/src/runtime/sigpanic_unix.go:12 +0x5a fp=0xc8222357e0 sp=0xc822235790
sync.(*Pool).Get(0x4c00390, 0x0, 0x0)
/usr/local/Cellar/go/1.6.2/libexec/src/sync/pool.go:102 +0x40 fp=0xc822235830 sp=0xc8222357e0
fmt.newPrinter(0x10)
/usr/local/Cellar/go/1.6.2/libexec/src/fmt/print.go:133 +0x27 fp=0xc822235870 sp=0xc822235830
fmt.Fprintf(0x55043f8, 0xc820026018, 0x45cda88, 0x6, 0xc822235968, 0x2, 0x2, 0xc82007e3f0, 0x0, 0x0)
/usr/local/Cellar/go/1.6.2/libexec/src/fmt/print.go:187 +0x30 fp=0xc8222358b8 sp=0xc822235870
github.com/mongodb/mongo-tools/common/log.(*ToolLogger).log(0xc8200145a0, 0xc82007e3f0, 0x8a)
/private/tmp/mongodb-20160713-59015-85tgmi/mongodb-src-r3.2.8/src/github.com/mongodb/mongo-tools/.gopath/src/github.com/mongodb/mongo-tools/common/log/tool_logger.go:84 +0x20e fp=0xc822235990 sp=0xc8222358b8
... (real log is very long)
它是否特定于我的操作系统?
感谢。
答案 0 :(得分:25)
我可以确认它确实是操作系统的内容,因为我已经更新并且遇到了同样的问题。我正在深入研究它,如果我找到了什么,我会让你知道!
<强>更新强>
在做了一些调查后,似乎它与MongoDB使用的Go依赖关系有关。目前MongoDB正在使用v1.4.2。事实证明,旧版本的Go on macOS Sierra存在问题。 https://github.com/golang/go/issues/16570解释说,问题已通过v1.7解决。除非有一种方法可以让MongoDB指向Go v1.7,我不确定在MongoDB升级其依赖项之前是否会解决这个问题。
更新2: 我计划向MongoDB提交与此问题有关的错误,直到我偶然发现... https://jira.mongodb.org/browse/TOOLS-1450。似乎MongoDB 3.2.10将使用Go v1.7并且应该修复您和我看到的问题。