pythom导出mysql指定binlog文件

要求

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

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

Windows 本地直接执行命令

python 复制代码
# 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

代码

python 复制代码
import subprocess

def 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 = 3306
    start_binlog_number = 1
    end_binlog_number = 3
    output_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
相关推荐
沈浩(种子思维作者)1 天前
真的能精准医疗吗?癌症能提前发现吗?
人工智能·python·网络安全·健康医疗·量子计算
njsgcs1 天前
ue python二次开发启动教程+ 导入fbx到指定文件夹
开发语言·python·unreal engine·ue
io_T_T1 天前
迭代器 iteration、iter 与 多线程 concurrent 交叉实践(详细)
python
华研前沿标杆游学1 天前
2026年走进洛阳格力工厂参观游学
python
Carl_奕然1 天前
【数据挖掘】数据挖掘必会技能之:A/B测试
人工智能·python·数据挖掘·数据分析
AI小怪兽1 天前
基于YOLOv13的汽车零件分割系统(Python源码+数据集+Pyside6界面)
开发语言·python·yolo·无人机
wszy18091 天前
新文章标签:让用户一眼发现最新内容
java·python·harmonyos
Eric.Lee20211 天前
python实现 mp4转gif文件
开发语言·python·手势识别·手势交互·手势建模·xr混合现实
EntyIU1 天前
python开发中虚拟环境配置
开发语言·python
wszy18091 天前
顶部标题栏的设计与实现:让用户知道自己在哪
java·python·react native·harmonyos