使用mysqldump & xtrabackup对数据库进行备份

数据备份是数据库的数据保护措施之一,数据备份可以使用工具轻松实现,结合定时任务也能一定程度上保证我们数据的安全。下面教你用mysqldump & xtrabackup 备份数据库的简陋方法

mysqldump的简单用法

#备份(导出)所有数据库的数据和结构(注意:这种方式备份,还原时,无需先创建数据库,可直接导入)
mysqldump -u root -p 'password' --all-databases > all.sql

 #备份指定数据库(db1和db2)
mysqldump -u root -p 'password' ---databases db1 db2 > db1-db2.sql

#恢复(导入)所有库
mysql -u root -p 'password' #导入某个库(只导入db1这个数据库,db2不导入)
mysql -u root -p 'password' db1 

xtrabackup工具(不支持mysql5.7)

介绍,能对InnoDB引擎进行增量备份(备份是不加锁),对MyISAM引擎全量备份(备份时会锁写)

第一:安装xtrabackup

wget https://www.percona.com/redir/downloads/percona-release/redhat/percona-release-0.1-4.noarch.rpm
rpm -ivh percona-release-0.1-4.noarch.rpm
yum clean all
yum makecache
yum install percona-xtrabackup.x86_64 -y

第二:备份数据库

#指定mysql的配置文件,指定mysql的用户,指定密码,指定用于存放备份的路径(注意:前提是my.cnf文件内指定了data的存放目录)#注意:innobackupex 不支持mysql 5.1的innodb备份
[root@iptables ~]# cat /etc/my.cnf
[mysqld]
datadir=/var/lib/mysql

innobackupex --defaults-file=/etc/my.cnf --user=root --password /mnt/mysqlback

第二:prepare数据库(预备份–apply-log)

#创建完的备份之后的数据还不能马上用于还原,需要回滚未提交事务,前滚提交事务,让数据库文件保持一致性
innobackupex --defaults-file=/etc/my.cnf --user=root --password --apply-log /mnt/mysqlback/2018-05-15

#成功后会输出,成功后备份可以被用来还原数据库了#prepare的过程,其实是读取备份文件夹中的配置文件,然后innobackupex重做已提交事务,回滚未提交事务,之后数据就被写到了备份的数据文件(innodb)中,并重建日志文件#--user-memory 指定prepare阶段可使用的内存大小,默认为10MB,内存多则快

第三:恢复数据库

注意,还原是先关闭服务,如果服务是启动的,那么就不能还原到datadir,并且datadir 必须是为空的,因为 innobackupex –copy-back 不会覆盖已存在的文件

#innobackupex 使用 --copy-back 来还原备份(recovery)
innobackupex --defaults-file=/etc/my.cnf --user=root --password --copy-back /mnt/mysqlback/2018-05-15
#innobackupex 会根据my.cnf的配置,将所有备份数据复制到my.cnf里面指定的 datadir 路径下#如果恢复成功,则有如下提示

第四:修改datadir目的的权限,启动数据库

#默认情况下是通过root用户恢复数据,所以mysql数据文件夹目录是root权限,需要修改为数据库程序的所有者权限
chown -R mysql:mysql datadir

附:备份压缩和流

#使用流特性,需要指定--stream 选项,使用tar备份(推荐方法)
innobackupex --defaults-file=/etc/my.cnf --user=root --password --stream=tar /mnt/mysqlback | gzip - > /mnt/mysqlback.tar.gz

#可用参数,--parallel=4 加速备份,这个选项指定xtrabackup备份文件的线程数#解压提取tar流文件,必须加 -i 参数,不然不可使用
tar -xizf /mnt/mysqlback.tar.gz

示例,备份mysql的boke数据库,并恢复

1:对mysql的boke库进行备份

innobackupex --defaults-file=/etc/my.cnf --user=root --password=111222 --database=boke --stream=tar /mnt/ 2>/mnt/back_data/boke.log | gizp 1>/mnt/back_data/boke.tar.gz

#说明
2>/mnt/back_data/boke.log #innobackupex的输出信息,写入日志文件,便于查阅核对,备份是否成功
1>/mnt/back_data/boke.tar.gz #打包压缩存储到该文件中

2:此处可以写一个脚本备份(back.sh)

#!/bin/shecho "开始备份----"`date`
LOG=boke_`date +%F-%H%M`.log
STR=boke_`date +%F-%H%M`.tar.gz

innobackupex --defaults-file=/etc/my.cnf --user=root --password=111222 --database=boke --stream=tar /mnt/back_data/ 2>/mnt/back_data/$LOG | gzip 1>/mnt/back_data/$STRecho "备份完成---"`date`

3:数据恢复

1:先停止数据库
2:解压
tar -izxvf /mnt/back_data/boke.tar.gz -C /mnt/back_data/db/ #没有db,需要mkdir /mnt/back_data/db/ 创建哦
3:恢复(确保datadir为空)
innobackupex --defaults-file=/etc/my.cnf --user=root --password=111222 --apply-log /mnt/back_data/db/
innobackupex --defaults-file=/etc/my.cnf --user=root --password=111222 --copy-back /mnt/back_data/db/
4:赋权
chown -R mysql:mysql /var/lib/mysql #这个目录是my.cnf 里面指定的datadir路径
5:启动数据库

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/221558.html<

(0)
运维的头像运维
上一篇2025-04-15 02:21
下一篇 2025-04-15 02:22

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注