通过 bsondump 命令工具 解析备份产生的bson文件
bsondump命令是将BSON格式的文件转换为可读性更强的文件格式,例如转为为JSON 格式的文档,bsondump默认转换为json格式的文档。
当通过mongodump命令进行备份时,如果有参数 --oplog,会在备份路径下产生一个oplog.bson文件。
这个文件是bson格式,没有办法直接查看的,打开乱码,
例如,tail -3 oplog.bson,打开 如下:

所以,我们可以先通bsondump将bson转换为json格式。
bsondump添加参数--outFile还可以,将转换后的数据以文件的形式输出出来。
例如,在mongodb可执行文档bin下执行,将/QQ/back/20180416/oplog.bson转换为json格式,输出的文件为/QQ/back/20180416/oplogtest01.json
执行命令如下:
./bsondump --quiet /QQ/back//oplog.bson --outFile /QQ/back//oplogtest01.json
转换后的oplogtest01.json可以直接查看。
如下:

现在回顾一下,我们之前实现的MongoDB增量备份,其导出数据是通过mongodump命令导出 -d local -c oplog.rs 的数据,产生的文件也包含oplog.rs.bson
导出的文件如下

这种bson文件的读取,也是需要bsondump转换的。
注意事项:
1:mongodump 备份时,如果有压缩参数 --gzip ,则备份生成的bson文件,通过bsondump不可以正常解析,报错:
0 objects found;unexpected EOF
错误截图如下:

2:转换后,增加可读性的好处是方便定位操作指令在什么时候产生的。例如,如果开发同学告诉我们在昨天的16点左右,有一个update误操作,具体的时间点很难定位。这时候,我们虽然有增量备份,如果你不知道具体的时间点,具体的 "ts" 数据,是不好恢复的。
而转换后,我们可以根据相关的命令,在转换后的文件中查找。
本文版权归作者所有,未经作者同意不得转载,谢谢配合!!!
通过 bsondump 命令工具 解析备份产生的bson文件的更多相关文章
- 命令行工具解析Crash文件,dSYM文件进行符号化
		备份 文/爱掏蜂窝的熊(简书作者)原文链接:http://www.jianshu.com/p/0b6f5148dab8著作权归作者所有,转载请联系作者获得授权,并标注“简书作者”. 序 在日常开发 ... 
- Python 命令行解析工具 Argparse介绍
		最近在研究pathon的命令行解析工具,argparse,它是Python标准库中推荐使用的编写命令行程序的工具. 以前老是做UI程序,今天试了下命令行程序,感觉相当好,不用再花大把时间去研究界面问题 ... 
- python之命令行解析工具argparse
		以前写python的时候都会自己在文件开头写一个usgae函数,用来加上各种注释,给用这个脚本的人提供帮助文档. 今天才知道原来python已经有一个自带的命令行解析工具argparse,用了一下,效 ... 
- 2019-9-2-C#命令行解析工具
		title author date CreateTime categories C#命令行解析工具 lindexi 2019-09-02 12:57:37 +0800 2018-2-13 17:23: ... 
- python命令行解析工具argparse模块【1】
		argpaser是python中很好用的一个命令行解析模块,使用它我们可以很方便的创建用户友好型命令行程序.而且argparse会自动生成帮助信息和错误信息. 一.示例 例如下面的例子,从命令行中获取 ... 
- Shell脚本字符串匹配及日常命令工具 - 用法总结(技巧指南)
		Shell提供了很多字符串和文件处理的命令,如awk.expr.grep.sed等命令,还有文件的排序.合并和分割等一系列的操作命令.下面重点总结下Shell字符串处理.文本处理以及各类命令及函数用法 ... 
- 命令行解析Crash文件
		做了快两年的开发了,没有写过博客,最近公司app上架,程序崩溃被拒绝了,可是给的crash文件,又看不出哪里的问题,网上各种搜,终于找到了解决的办法,想想还是写个博客吧,希望给哪些也遇到这类问题的朋友 ... 
- Linux资源监控命令/工具(综合)
		目录: ps pstree pidof top free uptime ifuser lsof mpstat vmstst pidstat iostat iotop watch sar 1.ps 1) ... 
- Windows命令行command的Shell命令详细解析和语法
		CMD命令大全及详细解释和语法 Microsoft Windows XP [版本 5.1.2600] 有关某个命令的详细信息,请键入 HELP 命令名 ASSOC 显示或修改文件扩展名关联. A ... 
随机推荐
- 实现对ASP.NETMvc及Asp.NetCore的权限控制
			AccessControlHelper Build Status Intro 由于项目需要,需要在 基于 Asp.net mvc 的 Web 项目框架中做权限的控制,于是才有了这个权限控制组件. 项目 ... 
- java客户端调用webService
			啥也不想说,以前使用的方法突然不行了.各种网搜(记得别忘记到jar包哦:axis.jar) 看代码,第一种方式,也就是以前的方式: 改方式不用表名参数名称 public static String i ... 
- spring的7个模块
			Spring 是一个开源框架,是为了解决企业应用程序开发复杂性而创建的.框架的主要优势之一就是其分层架构,分层架构允许您选择使用哪一个组件,同时为 J2EE 应用程序开发提供集成的框架. Spring ... 
- sqlserver聚合索引(clustered index) / 非聚合索引(nonclustered index)的理解
			1. 什么是聚合索引(clustered index) / 什么是非聚合索引(nonclustered index)? 可以把索引理解为一种特殊的目录.微软的SQL SERVER提供了两种索引:聚集索 ... 
- maven重新导入,不能拉到最新jar包的问题
			需要删除本地jar,再重新reimport pom.xml 
- JSONUtils.toJSONString的一个坑
			JSONUtils.toJSONString(null); //返回一个为"null"的字符串 这样会导致一个结果就是StringUtils.isBlank判断后,会为false ... 
- How to untar a TAR file using Apache Commons
			import org.apache.commons.compress.archivers.tar.TarArchiveEntry; import org.apache.commons.compress ... 
- JavaScript设计模式 Item 5 --链式调用
			1.什么是链式调用 这个很容易理解,例如: $(this).setStyle('color', 'red').show(); 一般的函数调用和链式调用的区别:调用完方法后,return this返回当 ... 
- Android SlidingMenu 使用详解
			转载请标明出处:http://blog.csdn.net/lmj623565791/article/details/36677279 很多APP都有侧滑菜单的功能,部分APP左右都是侧滑菜单~Slid ... 
- map用法
			描述: map()会根据提供的参数对指定序列做映射. 语法: map(function,iterable) function:函数以参数列表中的每一个元素调用function函数,返回包含每次func ... 
