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 的流程图

  1. 向 nova-api 发送请求

  2. nova-api 发送消息

  3. 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。

Nova Suspend 和 Pause相关推荐

  1. Nova Suspend/Rescue 操作详解 - 每天5分钟玩转 OpenStack(35)

    本节我们讨论 Suspend/Resume 和 Rescue/Unrescue 这两组操作. Suspend/Resume 有时需要长时间暂停 instance,可以通过 Suspend 操作将 in ...

  2. O035、Nova Suspend / Rescue 操作详解

    参考https://www.cnblogs.com/CloudMan6/p/5503501.html Suspend / Resume 有时候需要长时间暂停 instance , 可以通过 Suspe ...

  3. nova 组件-pause/suspend

    nova-api发送message到消息队列,然后nova-compute接收到消息后,执行操作. pause之后虚拟机状态直接变为paused. suspend与pause区别: 有时需要长时间暂停 ...

  4. openstack之虚拟机管理命令

    在控制节点上建hzb-openrc.sh export OS_PROJECT_DOMAIN_ID=default export OS_USER_DOMAIN_ID=default export OS_ ...

  5. 面经 - OpenStack(Docker、Django、K8S、SDN)知识点

    文章目录 概述 OpenStack 虚拟化 kvm 网络虚拟化 基本技术 Memcached Etcd 消息队列 概念 交换机类型 缺点 重复投递问题 顺序投递问题 restful api Horiz ...

  6. 应该了解的Openstack命令

    整理一下Openstack的命令.下面的命令,我都是全部在机器验证过,主要是参考 redhat文档 查看rabbitmq 队列 rabbitmqctl list_queues 查看keystone的用 ...

  7. Powershell命令中的 CommonParameters是指什么

    因为在命令中经常遇到这个参数,后来找了一下,有一个微软的官方文档,就不翻译了,英文好的自己读吧. https://docs.microsoft.com/zh-cn/powershell/module/ ...

  8. unable to start ssh-agent service, error :1058 问题的解决方法

    Windows 10 启动 ssh-agent 命令时,抛出 unable to start ssh-agent service, error :1058 : (1)原因分析 ssh-agent 服务 ...

  9. DB2 的REORG_学习(1)_REORG INDEXES/TABLE Command

    最近写一个DB2的REORG的脚本,因为以前在mysql里面是没有接触过这个REORG的,所以系统了解一下,我的学习的话是先从命令入手,看看这个名的结构,然后还有选项,这些选项会揭示一些这个命令能干什 ...

最新文章

  1. java创建请求拦截器_80.简单Retrofit+RxJava+日志拦截器结合使用
  2. 在64位Windows7上安装64位Oracle11g
  3. 项望烽:移动 IM 开发之心跳​
  4. 【收藏】k8s使用securityContext和sysctl
  5. mysql数据库query cache
  6. iBatis.Net(C#)数据库查询
  7. QT环境配置:QT5.8.0与VS2013环境配置
  8. 2021巨量引擎连锁经营行业洞察报告
  9. java中编码问题_[干货预警]一次搞懂Java中的编码问题
  10. kafka 在 360 商业化的实践
  11. 问题-[Delphi]用LoadLibrary加载DLL时返回0的错误
  12. python画雷达图-使用Python绘制雷达图
  13. Oracle DBHelper 第二版
  14. 让你浏览器飞起来的电脑插件合集
  15. redis hset hget字典的实现
  16. 黄河金岸诗词大赛获奖作品选登(2:现代新诗)
  17. js鼠标移入改变颜色,移除还原
  18. 为什么很多公司不要培训机构出来的程序员?
  19. 学习rtklib(三)
  20. 阿里云CDN不止于加速:基于https国密算法构建安全数据传输链路

热门文章

  1. 泰拉瑞亚加mod之后如何搭建服务器进行联机
  2. idea自定义过滤器
  3. cdn日志文件导入mysql进行分析,核心用到 Python
  4. 光缆常用的设备测试方法介绍
  5. 人脸识别技术开发解决方案,人脸识别智慧校园应用开发
  6. Spark设计理念与基本架构
  7. Python三维绘图:马鞍面
  8. 三个bypass案例分享
  9. 豌豆花开花蕊红太平军哥哥一去无影踪
  10. 【2】微信视频号的那点事儿