LVS/Nginx/HAProxy集群

1.一般中小型的web应用,比如日pv(访问量)小于1000万,用Nginx作负载均衡就可以了。

2.大型网站或重要的服务,且服务器比较多时,可以考虑用lvs。

3.目前比较流行的方案,web前端用Nginx/HAProxy+keepalived作负载均衡,后端用MySQL数据库一主多从和读写分离,采用lvs+keepalived架构。

就阶段而言,

第一阶段,单点的负载均衡Nginx/HAProxy,此时服务器刚脱离单服务器、单数据库模式,需要一定的负载均衡,但规模较小。

第二阶段,网络服务扩大,Nginx不能满足的情况,将Nginx作为LVS的节点来用,或者购买商业的负载均衡设备。

第三阶段,处于成本及自身产品的量身定制,LVS成为主流。

第四阶段,理想架构,Array/LVS+Nginx/HAProxy+Squid/Varnish+AppServer.

keepalived/heartbeat集群

1.heartbeat通过心跳进行通信和选举,keepalived通过VRRP协议进行通信和选举。

2.heartbeat有三个配置文件,keepalived只有一个配置文件。keepalived使用起来更简单,heartbeat配套工具更多,功能更强大。

3.heartbeat的脚本有限制约束,必须要支持 start/stop/restart,keepalived脚本没有约束。

4.heartbeat的目的是用户service的双机,keepalived的目的是模拟路由器的双机,建议业务用heartbeat,LVS用keepalived。