0

0

Linux LVM 快照备份与恢复实践

冷炫風刃

冷炫風刃

发布时间:2026-02-26 18:23:02

|

258人浏览过

|

来源于php中文网

原创

快照空间耗尽导致“snapshot is full”错误,因cow机制下原lv写入需额外存储旧数据;创建时须显式指定足够大小(如原lv的20%),并及时监控snap%、激活快照、避免长期留存。

linux lvm 快照备份与恢复实践

lvcreate -s 创建快照时为什么报错 snapshot: snapshot is full

快照空间耗尽是 LVM 备份中最常遇到的“假失败”——不是命令写错了,而是预留空间不够。LVM 快照用的是写时复制(COW),原逻辑卷(LV)每改一个块,快照就得存一份旧数据;如果原 LV 写入频繁或快照保留太久,snapshot 就会填满。

实操建议:

  • 创建时必须显式指定大小,lvcreate -s 不设 -L 会默认用 100% 空闲 PE,但实际往往不够;保守起见,对读多写少的数据库备份,按原 LV 预估写入量的 20% 分配(例如原 LV 100G,快照给 20G)
  • 监控快照使用率:用 lvs -o +snap_percent 查看 SNAP% 列,超过 85% 就该考虑合并或丢弃
  • 别把快照当长期归档——它不是副本,只是时间点视图;超过 24 小时未使用的快照,建议 lvremove 掉,避免拖慢原 LV 性能

从快照恢复数据:直接 mount 还是 dd 恢复?

快照本身是只读的(除非你加了 --permission rw,但不推荐),不能直接当生产盘用。恢复分两种场景:单文件误删和整卷回滚。

实操建议:

  • 恢复单个文件:先 mount /dev/vgname/snapname /mnt/snap,再从 /mnt/snap 拷贝所需文件,完事 umountlvremove
  • 整卷回滚:必须停掉对应服务,然后用 lvconvert --merge —— 注意:只能在快照未挂载、且原 LV 处于非激活状态(即 lvchange -an 后)才能执行;合并后快照自动消失,原 LV 回到快照创建时的状态
  • 别用 dd if=/dev/vgname/snapname of=... 做“镜像备份”,快照设备不是稳定块设备,dd 中途可能因 COW 填满而失败

快照备份脚本里漏掉 lvchange -ay 导致恢复失败

很多自动化脚本只记得 lvcreate -s,却忘了快照创建后默认是 inactive 状态,mount 会报 mount: wrong fs type, bad option, bad superblock —— 实际就是设备没激活。

CrePal
CrePal

一站式AI视频创作Agent

下载

实操建议:

  • 创建快照后立刻执行 lvchange -ay /dev/vgname/snapname,否则 mount 必败
  • 脚本中建议加检查:用 lvs -o+attr 看第三列,输出里应有 owi-a-s---(其中 a 表示 active);若为 owi---s---,说明没激活
  • 如果用 ext4,还要确认内核支持快照设备 mount(4.12+ 基本都行),老系统(如 RHEL6)需额外加载 dm-snapshot 模块

为什么 lvremove 快照前要确保没挂载也没被 merge?

lvremoveCan't remove open logical volume 或静默失败,八成是因为快照还在被使用:要么挂载着,要么已在 merge 队列里但原 LV 没重启。

实操建议:

  • 删之前先跑 lsof +D /mnt/snapfindmnt | grep snapname,确认无挂载点
  • 如果做过 lvconvert --merge,得等下次 reboot 才真正生效;此时 lvs 仍显示快照存在,但 attr 里会有 m 标记(如 owi-a-m---),这时强行 lvremove 会失败
  • 紧急清理:可先 lvchange -an /dev/vgname/snapname 关闭,再 lvremove;但若已标记 merge,必须重启,否则原 LV 数据可能不一致

快照机制看着简单,但 COW 的触发时机、merge 的延迟生效、以及 inactive/active 状态切换,这几个点一错,备份就变成障眼法。真出问题时,先看 lvs -o+attr,+snap_percent,比翻日志快得多。

相关文章

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

831

2023.08.22

数据库三范式
数据库三范式

数据库三范式是一种设计规范,用于规范化关系型数据库中的数据结构,它通过消除冗余数据、提高数据库性能和数据一致性,提供了一种有效的数据库设计方法。本专题提供数据库三范式相关的文章、下载和课程。

377

2023.06.29

如何删除数据库
如何删除数据库

删除数据库是指在MySQL中完全移除一个数据库及其所包含的所有数据和结构,作用包括:1、释放存储空间;2、确保数据的安全性;3、提高数据库的整体性能,加速查询和操作的执行速度。尽管删除数据库具有一些好处,但在执行任何删除操作之前,务必谨慎操作,并备份重要的数据。删除数据库将永久性地删除所有相关数据和结构,无法回滚。

2097

2023.08.14

vb怎么连接数据库
vb怎么连接数据库

在VB中,连接数据库通常使用ADO(ActiveX 数据对象)或 DAO(Data Access Objects)这两个技术来实现:1、引入ADO库;2、创建ADO连接对象;3、配置连接字符串;4、打开连接;5、执行SQL语句;6、处理查询结果;7、关闭连接即可。

356

2023.08.31

MySQL恢复数据库
MySQL恢复数据库

MySQL恢复数据库的方法有使用物理备份恢复、使用逻辑备份恢复、使用二进制日志恢复和使用数据库复制进行恢复等。本专题为大家提供MySQL数据库相关的文章、下载、课程内容,供大家免费下载体验。

259

2023.09.05

vb中怎么连接access数据库
vb中怎么连接access数据库

vb中连接access数据库的步骤包括引用必要的命名空间、创建连接字符串、创建连接对象、打开连接、执行SQL语句和关闭连接。本专题为大家提供连接access数据库相关的文章、下载、课程内容,供大家免费下载体验。

329

2023.10.09

数据库对象名无效怎么解决
数据库对象名无效怎么解决

数据库对象名无效解决办法:1、检查使用的对象名是否正确,确保没有拼写错误;2、检查数据库中是否已存在具有相同名称的对象,如果是,请更改对象名为一个不同的名称,然后重新创建;3、确保在连接数据库时使用了正确的用户名、密码和数据库名称;4、尝试重启数据库服务,然后再次尝试创建或使用对象;5、尝试更新驱动程序,然后再次尝试创建或使用对象。

419

2023.10.16

vb连接access数据库的方法
vb连接access数据库的方法

vb连接access数据库方法:1、使用ADO连接,首先导入System.Data.OleDb模块,然后定义一个连接字符串,接着创建一个OleDbConnection对象并使用Open() 方法打开连接;2、使用DAO连接,首先导入 Microsoft.Jet.OLEDB模块,然后定义一个连接字符串,接着创建一个JetConnection对象并使用Open()方法打开连接即可。

453

2023.10.16

Golang 实际项目案例:从需求到上线
Golang 实际项目案例:从需求到上线

《Golang 实际项目案例:从需求到上线》以真实业务场景为主线,完整覆盖需求分析、架构设计、模块拆分、编码实现、性能优化与部署上线全过程,强调工程规范与实践决策,帮助开发者打通从技术实现到系统交付的关键路径,提升独立完成 Go 项目的综合能力。

1

2026.02.26

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 9.8万人学习

Git 教程
Git 教程

共21课时 | 3.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号