二 数据库的备份与恢复
一 数据库的备份
1 普通备份 MySQL -uroot -p 数据库名.表名 < 路径可自定义 [root@es1 ~]# mysqldump -uroot -p haha < /root/haha.sql 2 完全备份 MySQL -uroot -p --all-databases > 路径可自定义 (可备份所有库) [root@es1 ~]# mysqldump -uroot -p --all-databases > /root/alldb.sql 3 同时备份指定的多个库 MySQL -uroot -p -B 库1 库2 > 路径可自定义 (可备份所有库) [root@es1 ~]# mysqldump -uroot -p -B mysql haha > /root/haha+mysql.sql
二 使用binlog日志
binlog日志的介绍
转自https://www.cnblogs.com/kevingrace/p/6065088.html
一、binlog日志介绍 1. 什么是binlog binlog日志用于记录所有更新了数据或者已经潜在更新了数据(例如,没有匹配任何行的一个DELETE)的所有语句。语句以“事件”的形式保存,它描述数据更改。 2. binlog作用 因为有了数据更新的binlog,所以可以用于实时备份,与master/slave主从复制结合。 3. binlog有关参数 log_bin 设置此参数表示启用binlog功能,并指定路径名称 log_bin_index 设置此参数是指定二进制索引文件的路径与名称 binlog_do_db 此参数表示只记录指定数据库的二进制日志 binlog_ignore_db 此参数表示不记录指定的数据库的二进制日志 max_binlog_cache_size 此参数表示binlog使用的内存最大的尺寸 binlog_cache_size 此参数表示binlog使用的内存大小,可以通过状态变量binlog_cache_use和binlog_cache_disk_use来帮助测试。 binlog_cache_use:使用二进制日志缓存的事务数量 binlog_cache_disk_use:使用二进制日志缓存但超过binlog_cache_size值并使用临时文件来保存事务中的语句的事务数量 max_binlog_size Binlog最大值,最大和默认值是1GB,该设置并不能严格控制Binlog的大小,尤其是Binlog比较靠近最大值而又遇到一个比较大事务时,为了保证事务的完整性,不可能做切换日志的动作,只能将该事务的所有SQL都记录进当前日志,直到事务结束 sync_binlog 这个参数直接影响mysql的性能和完整性 sync_binlog=0 当事务提交后,Mysql仅仅是将binlog_cache中的数据写入Binlog文件,但不执行fsync之类的磁盘 同步指令通知文件系统将缓存刷新到磁盘,而让Filesystem自行决定什么时候来做同步,这个是性能最好的。 sync_binlog=n,在进行n次事务提交以后,Mysql将执行一次fsync之类的磁盘同步指令,同志文件系统将Binlog文件缓存刷新到磁盘。 Mysql中默认设置sync_binlog=0,即不作任何强制性的磁盘刷新指令,这时性能是最好的,但风险也是最大的。一旦系统绷Crash,在文件系统缓存中的所有Binlog信息都会丢失
1 修改配置文件启用binlog日志
[root@es1 ~]# vim /etc/my.cnf
[mysqld] log-bin=mysql-bin //启用二进制日志,并指定前缀 server_id=1 binglog_format=STATEMENT ////在 Mysql5.7 中,binlog 日志格式默 认为 ROW,但它不记录 sql 语句上下文相关信息。需要将 binlog 日志格式修改为 STATEMENT
[root@es1 ~]# systemctl restart mysqld #重启数据库
查看binlog日志文件
[root@es1 ~]# mysqlbinlog --no-defaults /var/lib/mysql/mysql-bin.000001
数据恢复(按日志名恢复)
#mysqlbinlog /logdir/plj.000001 | mysql -uroot -p123456
数据恢复(按时间点)
[root@dbsvr1 ~]# mysqlbinlog \ --start-datetime="190419 19:55:47" \ #开始时间点 --stop-datetime="190419 20:06:39" \ # 结束时间点 /var/lib/mysql/mysql-bin.000002 | mysql -u root -p
pos 点(偏移量)恢复
#mysqlbinlog --start-position= 数 字 1 --stop-position= 数 字 2 /logdir/plj.000001 | mysql -uroot -p123456
三 XtraBackup 备分工具
1安装XtraBackup 备分工具
1 )查看软件包的描述信息
[root@es1 ~]# rpm -qpi percona-xtrabackup-24-2.4.7-1.el7.x86_64.rpm 查看软件包的描述信息
2 )安装依赖安装依赖包 perl-DBD-MySQL perl-Digest-MD5 libev 其中libev可在网上去下载
[root@es1 ~]# yum -y install perl-DBD-MySQL perl-Digest-MD5 [root@es1 ~]# rpm -ivh libev-4.15-1.el6.rf.x86_64.rpm 此包需要去网上找 [root@es1 ~]# rpm -ivh percona-xtrabackup-*.rpm
警告:percona-xtrabackup-24-2.4.7-1.el7.x86_64.rpm: 头V4 DSA/SHA1 Signature, 密钥 ID cd2efd2a: NOKEY
错误:依赖检测失败:
rsync 被 percona-xtrabackup-24-2.4.7-1.el7.x86_64 需要
上面提示安装错误是缺少rsync软件依赖
[root@es1 ~]# yum -y install rsync [root@es1 ~]# rpm -ivh percona-xtrabackup-*.rpm 警告:percona-xtrabackup-24-2.4.7-1.el7.x86_64.rpm: 头V4 DSA/SHA1 Signature, 密钥 ID cd2efd2a: NOKEY 准备中... ################################# [100%] 正在升级/安装... 1:percona-xtrabackup-24-2.4.7-1.el7################################# [100%]
3)确认安装的主要程序/脚本 显示以下内容就表示成功了
[root@es1 ~]# rpm -ql percona-xtrabackup-24 /usr/bin/innobackupex /usr/bin/xbcloud /usr/bin/xbcloud_osenv /usr/bin/xbcrypt /usr/bin/xbstream /usr/bin/xtrabackup /usr/share/doc/percona-xtrabackup-24-2.4.7 /usr/share/doc/percona-xtrabackup-24-2.4.7/COPYING /usr/share/man/man1/innobackupex.1.gz /usr/share/man/man1/xbcrypt.1.gz /usr/share/man/man1/xbstream.1.gz /usr/share/man/man1/xtrabackup.1.gz
2:使用 XtraBackup 执行数据库备份
如果需要查看XtraBackup的用法
--host 主机名 --port 3306 --user 用户名 --password 密码 --databases="库名" --databases="库 1 库 2" --databases="库.表" --no-timestamp 不用日期命名备份文件存储的子目录,使用备份的数据库名做备份目录名 --no-timestmap 不使用日期命名备份目
--redo-only 日志回滚合并(最后一次增量备份日志回滚不需要此项)--apply-log-only --apply-log 准备还原(回滚日志) --copy-back 恢复数据 --incremental 目录名 增量备份 --incremental--basedir=目录名 增量备份时指定上一次备份数据存储的目录名 --incremental-dir=目录名 准备恢复数据时,指定增量备份数据存储目录名 --export 导出表信息 import 导入表空间
innobackupex –help可以查到详细用法,当然全英文,可用谷歌或百度翻译
完全备份 innobackupex –user=用户–password=密码 –databases=“库名” 备份路径
[root@es1 ~]# innobackupex --user=root --password=123456 /backup/mysql [root@es1 ~]# ls /backup/mysql/2019-04-20_17-58-50/ #这就可以查询到你所有的备份内容了 backup-my.cnf ib_buffer_pool mysql sys xtrabackup_binlog_info xtrabackup_info haha ibdata1 performance_schema xixihaha xtrabackup_checkpoints xtrabackup_logfile
增量备份
然后在数据库中添加一条记录在做一次备份 语法:innobackupex --user=用户 --password=密码 --databases=“库名” --incremental 指定增量备份目录名 --incremental-basedir=/完全备份目录/ --no-timestamp 增量备份就上述公式可根据需求套用一些参数,第一次增量第二次增量没有去呗,就是需要指定不同的备份目录
数据恢复(恢复完全备份)
innobackupex --user 用户名 --password 密码 --databases=“库名” --apply-log --redo-only 恢复完全备份的路径
数据恢复(恢复增量)
innobackupex --user 用户名 --password 密码 --databases=“库名” --apply-log --redo-only 恢复完全备份的路径 --incremental-dir=“备份的增量目录”
导出信息表
innobackupex --user 用户名 --password 密码 --databases=“库名” --apply-log --export /导出目录’
恢复某个表
首先要拷贝表信息文件到数据库文件存储目录 然后再给数据库文件目录授权 mysql>system chown mysql:mysql /var/lib/myql mysql>alter table 库名.表名 import tablespace 导入表空间