千家信息网

如何提取MySQL binlog中指定表的操作记录

发表于:2025-01-25 作者:千家信息网编辑
千家信息网最后更新 2025年01月25日,小编给大家分享一下如何提取MySQL binlog中指定表的操作记录,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!一段简单的Python脚本,需要本地装了合适版本的mysqlbinl
千家信息网最后更新 2025年01月25日如何提取MySQL binlog中指定表的操作记录

小编给大家分享一下如何提取MySQL binlog中指定表的操作记录,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!

一段简单的Python脚本,需要本地装了合适版本的mysqlbinlog工具。
支持Python 2.7+

点击(此处)折叠或打开

  1. #_*_ coding:utf-8 _*_


  2. import sys

  3. import os

  4. import io


  5. binlogfile = sys.argv[1]

  6. database_name = sys.argv[2]

  7. table_name = sys.argv[3]


  8. def format_binlog():

  9. os.system('mysqlbinlog --base64-output=decode-rows -v '+binlogfile+'>'+binlogfile+'.txt')


  10. def pickupbinlog():

  11. f = io.open(binlogfile+'.txt','r')

  12. fw = io.open(database_name+'_'+table_name+'.txt','a')

  13. priv_str = ''

  14. priv_line = ''

  15. goal_flag = 0

  16. for row in f:

  17. # 处理首行

  18. if row[0:3] == '###' and priv_str != '###':

  19. if database_name in row and table_name in row:

  20. goal_flag = 1

  21. fw.write(priv_line)

  22. fw.write(row)

  23. # 处理末行

  24. if row[0:3] != '###' and priv_str == '###':

  25. goal_flag = 0

  26. # 处理目标操作

  27. if row[0:3] == '###' and priv_str == '###' and goal_flag == 1:

  28. fw.write(row)

  29. priv_str = row[0:3]

  30. priv_line = row

  31. f.close()

  32. fw.close()


  33. if __name__ == '__main__':

  34. # python2.7 pickupbinlog.py mysql-bin.001051 dbname tablename

  35. # python3 pickupbinlog.py mysql-bin.001051 dbname tablename

  36. format_binlog()

  37. pickupbinlog()

看完了这篇文章,相信你对"如何提取MySQL binlog中指定表的操作记录"有了一定的了解,如果想了解更多相关知识,欢迎关注行业资讯频道,感谢各位的阅读!

0