写点什么

从小型网站到超大规模网站的 MySQL 参考架构

  • 2013-03-18
  • 本文字数:1367 字

    阅读完需:约 4 分钟

Oracle 发布《面向大规模可伸缩网站基础设施的MySQL 参考架构》白皮书,针对将MySQL 用作数据存储的不同类型和不同规模的网站给出了推荐的拓扑结构。

根据分别提供4 类服务——用户和会话管理、电子商务、分析类应用 (多结构数据) 和CMS(元数据)——的网站的规模和可用性要求(如下表所示),这份白皮书给出了4 个参考架构。

请注意,这里给出的指导方针只是基本建议,实际应用中需要根据读写模式、负载平衡和所用的缓存机制等因素进行调整。

小型(Small)网站参考架构

这一参考架构可用于上述4 类网站的所有小型实现。可以使用MySQL Replication 来制作数据的副本以支持备份和分析。

中型(Medium)网站参考架构

在这种情况下,推荐针对不同类型的活动选择独立的基础设施,考虑每个MySQL 服务器最多支持8 个应用服务器,如果因伸缩性需求应用服务器数量增加,则添加更多的MySQL 从服务器。

为满足会话管理网站和电子商务网站的高可用性要求,可以使用 Linux 心跳(Heartbeat)和半同步复制。CMS 网站通常对读操作的向外扩展有更高要求,假定每个 MySQL 从服务器最多可以处理 3000 个并发用户,白皮书建议为每个 MySQL 主服务器添加 20-30 个从服务器。CMS 系统可将数据保存在一个 SAN 中,或者保存在连接到该服务器的分布式设备中。

会话管理网站和 CMS 网站推荐使用 Memcached,这有助于减轻应用服务器和 MySQL 服务器的负担。

分析类网站的拓扑结构简单一些,1 个主服务器加 3 个从服务器就能解决问题。

大规模(Large)网站参考架构

针对大规模网站,白皮书推荐使用 MySQL Geographic Replication 来进行跨数据中心的数据库复制,这种方式支持跨越地理上分离的集群进行异步复制。

会话管理网站和电子商务网站应该使用集群,白皮书声称“4 个数据节点,1 秒可以支持 6000 个会话(页面点击),其中每次页面点击生成 8–12 个数据库操作”。大规模 CMS 网站使用的配置与中型网站类似,只是必要时需要多添加一些从服务器。针对分析类应用,这里引入了一个数据提炼(Data Refinery)单元,用于数据的清理和组织。

超大规模(Extra Large)网站参考架构

针对社交网站,白皮书也给出了相应建议。它声称“网络上流量最大的 10 个网站有 9 个部署了 MySQL,其中包括 Google、Facebook 和 YouTube”,但是没有说明这些网站用 MySQL 干什么,不过众所周知的是,LinkedIn 成功应用了 MySQL。

社交网站的拓扑结构利用了中型和大规模网站中实现的概念,包括专用应用服务器、Memcached 和数据提炼单元, 但为支持写操作的向外扩展引入了分片(Shard)。MySQL 集群被用于用户的认证和查找,当“用于查找的键(key)不止 1 个”时,直接读写相应的分片。

MySQL 主服务器和从服务器的推荐规格如下:

  • 8–16 个 x86-64 位 CPU 核心(MySQL 5.5 及以上)。
  • 4–8 个 x86 -64 位 CPU 核心(MySQL 5.1 及更早版本)。
  • 比活动数据多 3–10 倍的内存。
  • Linux、Solaris 或 Windows 操作系统。
  • 最少 4 块磁盘,8–16 块磁盘能增加 I/O 密集型应用的性能。
  • 支持电池供电高速缓存的硬件 RAID。
  • 推荐使用 RAID 10。如果负载为读密集型,RAID 5 也是合适的。
  • 2 个网卡和 2 个供电单元用作冗余。

另外,白皮书还有一些针对 MySQL 集群和数据存储设备的建议,再就是用于监控、备份和集群管理的解决方案。

查看英文原文 MySQL Reference Architectures for Small to Extra Large Websites

2013-03-18 04:1913804
用户头像
臧秀涛 略懂技术的运营同学。

发布了 300 篇内容, 共 149.9 次阅读, 收获喜欢 35 次。

关注

评论

发布
暂无评论
发现更多内容

鸿蒙应用开发从入门到实战(十):ArkUI图片组件Image

程序员潘Sir

鸿蒙 HarmonyOS

打印机漏洞、匿名协议与AWS安全:一周技术热点解析

qife122

AWS安全 打印机攻击

No009:如果DeepSeek拥有“身体”——具身智能与多模态交互

lsycang

大厂思维与“小快轻准”产品的矛盾

lsycang

4+10+N,华为坤灵“求解”中小企业智能化

Alter

AI 智能化

第七届机器学习、大数据与商务智能国际会议(MLBDBI 2025)

搞科研的小刘

机器学习 大数据与商务智能

“超节点+集群”:华为撞出来的算力之路

脑极体

AI

手撕大模型|FlashAttention 原理及代码解析

地平线开发者

自动驾驶; 算法工具链 地平线征程6

ClaudeCode中的效率神器SubAgents怎么用?

阿星AI工作室

产品 AI 产品经理 AI编程

在YashanDB数据库中进行数据分区的最佳实践

数据库砖家

在YashanDB数据库中实现大规模数据分析的有效策略

数据库砖家

No010:如果DeepSeek能“自我进化”——终身学习与群体智能

lsycang

PD 分离推理架构详解

Se7en

推理 LLM vLLM

2025年最佳笔记本扩展坞评测:一站式提升工作站效率

qife122

扩展坞 多显示器

鸿蒙应用开发从入门到实战(十一):ArkUI组件Text&TextInput

程序员潘Sir

鸿蒙 HarmonyOS

Mac 视频转码编辑工具 Compressor v4.11.0

Rose

释放定性数据的力量!ATLAS.ti 8 让复杂研究变得清晰直观

Rose

Android隐藏活动启动器 - 一键创建应用快捷方式

qife122

android 活动启动

搜索百科(3):Elasticsearch — 搜索界的“流量明星”

极限实验室

搜索引擎 lucene elasticsearch 开源 搜索百科

Motion 5 for Mac v5.11.0 视频后期特效处理 利用 Apple Log 2视频的动态范围和更广色域

Rose

‌Daft:AI驱动的多模态数据融合引擎

老周聊架构

AICon

BRV Capital投资Zettabyte并启动“TITAN”AIDC项目

财见

DRUID AI获得3100万美元C轮融资

财见

No008:共建产业知识生态——DeepSeek如何助力中小企业数字化转型

lsycang

第六届医学人工智能国际学术会议(ISAIMS 2025)

搞科研的小刘

学术会议 医学 医学人工智能

Final Cut Pro v11.2.0 通过应用 Apple Log 2LUT,以原始场景鲜明度编辑及播放 Apple Log 2素材

Rose

云计算时代下的YashanDB数据库最佳实践

数据库砖家

在YashanDB数据库中处理大规模数据挑战

数据库砖家

如何向AI借脑使用高级表达?

阿星AI工作室

编程 AI 产品经理 AIGC Claude

基于YOLOv8的人体多姿态行为识别系统(站立、摔倒、坐姿、深蹲与跑步)|完整源码数据集+PyQt5界面+完整训练流程+开箱即用!

申公豹

人工智能

十分好用的重复文件快速查找器 Duplicate File Finder mac版

Rose

从小型网站到超大规模网站的MySQL参考架构_数据库_Abel Avram_InfoQ精选文章