zoukankan      html  css  js  c++  java
  • 二 数据库的备份与恢复

    一 数据库的备份

    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  导入表空间
  • 相关阅读:
    02
    循环语句的注意点
    unsigned/signed int/char类型表示的数值范围
    C程序设计语言(第二版)--- 习题选
    第一篇来自博客园的博客--哈哈希望大家点赞
    脆弱的GPS系统--摘抄《环球科学》
    【Python入门自学笔记专辑】——函数式编程
    c++标准库conio.h文件
    推荐几个配色和图标网站
    Ajax实现简单下拉选项
  • 原文地址:https://www.cnblogs.com/liucsxiaoxiaobai/p/10738680.html
Copyright © 2011-2022 走看看