备份数据库
mysqldump -uroot -p liuyang > liuyang.sql
mysqldump -uroot -p'123456' liuyang > liuyang.sql
mysqldump -uroot -p'123456' liuyang > liuyang.$(date +%F).sql
-B备份时添加创建此数据库语句,导入时不用手动创建数据库
mysqldump -uroot -p'123456' -B liuyang > liuyang.$(date +%F).sql.B
mysqldump -uroot -p'123456' -B liuyang|gzip > liuyang.$(date +%F).sql.gz
mysqldump -uroot -p'123456' --default-character-set=gbk -B liuyang|gzip > liuyang.$(date +%F).sql.gz
-A备份所有数据库
mysqldump -uroot -p'123456' --default-character-set=gbk -B -A|gzip > all.$(date +%F).sql.gz
-F刷新binlog文件,用于增量备份
mysqldump -uroot -p'123456' --default-character-set=gbk -B -A -F|gzip > all.$(date +%F).sql.gz
备份数据表
mysqldump -uroot -p'123456' liuyang ceshi > liuyang_ceshi.$(date +%F).sql
备份数据库结构
mysqldump -uroot -p'123456' -d liuyang > liuyang.$(date +%F).sql
备份数据表结构
mysqldump -uroot -p'123456' -d liuyang ceshi > liuyang_ceshi.$(date +%F).sql
精简备份数据库
mysqldump -uroot -p'123456' --compact liuyang> liuyang.$(date +%F).sql
还原数据库
mysql -uroot -p liuyang < liuyang.sql
mysql -uroot -p --default-character-set=gbk liuyang < liuyang.sql
mysql -uroot -p < liuyang.sql.B
gzip -d liuyang.sql.gz
增量备份
增量备份就是备份binlog二进制日志文件
rsync -avzP /opt/mysqldb/mysql-bin.* liuyang@192.168.1.171::sersync/ --password-file=/etc/rsync.passwd
增量还原数据库
#还原前先切割binlog文件
mysqladmin -u root -p flush-logs
#只把binlog文件中liuyang的数据库内容导出到一个文件内
mysqlbinlog --no-defaults -d liuyang mysql-bin.000002 > mysql-bin.sql
#先还原某时间点的全量备份
mysql -uroot -p < liuyang.2017-06-29.sql
#再还原该时间点后的增量备份
mysql -uroot -p liuyang < mysql-bin.sql
基于时间点的恢复
把binlog文件中'2017-06-29 10:20:30'开始之后所有数据库内容导出到一个文件内
mysqlbinlog --no-defaults mysql-bin.000002 --start-datetime='2017-06-29 10:20:30'> mysql-bin.sql
把binlog文件中'2017-06-29 10:20:30'开始之前所有数据库内容导出到一个文件内
mysqlbinlog --no-defaults mysql-bin.000002 --stop-datetime='2017-06-29 10:20:30'> mysql-bin.sql
基于位置点的恢复
把binlog文件中位置点100开始之后所有数据库内容导出到一个文件内
mysqlbinlog --no-defaults mysql-bin.000002 --start-position=100 > mysql-bin.sql
把binlog文件中位置点100开始之前所有数据库内容导出到一个文件内
mysqlbinlog --no-defaults mysql-bin.000002 --stop-position=100 > mysql-bin.sql