又拍网架构 -- 前端PHP后台Python +消息中间件 RabbitMQ + 分库步骤

 又拍网架构 (http://www.bopor.com/?p=652), 很有价值。


 

又拍网的服务器端开发语言主要是PHP和Python,其中PHP用于编写Web逻辑(通过HTTP和用户直接打交道), 而Python则主要用于开发内部服务和后台任务。 这是目前Web2.0公司的通用选项。

 

消息中间件:RabbitMQ

1.RabbitMQ: high performance messaging solution

http://sunjun041640.blog.163.com/blog/static/256268322010325105129567/

2. Rabbits and warrens

http://blogs.digitar.com/jjww/2009/01/rabbits-and-warrens/

3.通过消息中间件和云计算实现系统可伸缩性

http://blogs.huihoo.com/?p=655

4.RabbitMQ/AMQP所描绘的 美好前景(转)

http://swingchen.javaeye.com/blog/173658

5.RabbitMQ安装和测试小记

http://blog.csdn.net/dqatsh/archive/2010/06/05/5649539.aspx

 

 

分库的一般阶段:

1. 一台主库和一台从库组成。 从库只用作备份和容灾,当主库出现故障时,从库就手动变成主库,一般情况下,从库不作读写操作(同步除外)。

2. 一台主库和多台从库。一些实时性要求不高的Query放到从库去执行。后面又通过添加多个从库来分流查询压力。

3. 随着数据量的增加,主库的写压力也越来越大,这是要拆库:

   3.1. 垂直拆分:是指按功能模块拆分,比如可以将群组相关表和照片相关表存放在不同的数据库中,这种方式多个数据库之间的表结构不同。

   3.2. 水平拆分:而水平拆分是将同一个表的数据进行分块保存到不同的数据库中,这些数据库中的表结构完全相同。

   3.3. 一般都会先进行垂直拆分,因为这种方式拆分方式实现起来比较简单,根据表名访问不同的数据库就可以了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值