如何使用mysqldump备份数据库

一、背景

在开发项目中,数据库是核心资产。除了做主备冗余增加可靠性外,定期备份数据也是必须的。

使用mysqldump备份数据具有操作简单,备份和恢复时间短的优点(mysqldump备份数据生成的是批量insert语句,恢复数据时间比navcat导出的逐条插入方式快不只一个数量级)。

总之、如果你使用的是mysql数据库,需要备份数据,使用mysqldump就没错了。

二、解决方案

开发一个备份数据库的批处理脚本,自动完成多服务器上多数据库的备份、数据压缩工作。

1、首先,准备环境

建一个backup_db文件夹:

如何使用mysqldump备份数据库

说明:mysql.exe、mysqldump.exe从mysql数据库bin目录下拷贝。7z.exe和7z.dll从7z安装目录下拷贝(推荐使用7z,免费又好用)。

2、其次,开发脚本

编辑上面截图中的backup.bat文件。

@echo off
set curDir=%CD%

::1、初始化待备份数据库IP地址与数据库名称的对应关系
set dbIpMap="192.168.1.102,testdb1"^
 "192.168.1.102,testdb2"^
 "192.168.1.102,testdb3"

::2、创建存放数据库备份文件的临时文件夹
set folderName=%DATE:~0,4%%DATE:~5,2%%DATE:~8,2%%TIME:~0,2%%TIME:~3,2%%TIME:~6,2%
mkdir "%curDir%\%folderName%"

::设置变量延时赋值
setlocal ENABLEDELAYEDEXPANSION

::3、循环备份数据库中的所有表结构和数据
for %%a in (%dbIpMap%) do (

    set dbPair=%%a

    ::删除引号
    set dbip=!dbPair:"=!

    @echo 正在备份数据库:!dbip!...

    for /f "delims=, tokens=1,2" %%i in ("!dbip!") do (
        set ip=%%i
        set dbName=%%j

        mysqldump -h192.168.1.102 -uroot !dbName!>"%curDir%\%folderName%\!dbName!.sql"
    )

    @echo 备份数据库完成!

    ::备份的文件可能比较大,做一下压缩
    7z a "%curDir%\%folderName%\!dbName!.zip" "%curDir%\%folderName%\!dbName!.sql"

    ::备份后删除原始文件
    del /f "%curDir%\%folderName%\!dbName!.sql"
)

编写完上面的批处理脚本后,可以把它添加到操作系统的定时任务里面,这样就每天定时备份了,不用人工干预。

三、写在后面的话

备份文件经过压缩后已经极大缩小了(文本文件的压缩比是很高的),但日积月累还是可能很占磁盘空间,特别是数据量很大的情况下。

可以再加一些脚本处理,将压缩后的文件上传到公司的配置库上,这样既解决了磁盘空间问题也解决了防数据丢失的问题。这块要看公司使用的是什么配置库, SVN/ClearCase/Git使用的命令不一样,可以翻一手册;都比较简单。

上一篇:使用Mysqldump 备份数据库


下一篇:Java参数按值传递?按引用传递