业务上需要根据MySQL的mysql-bin.index实现增量数据同步恢复,用到了文件对比,方法记录如下:
一:comm命令实现
comm命令的参数
-1 不显示只在第1个文件里出现过的列。
-2 不显示只在第2个文件里出现过的列。
-3 不显示只在第1和第2个文件里出现过的列。
常用的用法如下:
comm -12 就只显示在两个文件中都存在的行;
comm -23 只显示在第一个文件中出现而未在第二个文件中出现的行;
comm -3 显示第一个文件中未出现,在第二个中出现的内容
如 comm -3 2017060612_bin.log /home/data/mysql/binlog/mysql-bin.index
运行结果如下/home/data/mysql/binlog/mysql-bin.009021
/home/data/mysql/binlog/mysql-bin.009022
两个文件的内容在比较前,一定要进行sort排序。不然输出的结果将是错误的,就是说顺序必须一致
二:diff命令比较
diff命令是一个比较经典的文本比较工具了,diff命令较comm的参数要多。其经常和patch命令组合使用,进行补丁升级。其默认使用的是-a参数,即逐行比较两个文件之间的不同。此处我们要实现想要得到的结果,还需要配合grep和awk实用:
diff 2.txt 1.txt |grep "
注:此处也发现,在使用diff命令进行比较时,也需要预先对经比较的文件进行sort排序,不然输出的结果同样是不正确的。
F