`
java.guru
  • 浏览: 65345 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

lbpool:一个支持负载均衡的JDBC连接缓冲池

阅读更多
lbpool是根据MySQL的复制机制设计的支持负 载均衡的JDBC连接缓冲池。一般来说,MySQL复制机制涉及一台主服务器(master server)和多台复制服务器(slave server),数据库写操作只发生在主服务器上,而读操作则可以分布到主服务器及其他复制服务器。

虽然lbpool是为MySQL设计的,但也可以方便地扩展到其他支持复制功能的数据库系统,如PostgreSQL等。

负载均衡策略

负载均衡算法主要基于并发连接数,负载和slave的状态等参数来选择合适的服务器:
  • 是否可访问;
  • 复制是否依然在进行;
  • 复制是否已经落后主服务器;
  • 负载是否太高;
  • 数据库连接数是否太多。

一些有用的特性

  • 实时重负载均衡:即当客户端断开,或某服务器断线或重新在线后,系统会对现有数据库连接进行重分配以达到动态的负载平衡;
  • 如果所有服务器都断线,则系统在一段时间内会阻塞数据库查询,避免马上抛出SQLException,当某台机器在线后,则数据库查询马上恢复正常;
  • 如果某台服务器断线,或复制服务器与主服务器断开或滞后很长时间,则原有连接会被切换到其他服务器,而且并不影响正在进行过程的查询;
  •  复制服务器信息配置在主服务器上,支持动态配置,因此可以方便地增加、删除或维护复制服务器。

可与Hibernate的集成?

目前很多系统都采用Hibernate做持久层,而Hibernate支持C3P0, DBCP等JDBC数据库连接缓冲池。

而我公司在做的网站监测项目YouMonitor.Us也是采用Hibernate做数据持久层的,我们目前采用C3P0缓冲池,但C3P0不支持在主服务器、及多个复制服务器间分布查询操作。

因此,JDBC连接缓冲池与Hibernate的集成性显得特别重要。目前不能确定lbpool是否可以与Hibernate集成;若不支持,是否可方便地修改源码来支持?

分享到:
评论
1 楼 xianglei 2008-10-21  
能给发个lbpool的包么?好像现在那个连接不能下载了。邮箱xnang@163.com  谢谢

相关推荐

Global site tag (gtag.js) - Google Analytics