Nova Suspend/Rescue 操作详解 - 每天5分钟玩转 OpenStack(35)
本节我们讨论 Suspend/Resume 和 Rescue/Unrescue 这两组操作。
Suspend/Resume
有时需要长时间暂停 instance,可以通过 Suspend 操作将 instance 的状态保存到宿主机的磁盘上。当需要恢复的时候,执行 Resume 操作,从磁盘读回 instance 的状态,使之继续运行。
这里需要对 Suspend 和 Pause 操作做个比较:
相同点
两者都是暂停 instance 的运行,并保存当前状态,之后可以通过 Resume 操作恢复
不同点
1. Suspend 将 instance 的状态保存在磁盘上;Pause 是保存在内存中,所以 Resume 被 Pause 的 instance 要比 Suspend 快。 2. Suspend 之后的 instance,其状态是 Shut Down;而被 Pause 的 instance 状态是Paused。 3. 虽然都是通过 Resume 操作恢复,Pause 对应的 Resume 在 OpenStack 内部被叫作 “Unpause”;Suspend 对应的 Resume 才是真正的 “Resume”。这个在日志中能体现出来。
Suspend/Resume 的日志分析留给大家做练习。
Rescue/Unrescue
从这节开始,我们将讨论几种 instance 故障恢复的方法,不同方法适用于不同的场景。 首先我们考虑操作系统故障。
有时候由于误操作或者突然断电,操作系统重启后却起不来了。 为了最大限度挽救数据,我们通常会使用一张系统盘将系统引导起来,然后在尝试恢复。 问题如果不太严重,完全可以通过这种方式让系统重新正常工作。 比如某个系统文件意外删除, root 密码遗忘等
Nova 也提供了这种故障恢复机制,叫做 Rescue。 我们来看看 rescue 的说明:
Rescue 用指定的 image 作为启动盘引导 instance,将 instance 本身的系统盘作为第二个磁盘挂载到操作系统上。
下面是 rescue instance 的流程图
向 nova-api 发送请求
nova-api 发送消息
nova-compute 执行操作
下面我们详细讨论每一个步骤。
向 nova-api 发送请求
目前 Rescue 操作只能通过 CLI 执行
这里我们没有指明用哪个 image 作为引导盘,nova 将使用 instance 部署时使用的 image
查看日志 /opt/stack/logs/n-api.log
nova-api 发送消息
nova-api 向 Messaging(RabbitMQ)发送了一条消息:“Rescue 这个 Instance” 源代码在 /opt/stack/nova/nova/compute/api.py,方法是 rescue。
nova-compute执行操作
查看日志 /opt/stack/logs/n-cpu.log
关闭 instance
通过 image 创建新的引导盘,命名为 disk.rescue
启动 instance
Rescue 执行成功后,可以通过 virsh edit <instance_name> 查看 instance 的 XML 定义,disk.rescue 作为启动盘 vda,真正的启动盘 disk 作为第二个磁盘 vdb。
登录 instance,通过 fdisk 也可确认。
此时,instance 处于 Rescue 状态
Rescue 操作让我们有机会修复损坏的操作系统。 修好之后,使用 Unrescue 操作从原启动盘重新引导 instance。
Unrescue 的日志分析留给大家练习。
Nova Suspend/Rescue 操作详解 - 每天5分钟玩转 OpenStack(35)相关推荐
- Pause/Resume Instance 操作详解 - 每天5分钟玩转 OpenStack(34)
Pause/Resume Instance 操作详解 - 每天5分钟玩转 OpenStack(34) 本节通过日志详细分析 Nova Pause/Resume 操作. 有时需要短时间暂停 instan ...
- O035、Nova Suspend / Rescue 操作详解
参考https://www.cnblogs.com/CloudMan6/p/5503501.html Suspend / Resume 有时候需要长时间暂停 instance , 可以通过 Suspe ...
- Snapshot Instance 操作详解 - 每天5分钟玩转 OpenStack(36)
本节我们通过日志详细讨论 instance 的 snapshot 操作. 有时候操作系统损坏得很严重,通过 Rescue 操作无法修复,那么我们就得考虑通过备份恢复了.当然前提是我们之前对instan ...
- Unshelve Instance 操作详解 - 每天5分钟玩转 OpenStack(39)
上一节我们 shelve instance 到 Glance,本节讨论如何通过 unshelve 操作恢复该 instance. 因为 Glance 中保存了 instance 的 image,uns ...
- Rebuild Instance 操作详解 - 每天5分钟玩转 OpenStack(37)
上一节我们讨论了 snapshot,snapshot 的一个重要作用是对 instance 做备份. 如果 instance 损坏了,可以通过 snapshot 恢复,这个恢复的操作就是 Rebuil ...
- Start Instance 操作详解 - 每天5分钟玩转 OpenStack(31)
本节通过日志文件详细分析 instance start 操作. 下面是 start instance 的流程图 向 nova-api 发送请求 nova-api 发送消息 nova-compute 执 ...
- Migrate Instance 操作详解 - 每天5分钟玩转 OpenStack(40)
Migrate 操作的作用是将 instance 从当前的计算节点迁移到其他节点上. Migrate 不要求源和目标节点必须共享存储,当然共享存储也是可以的. Migrate 前必须满足一个条件:计算 ...
- Launch和Shut Off操作详解 - 每天5分钟玩转 OpenStack(30)
本节详细分析 instance launch 和 shut off 操作,以及如何在日志中快速定位有用信息的技巧. Launch Launch instance 应该算 Nova 最重要的操作. 仔细 ...
- Cinder 组件详解 - 每天5分钟玩转 OpenStack(47)
Cinder 组件详解 - 每天5分钟玩转 OpenStack(47) 本节我们将详细讲解 Cinder 的各个子服务. cinder-api cinder-api 是整个 Cinder 组件的门户, ...
最新文章
- 事物的级别_浅谈MySQL并发控制:隔离级别、锁与MVCC
- 如何为云部署安全开源代码?
- Quartz框架中的JobStore
- 能在任意一种框架中复用的组件,太牛了!
- java导出excel_Hutool Java 工具类库导出 Excel,超级简单!
- python colorbar位置大小调整_python - matplotlib相邻子图:添加colorbar更改子图的大小 - 堆栈内存溢出...
- 柔性机械臂_机械臂位置控制概述
- 计算机房电缆,机房设计常用计算公式大全
- win7显示安装程序正在启动服务器失败,Win7安装程序正在启动服务怎么办?
- php的垃圾回收机制
- 浅谈敏捷思想-06.精益创业
- 听歌识曲java_Android自定义View之继承扩展(仿网易云音乐听歌识曲)
- 基于手机音频通信应用
- 大明最不该被遗忘的英烈——李定国
- 【MySQL集群】——Java程序连接MySQL集群
- 几种典型的立体匹配算法
- android收集备忘录恢复工具,备忘录不小心删了怎么恢复?专业恢复工具分享
- PHP清除网页病毒的方法
- 无向图最小环——Floyd解法
- SonarLint插件
热门文章
- 如何上传本地图片到PictureBox控件
- 实现pxe的自动化安装
- Fedora16安装mplaye和smplayer
- Windows7 Credential Manage
- Enterprise Library 2.0 Hands On Lab 翻译(14):加密应用程序块(一)
- 艾蔻扫地机器人怎么充电_扫地机器人锂电池的正确使用方法
- 数据库操作的隔离级别 Transaction Isolation Levels
- arm linux 进程页表,linux-kernel – ARM Linux页表项格式 – 未使用的位?
- 贝叶斯优化python包_Bayesian2D-用贝叶斯优化方法求任意二维函数的最大值或最小值的软件包-Juhan Raidal...
- linux的lnmp环境,Ubuntu 16.04 LTS下LNMP环境配置简述