当前位置: 首页 > news >正文

pythom导出mysql指定binlog文件

要求

要求本地有py环境和全局环境变量

先测试直接执行binlog命令执行命令

Windows 本地直接执行命令

# E:\output>E:\phpstudy_pro\Extensions\MySQL5.7.26\bin\mysqlbinlog binglog文件地址
# --no-defaults 不限制编码
# -h mysql链接地址
# -u mysql 链接名称
# -p mysql 密码
# -P3306 mysql 端口
# --read-from-remote-server  --raw  mysqlbinlog 命令的一个选项,它指示 mysqlbinlog 从远程 MySQL 服务器读取二进制日志文件进行解析。
# binlog.000003 文件地址#命令如下E:\output>E:\phpstudy_pro\Extensions\MySQL5.7.26\bin\mysqlbinlog --no-defaults -h 127.0.0.1 -u root -p -P3306 --read-from-remote-server --raw binlog.000003

代码

import subprocessdef download_binlogs(host, user, password, port, start_binlog, end_binlog, output_path):try:for binlog_number in range(start_binlog, end_binlog + 1):binlog_filename = f"binlog.{str(binlog_number).zfill(6)}"output_filename = f"{output_path}/binlog_{binlog_number}.sql"# 构建命令command = ['E:/phpstudy_pro/Extensions/MySQL5.7.26/bin/mysqlbinlog.exe','--no-defaults','-h', host,'-u', user,'-p' + password,'-P' + str(port),'--read-from-remote-server','--raw',binlog_filename]# 运行命令并将输出重定向到文件with open(output_filename, 'w') as output_file:subprocess.run(command, stdout=output_file)output_file.flush()  # 刷新缓冲区print(f"Binlog日志文件 '{binlog_filename}' 下载成功!保存为 '{output_filename}'")except Exception as e:print(f"下载失败:{e}")if __name__ == "__main__":# 替换以下信息为实际的Polardb连接信息和binlog文件范围polardb_host = "127.0.0.1"polardb_user = "root"polardb_password = "root"polardb_port = 3306start_binlog_number = 1end_binlog_number = 3output_directory = "E:/output"  # 替换为你想要保存文件的目录download_binlogs(polardb_host, polardb_user, polardb_password, polardb_port, start_binlog_number, end_binlog_number, output_directory)

python执行

python .\binlog.py

http://www.lryc.cn/news/235887.html

相关文章:

  • TDengine 跨版本迁移实战
  • FPGA设计时序约束八、others类约束之Set_Case_Analysis
  • xftp连接wsl2
  • Cross-View Transformers for Real-Time Map-View Semantic Segmentation 论文阅读
  • MySQL InnoDB 引擎底层解析(一)
  • redis安装(Windows和linux)
  • 【LeetCode刷题-树】--1367.二叉树中的链表
  • 【嵌入式 – GD32开发实战指南(ARM版本)】第2部分 外设篇 - 第3章 温度传感器DS18B20
  • 基于spring gateway 的静态资源缓存实现
  • SDUT OJ《算法分析与设计》搜索算法
  • 【NI-DAQmx入门】校准
  • C语言链表
  • LabVIEW进行MQTT通信及数据解析
  • 基于DOTween插件实现金币飞行到指定位置功能
  • python-opencv 培训课程作业
  • 【Go入门】并发
  • Java虚拟机运行时数据区结构详解
  • 华为OD机试 - 转盘寿司(Java JS Python C)
  • 【ATTCK】MITRE Caldera-emu插件
  • 23111709[含文档+PPT+源码等]计算机毕业设计基于Spring Boot智能无人仓库管理-进销存储
  • SDUT OJ《算法分析与设计》贪心算法
  • 金融业务系统: Service Mesh用于安全微服务集成
  • Linux下快速确定目标服务器支持哪些协议和密码套件
  • LeetCode100122. Separate Black and White Balls
  • 系列二十六、idea安装javap -c
  • nginx 如何根据IP做限流,以及 nginx 直接返回 json 格式数据
  • C语言链式栈
  • 【Go入门】 Go的http包详解
  • 解决k8s node节点报错: Failed to watch *v1.Secret: unknown
  • 日志维护库:loguru