lvm快照备份

前提

数据文件要在逻辑卷上;

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

数据文件和事务日志要在同一个逻辑卷上;

前提:MySQL数据lv和将要创建的快照要在同一vg,vg要有足够的空间存储

优点

几乎是热备(创建快照前把表上锁,创建完毕后立即释放)

支持所有的存储引擎

备份速度快

无需使用昂贵的商业软件(操作系统级别的)

缺点

可能需要部门协调(使用操作系统级别的命令,DBA一般没有权限)

无法预计服务停止时间

数据如果分布在多个卷上比较麻烦

操作流程

1)锁表 flush table with read lock

2)查看position号并记录,便于后期恢复 show master status

3)创建snapshot快照 create snapshop

4)解表 unlock tables

5)挂载snapshot

6)拷贝snapshot数据,进行备份。备份整个数据库之前,要关闭mysql服务(保护ibdata1文件)

7)卸载

8)移除快照

步骤

复制代码
# 创建逻辑卷
[root@openEuler-1 ~]# vgcreate mysql /dev/sdbd
[root@openEuler-1 ~]# lvcreate -n lv_mysql -L 5G mysql
[root@openEuler-1 ~]# mkfs.ext4 /dev/mysql/lv_mysql
 
# 停止mysql服务
[root@openEuler-1 ~]# systemctl stop mysqld
 
# 备份所有的数据文件到指定的地方
[root@openEuler-1 ~]# cd /var/lib/mysql
[root@openEuler-1 mysql]# tar czf /tmp/mysql.tar.gz *
 
# 挂载逻辑卷到当前mysql的数据目录里
[root@openEuler-1 mysql]# cd
[root@openEuler-1 ~]# mount /dev/mysql/lv_mysql /var/lib/mysql
 
# 将刚刚备份的数据解压到数据目录里
[root@openEuler-1 ~]# tar xf /tmp/mysql.tar.gz -C /var/lib/mysql
 
# 更改权限重新启动
[root@openEuler-1 ~]# chown mysql. -R /var/lib/mysql/
[root@openEuler-1 ~]# systemctl restart mysqld
 
# 编写备份脚本
[root@openEuler-1 ~]# vim bak_mysql.sh
[root@openEuler-1 ~]# cat bak_mysql.sh
#!/bin/bash
#########################
#File name:bak_mysql.sh
#Email:obboda@163.com
#Created time:2025-01-19 12:16:20
#Description:
#########################
 
bak_dir=/mysql/lvm_bak/$(date +%F)
[ -d ${bak_dir} ] || mkdir -p ${bak_dir}
 
echo "flush tables with read lock; system lvcreate -n lv_mysql_s -L 500M -s /dev/mysql/lv_mysql; unlock tables;"
 | mysql -uroot -pMySQL@123
 
[ -d /mnt/mysql/ ] || mkdir /mnt/mysql
mount /dev/mysql/lv_mysql_s /mnt/mysql
 
rsync -az /mnt/mysql/ ${bak_dir}
if [ $? -eq 0 ]
then
  umount /mnt/mysql/ && lvremove -f /dev/mysql/lv_mysql_s &>/dev/null
 
 
# 测试:
[root@openEuler-1 ~]# bash bak_mysql.sh
# 修改配置文件(一般是在/etc/my.cnf内)
[root@openEuler-1 ~]# vim /etc/my.cnf.d/mysql-server.cnf
#datadir=/var/lib/mysql
datadir=/mysql/lvm_bak/2025-01-19
# 修改目录权限
[root@openEuler-1 ~]# chown -R mysql.mysql /mysql/lvm_bak/2025-01-19/
# 重启服务
[root@openEuler-1 ~]# systemctl restart mysqld
# 查看数据库
[root@openEuler-1 ~]# mysql -e "select * from school.Student"
+-----+----------+------+------+-----------------+
| Sno | Sname    | Ssex | Sage | Sdept           |
+-----+----------+------+------+-----------------+
|   1 | 陆亚     | 男   |   24 | 计算机网络      |
|   2 | tom      | 男   |   26 | 英语            |
|   3 | 张阳     | 男   |   21 | 物流管理        |
|   4 | alex     | 女   |   22 | 电子商务        |
|   5 | xumubin  | 男   |   29 | 中文专业        |
|   6 | wangzhao | 男   |   21 | 导弹专业        |
+-----+----------+------+------+-----------------+
相关推荐
TeleostNaCl3 小时前
如何安装 Google 通用的驱动以便使用 ADB 和 Fastboot 调试(Bootloader)设备
android·经验分享·adb·android studio·android-studio·android runtime
练小杰1 天前
【Mysql-installer-community-8.0.26.0】Mysql 社区版(8.0.26.0) 在Window 系统的默认安装配置
数据库·sql·mysql·adb·配置文件·mysql安装·关系型数据库
袁美丽..1 天前
Android studio的adb和终端的adb互相抢占端口
android·adb·android studio
fatiaozhang95272 天前
浪潮CD1000-移动云电脑-RK3528芯片-2+32G-安卓9-2种开启ADB ROOT刷机教程方法
android·网络·adb·电脑·电视盒子·刷机固件·机顶盒刷机
黎宇幻生2 天前
Java全栈学习笔记30
android·adb
今人不见古时月,今月曾经照古人4 天前
将 Android 设备的所有系统日志(包括内核日志、系统服务日志等)完整拷贝到 Windows 本地
windows·adb
zhangphil4 天前
Android adb shell命令分析应用内存占用
android·adb
华农第一蒟蒻4 天前
Elasticsearch赋能3D打印机任务统计分析
java·大数据·spring boot·后端·elasticsearch·adb·maven
一个CCD4 天前
MySQL主从复制之进阶延时同步、GTID复制、半同步复制完整实验流程
android·mysql·adb
独行soc6 天前
2025年渗透测试面试题总结-42(题目+回答)
android·数据库·安全·adb·面试·渗透测试·sqlite