解决mongorestore恢复警告don‘t know what to do with subdirectory “xxxx/xxx“, skipping...
  TEZNKK3IfmPf 2023年11月14日 23 0

解决方法

使用mongodump导出时,每一个集合都会对应到以下两个文件:

  • 集合名.metadata.json
  • 集合名.bson

使用mongorestore时,导入的文件直接指定到.bson后缀的文件,如使用:

./mongorestore -h 192.168.1.150:27017
	--authenticationDatabase admin
	-u mongo_user
	-p mongo_pass
	-d my_data
	/Users/xq/Desktop/mongo_wind_data/wind_data/stock_k_line.bson

这样就可以恢复一个库里的固定的集合

问题解析

通常来讲是可以直接把文件夹传进去的,有时候会成功,但是如果失败,会报一个编码的报错,且在谷歌上是人类未知领域,几乎找不到解决方案,因此只好曲线救国,循环导出的文件夹里的每一个bson文件

这里有一个小脚本:

for bson_file in `ls 恢复数据的文件夹`: # 循环想要恢复数据的那个文件夹,拿到文件名
do
    cd ~/mongodb-database-tools-macos-x86_64-100.6.1/bin # 进入到包含mongorestore的工具包目录
    if [[ "$bson_file" == *".bson"* ]]; then
        ./mongorestore -h 127.0.0.1:27017 --authenticationDatabase admin -u user -p password -d cover_data ~/my_data/$bson_file
        # 使用用户名user,密码password,来运行mongorestore,直接恢复具体的 ~/my_data/xxx.bson文件
    fi
done

使用示例:

for bson_file in `ls wind_data`:
do
    cd ~/mongodb-database-tools-macos-x86_64-100.6.1/bin
    if [[ "$bson_file" == *".bson"* ]]; then
        ./mongorestore -h 127.0.0.1:27017 --authenticationDatabase admin -u user -p password -d cover_data ~/my_data/$bson_file
    fi
done
【版权声明】本文内容来自摩杜云社区用户原创、第三方投稿、转载,内容版权归原作者所有。本网站的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@moduyun.com

  1. 分享:
最后一次编辑于 2023年11月14日 0

暂无评论

推荐阅读
  TEZNKK3IfmPf   2024年05月31日   25   0   0 sqlite数据库
  TEZNKK3IfmPf   2024年05月31日   26   0   0 数据库mysql
  TEZNKK3IfmPf   2024年05月31日   25   0   0 数据库mysql
TEZNKK3IfmPf