手游业务MySQL数据库虚拟化漫谈 | By 肖力

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: 手游业务MySQL数据库虚拟化漫谈 | By 肖力

作者简介

肖力, 资深运维专家,拥有15年运维经验,就职于金山西山居,担任系统运维经理,曾就职于盛大游戏,在运维圈有极大的影响力。国内最顶尖的KVM专家之一,从2009年开始研究KVM技术,是国内较早在生产环境大规模实践KVM的人之一,积累了非常丰富的经验。

热衷于技术传播,一直在无私地为运维领域的发展做贡献,维护有微信订阅号“KVM虚拟化实践”,分享了大量KVM和运维领域的干货内容,同时还运营着多个运维相关的微信群。此外,他还是华章“运维前线”系列图书的总策划,无偿地在组织大量愿意无私分享经验的运维工程师们来参与写作。

作者

  • 肖力(原著)

编辑

  • 叶金荣(文章整理)

内容简介

资深运维专家肖力谈手游业务MySQL虚拟化方案

手游业务MySQL服务特点

  1. 目前手游业务大多是采用Redis和MySQL相结合的方案;
  2. Redis则用于游戏业务中当前状态数据的存储,而MySQL一般用于数据持久化存储以及事务控制、数据一致性保证;
  3. 手游业务中的MySQL数据库一般负载不高。

正因为MySQL负载不高,才需要想办法提高资源利用率,这里可以有两个思路:

  • 单机多实例;
  • 虚拟化技术。

这两种方法各有优缺点,我们接下来各自分析对比下。

1、单机多实例

在同一个OS下启动多个mysqld进程,监听多个端口。

优点:

  • 计算资源利用率相对较高,因为没有虚拟化层的损耗;
  • 适合中小企业,因为无需额外维护KVM等虚拟化组件。

缺点:

  • 隔离性相对较差,不同业务的MySQL实例间可能会因为业务瞬间突增而相互影响;
  • 定制化相对麻烦,不同实例要使用不同的MySQL版本,操作配置比较麻烦;
  • 不同实例无法都使用默认的3306端口,除非事先绑定多个IP,相对较复杂。

2、虚拟化技术

在每个虚拟机只运行一个数据库实例。

优点:

  • 方便推动数据库部署标准化、模版化,为后续推进快速部署打好基础;
  • 通过虚拟化技术,实现数据库服务快速批量部署,公有云RDS一般也是这么做的;
  • 具备良好的隔离性,一个实例中的OS或数据库故障不影响其他实例下的服务。

缺点:

  • 多了虚拟化层,增加一部分计算资源消耗;
  • 每个虚拟化实例使用单独的IP,网络管理上更复杂;
  • 手游业务数据库虚拟化方案可以考虑KVM结合Docker的方案。

数据库使用KVM虚拟化方案需要关注下面的几个要点:

  1. 服务稳定性,业务的稳定是一切基础,再好的方案也不能影响业务的稳定,否则都是耍流氓;
  2. 避免性能瓶颈,数据库服务主要的瓶颈在于磁盘I/O,好在手游业务的压力一般不太大。不过上线前也要做足测试,对潜在的性能需求要有预估。遇到高负载时可直接使用SSD或者PCIe SSD设备,在KVM虚拟化中也可将SSD直接以裸盘方式挂载到KVM实例上。
  3. 服务可靠性,可从下面两个方面提升服务可靠性:

1)数据库层面,可采用主从复制、定期物理&逻辑备份(全备+差异备份)、备份恢复等机制;

2)虚拟化层面,可采用共享存储、虚拟机快照等。共享存储优先选择企业级存储设备,要注意虚拟机快照并不能保证数据库的完整性。

数据库使用Docker技术

数据库服务基于Docker技术,有效平衡了单机多实例以及KVM虚拟化两种方案,其资源损耗小,又具备虚拟化灵活部署和隔离性等优点

但当前Docker技术仍有诸多限制:

  • 其使用AUFS文件系统,更容易造成磁盘I/O性能瓶颈(可配置SSD盘缓解I/O压力);
  • Docker的实例不支持热迁移(可和KVM结合,利用KVM实现热迁移);
  • Docker的网络模块上也有瓶颈。

上述这些因素决定了目前在Docker里跑MySQL还有待进一步完善,我们也相信随着Docker技术的不断改进,这些限制或者瓶颈会越来越少,更适大规模运行MySQL等服务。

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
20天前
|
存储 安全 数据管理
时序数据库TDengine 与中移软件达成兼容性互认证,推动虚拟化云平台与时序数据库的深度融合
在数字化转型和智能化升级的浪潮下,企业对数据的需求日益增长,尤其是在物联网、大数据和实时分析等领域。随着设备数量的激增,时序数据的管理和处理变得愈发复杂,企业亟需高效、稳定的数据解决方案来应对这一挑战。时序数据库作为专门处理时间序列数据的工具,正逐渐成为各行业数字化转型的重要支撑。
39 4
|
存储 运维 固态存储
手游业务MySQL数据库虚拟化漫谈 | By 肖力
手游业务MySQL数据库虚拟化漫谈 | By 肖力
229 0
|
数据库 虚拟化
《数据虚拟化:商务智能系统的数据架构与管理》一 1.14 示例数据库:世界一流电影
本节书摘来自华章出版社《数据虚拟化:商务智能系统的数据架构与管理》一 书中的第1章,第1.14节,作者:[荷]里克 F. 范德兰斯(Rick F. van der Lans),更多章节内容可以访问云栖社区“华章计算机”公众号查看。
1236 0
|
SQL 数据库 数据中心
《构建高可用VMware vSphere 5.X虚拟化架构》——2.6 vCenter Server数据库的备份恢复
至此,完成了vCenter Server数据库的备份恢复操作,针对于数据库的备份操作相当重要,可以采用“计划任务”方式定期对数据库进行备份操作。备份完成后,也需要定期对数据库进行恢复操作检验备份的可用性。
2028 0
|
关系型数据库 测试技术 Linux
《构建高可用VMware vSphere 5.X虚拟化架构》——2.5 使用Oracle作为VMware vCenter Server Appliance数据库
对于Linux版本来说,用户无需复杂的配置,通过VMware官方发布的模版部署到ESXi主机上即可使用,因此,Linux版VMware vCenter Server Appliance也有大量的用户,遗憾的是嵌入式数据库只能支持不超过5台ESXi主机以及50台虚拟机,独立数据库只支持Oracle,
2180 0
|
SQL 数据库连接 数据库
《构建高可用VMware vSphere 5.X虚拟化架构》——2.4 使用SQL Server作为Windows版vCenter Server数据库
vCenter Server最核心的部分就是数据库,在创建上与其他数据库有一些差异,本节实战将在一台运行Windows Server 2008 R2的虚拟机上安装SQL Server 2008,再介绍vCenter Single Sign On数据库和vCenter Server数据库的创建。
1958 0
|
SQL 关系型数据库 Linux
《构建高可用VMware vSphere 5.X虚拟化架构》——2.2 如何选择vCenter Server数据库
对于vCenter Server来说,无论是Windows版本还是Linux版本,都可以使用嵌入数据库或独立数据库,作为虚拟化的实施人员,如何选择使用数据库,了解一下两者之间的优缺点是很重要的。
1569 0
|
关系型数据库 大数据 网络安全

推荐镜像

更多