文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

菜鸟学Linux 第079篇笔记 mysql备份lvm

2024-04-02 19:55

关注

菜鸟学Linux 第079篇笔记 mysql备份lvm




内容总览

上节知识点补充

单表的导出导入

LVM创建快照实现数据库备份






上节少了一点知识点

使用mysqldump备份还原时 要临时将sql_log_bin关闭(临时性的关闭二进制日志记录)

因为还原时所生成的二进制日志对于下一次备份时是没有用的,所以在还原时要关闭二进制

日志记录  切记切记

SET sql_log_bin=0;   关闭


导入使用

mysql> \. /path/backup.sql


SET sql_log_bin=1;  开启


mysqldump 

--databases DB1,DB2

--all-databases

--flush-logs

--routines

--triggers

--master-data={0|1|2}


MyISAM 温备份

--lock-all-tables

--lock-table


InnoDB 热备份

--single-transaction



逻辑备份

1. 浮点数据丢失精度;

2. 备份的数据更点用存储空间,压缩后可大大节省空间

3. 不适合对大数据库做完全备份


INNODB

SHOW ENGINES INNODB STATUS;


mvcc, REPEATABLE-READ

--single-transaction




直接将表导出不添加任何信息

mysql> SELECT * INTO OUTFILE '/path/file_name.txt' FROM tb_name [WHERE]

mysql> SELECT * INTO OUTFILE '/tmp/tutor.txt' FROM tutors;

(注意所给的系统路径 必须mysql用户可以访问的目录 )


还原导出的表

导入之前需要重新建立表,和对应的列名称及其属性

mysql> CREATE TABLE tutor LIKE tutors;

mysql> LOAD DATA INFILE '/tmp/tutor.txt' INTO TABLE tutor;


此种方式仅做单张表备份,速度快 (且不会写进二进制日志文件里)





几乎热备 LVM

snapshot


前提

1. 数据文件要在逻辑卷上

2. 此逻辑卷所在卷组必须有足够空间使用快照卷

3. 使用快照热备 数据文件和事务日志必须在一个逻辑卷里



1. 锁表

mysql> FLUSH TABLES WITH READ LOCK;

mysql> FLUSH LOGS;

mysql> SHOW MASTER STATUS;


此时切记不要退出会话, 要新建立一个会话执行如下命令


# mkdir /backup

# mysql -e "SHOW MASTER STATUS\G;" > /backup/master-`date +%F`.info


2. 创建快照并备份数据

# lvcreate -L 50M -s -p r -n mydata-snap /dev/myvg/mydata


                释放表锁

mysql> UNLOCK TABLES;


# mount /dev/myvg/mydata-snap /mnt/ -o ro

# mkdir /backup/full-backup-`date +%F`

# cp -a /mnt/data/* /backup/full-backup-2017-01-13/

# rm -rf /backup/full-backup-2017-01-13/mysql-bin.*

(我这里是模拟的,其实二进制日志不应该也在数据文件里的所以删除掉)

# cd

# umount /mnt

# lvremove --force /dev/myvg/mydata-snap


3. 备份二进制日志文件

# cat /backup/master-2017-01-13.info

会在此里边查找到位置我的是107

二进制日志文件是mysql-bin.000005


# mysqlbinlog --start-position=107 /mydata/data/mysql-bin.000003

此句在于找出其开始时间,下一句是备份


# mysqlbinlog --start-datetime='2017-01-13' mysql-bin.000003 

mysql-bin.000004 mysql-bin.000005...  > /backup/binary/binary-`date %F`.sql



4. 模拟数据库损坏并还原

将数据库里所有信息删除

# service mysqld stop

# rm -rf /mydata/data/*

# killall mysqld


实现还原

# cp -a /backup/full-backup-2017-01-13/* /mydata/data/

# ls /mydata/data

# service mysqld start


5. 即时点还原(导入二进制日志文件)

mysql> SET sql_log_bin=0;

mysql> SOURCE /backup/binary-2017-01-13.sql

mysql> SET sql_log_bin=1;



总结步骤

1.打开会话,施加读锁,锁定所有表

mysql> FLUSH TABLES WITH READ LOCK;

mysql> FLUSH LOGS;


2.通过另一个终端,保存二进制日志文件及相关位置信息

# mysql -uroot -p -e "SHOW MASTER STATUS\g" > /path/master-`date +%F`.info


3.创建快照

# lvcreate -L # -s -p r -n LV_name /dev/path/source-lv


4.释放锁

mysql> UNLOCK TABLES;


5.挂载快照卷,备份

mount 

cp


6.删除快照卷


7.增量备份二进制日志


8.还原时一定要记得将二进制日志给临时性的关闭掉



InnoDB 数据库一定要记得使用了

innodb_file_per_table           | ON


要不然备份单个数据库使用快照这种方式就比较麻烦了


创建快照来备份数据库比较适合进行所有库备份




阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯