找回密码
 FreeOZ用户注册
查看: 3001|回复: 3
打印 上一主题 下一主题

[网络技术] 8w同时连接数的DISCUZ论坛结构改进

[复制链接]
跳转到指定楼层
1#
发表于 9-8-2008 09:01:51 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有帐号?FreeOZ用户注册

x
8w同时连接数的DISCUZ论坛结构改进                                                                                                                                                                                                                                                                                                                        转自:
http://www.hiadmin.com/discuz%E8 ... %E6%96%B9%E6%A1%88/

魔力游的论坛达到8w同时连接数,原有的架构已经无法满足如此巨大的访问请求

原有结构

前端使用F5进行负载均衡
将负载分摊至4台WEB SERVER
然后WEB SERVER同时连接后端的MYSQL服务器
瓶颈很明显在于MYSQL服务器
第1次改进

增加两台WEB SERVER
由于WEB的CPU负载也非常高.所以增加WEBserver的量来分摊CPU LOAD.
在后端使用LVS分发读写请求到后面的两台MYSQL服务器
然后MYSQL的表数据从同一的集中存储中获取
这次改进的问题很明显
锁表
由于MYSQL在执行写操作时会进行锁表
所以运行没多久,MYSQL的库文件就损坏了
第2次改进

接下来我们考虑过使用NDB作为存储后端代替NFS
但是由于数据库量太大
在进行数据导入时,超出内存
无法将原有的数据库导入到NDB中
所以我们只能使用Mysql proxy + master/slave的方式
进行读写分离
以求分摊负载
由于没有时间进行discuz的程序段的改造
所以只能使用对程序透明的mysql proxy方式进行负载分摊
这次改进的缺点在于对于只读服务器的分摊仍旧是在配置里手工写的
而不能通过程序来进行自动分发.
第3次改进

由于考虑到服务器的自动维护性
以及服务器数量的限制
我们把LVS加在两台read only的mysql服务器上
加上heat beat之后.任何一个只读节点的故障都不会影响
今后如果扩展mysql的IO能力
只要在mysql机群内加入新的mysql slave服务器
加入LVS之后便可以了
回复  

使用道具 举报

2#
发表于 9-8-2008 18:46:22 | 只看该作者
回复  

使用道具 举报

3#
发表于 11-8-2008 22:01:06 | 只看该作者
提示: 作者被禁止或删除, 无法发言

天书啊天书,根本不知道在说啥
回复  

使用道具 举报

4#
 楼主| 发表于 11-8-2008 23:31:00 | 只看该作者

回复 #3 herejingying 的帖子

隔行如隔山
回复  

使用道具 举报

您需要登录后才可以回帖 登录 | FreeOZ用户注册

本版积分规则

小黑屋|手机版|Archiver|FreeOZ论坛

GMT+10, 27-4-2024 21:06 , Processed in 0.038283 second(s), 21 queries , Gzip On, Redis On.

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表