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
相关推荐
中型(Medium)网站参考架构 在这种情况下,推荐针对不同类型的活动选择独立的基础设施,考虑每个MySQL服务器最多支持8个应用服务器,如果因伸缩性需求应用
摘要:在本白皮书中,我们提出了四个参考架构基于最佳实践从与这个星球上最成功的网页内容合作开发的。我们选择了常见的大多数网页内容四部分组成(用户认证 /会话管理,
Oracle发布《面向大规模可伸缩网站基础设施的MySQL参考架构》白皮书,针对将MySQL用作数据存储的不同类型和不同规模的网站给出了推荐的拓扑结构。
Google高级架构师Jeremy Cole谈大规模MySQL架构
小型网站java mysql
MySQL官方文档架构图
大型网站技术架构:核心原理与案例分析 分布式服务框架原理与实践_李林锋著 高性能MySQL(第3版) 等pdf文档
MySQL架构篇
《PHP+MySQL动态网站开发》注重将理论讲解与工程应用结合起来,选择的案例是作者实践的结晶,能提高读者学习的积极性和效率,通过学习这些案例,读者能够掌握《PHP+MySQL动态网站开发》的精髓,并可以直接应用到动态...
资源包含文件:课程论文word+源码及数据库文件 由于实现了两种用户模式(管理员和普通顾客会员),页面上的安排肯定要随着不同的登录身份而做出...详细介绍参考:https://blog.csdn.net/newlw/article/details/124829033
MYSQL_架构设计,介绍MYSQL_架构设计\可扩展设计的基本原则
arm架构centos7 下mysql8离线安装包 包含: mysql-community-client-8.0.20-1.el7.aarch64.rpm mysql-community-common-8.0.20-1.el7.aarch64.rpm mysql-community-devel-8.0.20-1.el7.aarch64.rpm mysql-community-...
mysql架构思维导图
4.16.1 从一个 3.22 版本升级到 3.23 4.16.2 从一个 3.21 版本升级到 3.22 4.16.3 从一个 3.20 版本升级到 3.21 4.16.4 升级到其他的体系结构 5 MySQL 与标准的兼容性? 5.1 MySQL对...
百度的mysql架构,讲解了百度从2005 -2011年的mysql数据库架构发展,有分散式,集中式,到分布式.
MySql Innodb底层存储架构
2.3.11. 从Windows命令行启动MySQL 2.3.12. 以Windows服务方式启动MySQL 2.3.13. 测试MySQL安装 2.3.14. 在Windows环境下对MySQL安装的故障诊断与排除 2.3.15. 在Windows下升级MySQL 2.3.16. Windows版MySQL同Unix版...
本书以 MySQL 数据库的基础及维护为切入点,重点介绍了 MySQL 数据库应用系统的性能调优,以及高可用可扩展的架构设计。 全书共分3篇,基础篇介绍了MySQL软件的基础知识、架构组成、存储引擎、安全管理及基本的备份...