热门标签 | HotTags
当前位置:  开发笔记 > 运维 > 正文

KVM虚拟机环境与高可用

KVM是成熟的开源虚拟化解决方案,将其部署于企业生产环境,其高可用性也是必须要仔细考虑的问题。高可用性(HighAvailability)是指系统提供不间断服务的能力,也就是尽可能的减少系统停止服务的时间。KVM虚拟化环境也存在HA的问题,KVM主机软硬件或外部环境都有

KVM是成熟的开源虚拟化解决方案,将其部署于企业生产环境,其高可用性也是必须要仔细考虑的问题。

高可用性(High Availability)是指系统提供不间断服务的能力,也就是尽可能的减少系统停止服务的时间。KVM虚拟化环境也存在HA的问题,KVM主机软硬件或外部环境都有可能出现问题甚至是灾难,这就必须要考虑一些高可用方案。

KVM高可用方案无非就是如何能最大限度的让客户机保持正常运行。目前想到的HA方案有如下几个。

1、DRBD

DRDB(Distributed Replicated Block Device),可以直译为"分布式复制块设备",其工作方式为通过网络来镜像块设备,可以称其为网络RAID1(Network RAID1)。 DRDB在本地接受IO请求,除了将数据写入本地硬盘外,还会通过网络发送给另一主机,另一主机将其写入自己的本地硬盘,从而保持两台主机的块设备实时同步。

从kernel 2.6.33开始DRDB已经进入mainline。DRBD 9.0之前只能将数据复制到一个节点,9.0之后将提供复制到多个节点的能力。

通过与heartbeat结合可以做到自动的failover,从而达到高可用性。

DRBD是一种通用解决方案,KVM虚拟化环境完全可以使用这一高可用技术。

2、Sheepdog

Sheepdog是专为QEMU/KVM开发的分布式块存储系统。它可以提供QEMU/KVM可以直接挂接使用的高可用块级存储卷。Sheepdog可以扩大到上百个节点,并且支持高级卷管理特性,比如快照、克隆、thin provisioning等。它是针对KVM的专用集群存储方案。

这玩意儿听起来真像那么一回事儿,但目前版本为0.3.0,成熟度貌似还很不够。不过很看好这项目。

3、双机

双机共享存储,但这种方式仍然存在单一故障点,那就是存储,所以这种方式并不是一种很好的方式,虽然存储的可靠性比主机要高的多。

目前正在采用这种方式,两台服务器分别通过多路径连接到共享的磁盘阵列,但同一时刻只能有一台服务器挂载磁盘阵列。因为磁盘阵列使用的是ext4文件系统,这种单机文件系统是不支持两台主机同时访问的,会造成数据混乱,甚至文件系统崩溃。

KVM客户机客户机磁盘镜像文件和启动KVM客户机的命令脚本都放在共享存储上面,当正在使用磁盘阵列的主机出现故障时,可以使用备机挂载磁盘阵列来运行KVM客户机。因为有了共享存储,也可以通过NFS来做客户机的动态迁移,即V2V热迁移,客户机可以在几乎没有任何中断的情况下从一台主机迁移到另一台主机。

因为存储是单一故障点,所以有必要经常备份KVM客户机。但目前KVM客户机还不能热备份,也就是要想完整备份客户机,只能将客户机停掉,然后拷贝其磁盘镜像文件。显然这样太麻烦了。

热备份的问题可以通过文件系统快照来间接实现。ext4不支持snapshot,ZFS是更好的选择。ZFS on linux是ZFS到linux的原生移植,以内核模块的方式来绕过license限制。通过ZFS给文件系统做快照,然后将快照传输到远程主机,来间接的实现KVM虚拟机的热备份。

近期会测试这种方式,ZFS on linux 现在的版本为0.6.0-rc8,不知道稳定性如何!

当然还有一种备份方式,现在的磁盘阵列大部分提供一种功能叫做远程卷镜像RVM(remote volume mirroring)的特性,但这种方式有许多缺点,比如硬件投资高,灵活性差,而且RVM会忠实的镜像一切数据,包括错误,一旦原卷数据损坏,可能远程镜像卷也会无法使用,如果RVM能提供事务支持就更好了,当然也有阵列提供snapshot功能。但是能用软件方案解决的问题还是尽量不要用硬件解决方案。

总结

总的来说,使用DRBD或Sheepdog是更好的解决方案,Sheepdog还不太成熟,也许DRDB是目前一个很好的选择。双机热备这种古老的技术其实并不灵活也不十分可靠,集群才是高可用和高性能的方向。


推荐阅读
  • 深入解析Serverless架构模式
    本文将详细介绍Serverless架构模式的核心概念、工作原理及其优势。通过对比传统架构,探讨Serverless如何简化应用开发与运维流程,并介绍当前主流的Serverless平台。 ... [详细]
  • Symfony是一个功能强大的PHP框架,以其依赖注入(DI)特性著称。许多流行的PHP框架如Drupal和Laravel的核心组件都基于Symfony构建。本文将详细介绍Symfony的安装方法及其基本使用。 ... [详细]
  • 本文详细介绍了如何在云服务器上配置Nginx、Tomcat、JDK和MySQL。涵盖从下载、安装到配置的完整步骤,帮助读者快速搭建Java Web开发环境。 ... [详细]
  • 主调|大侠_重温C++ ... [详细]
  • 本文深入探讨了MySQL中常见的面试问题,包括事务隔离级别、存储引擎选择、索引结构及优化等关键知识点。通过详细解析,帮助读者在面对BAT等大厂面试时更加从容。 ... [详细]
  • 远程过程调用(RPC)是一种允许客户端通过网络请求服务器执行特定功能的技术。它简化了分布式系统的交互,使开发者可以像调用本地函数一样调用远程服务,并获得返回结果。本文将深入探讨RPC的工作原理、发展历程及其在现代技术中的应用。 ... [详细]
  • CentOS 7.6环境下Prometheus与Grafana的集成部署指南
    本文旨在提供一套详细的步骤,指导读者如何在CentOS 7.6操作系统上成功安装和配置Prometheus 2.17.1及Grafana 6.7.2-1,实现高效的数据监控与可视化。 ... [详细]
  • 本文深入探讨了 PHP 实现计划任务的方法,包括其原理、具体实现方式以及在不同操作系统中的应用。通过详细示例和代码片段,帮助开发者理解和掌握如何高效地设置和管理定时任务。 ... [详细]
  • 本文介绍如何配置SecureCRT以正确显示Linux终端的颜色,并解决中文显示问题。通过简单的步骤设置,可以显著提升使用体验。 ... [详细]
  • 深入解析Spring Cloud微服务架构与分布式系统实战
    本文详细介绍了Spring Cloud在微服务架构和分布式系统中的应用,结合实际案例和最新技术,帮助读者全面掌握微服务的实现与优化。 ... [详细]
  • 深入解析BookKeeper的设计与应用场景
    本文介绍了由Yahoo在2009年开发并于2011年开源的BookKeeper技术。BookKeeper是一种高效且可靠的日志流存储解决方案,广泛应用于需要高性能和强数据持久性的场景。 ... [详细]
  • 为何我选择了华为云GaussDB数据库
    本文分享了作者选择华为云GaussDB数据库的理由,详细介绍了GaussDB(for MySQL)的技术特性和优势,以及它在金融和互联网行业的应用场景。 ... [详细]
  • Go语言以其简洁的语法和强大的并发处理能力而闻名,特别是在云计算和分布式计算领域有着广泛的应用。本文将深入探讨Go语言中的Channel机制,包括其不同类型及其在实际编程中的应用。 ... [详细]
  • 2012年7月30日,语言岛团队宣布其智能记单词软件V0.3.4.554版本正式开源。该版本不仅支持跨平台使用,还引入了多项创新功能,旨在帮助用户更高效地记忆单词。 ... [详细]
  • 在编译BSP包过程中,遇到了一个与 'gets' 函数相关的编译错误。该问题通常发生在较新的编译环境中,由于 'gets' 函数已被弃用并视为安全漏洞。本文将详细介绍如何通过修改源代码和配置文件来解决这一问题。 ... [详细]
author-avatar
AndreaDittis
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有