服务器集群环境下Hibernate使用问题与解决方案①.docVIP

服务器集群环境下Hibernate使用问题与解决方案①.doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
服务器集群环境下Hibernate使用问题与解决方案①

服务器集群环境下Hibernate使用问题与解决方案①   摘 要:近段时间应用系统由原来的单服务器响应升级到了服务器集群环境,但是在升级过程中,系统原有的应用软件碰到了一些问题,本文主要针对Hibernate在服务器集群环境下的一些问题探讨和提出解决方案。   关键词:服务器集群 Hibernate Increment Cache   中图分类号:TP393 文献标识码:A 文章编号:1672-3791(2011)08(b)-0014-01      1 服务器集群   服务器集群就是指将很多服务器集中起来一起进行同一种服务,在客户端看来就像是只有一个服务器集群可以利用多个计算机进行并行计算从而获得很高的计算速度,也可以用多个计算机做备份,从而使得任何一个机器坏了整个系统还是能正常运行。   使用集群服务器构建的集群系统优点在于:(1)统集群系统可解决所有的服务器硬件故障,当某一台服务器出现任何故障,如:硬盘、内存、CPU、主板、I/O板以及电源故障,运行在这台服务器上的应用就会切换到其它的服务器上。(2)集群系统可解决软件系统问题,我们知道,在计算机系统中,用户所使用的是应用程序和数据,而应用系统运行在操作系统之上,操作系统又运行在服务器上。这样,只要应用系统、操作系统、服务器三者中的任何一个出现故障,系统实际上就停止了向客户端提供服务,比如我们常见的软件死机,就是这种情况之一,尽管服务器硬件完好,但服务器仍旧不能向客户端提供服务。而集群的最大优势在于对故障服务器的监控是基于应用的,也就是说,只要服务器的应用停止运行,其它的相关服务器就会接管这个应用,而不必理会应用停止运行的原因是什么。(3)集群系统可以解决人为失误造成的应用系统停止工作的情况,例如:当管理员对某台服务器操作不当导致该服务器停机,因此运行在这台服务器上的应用系统也就停止了运行。由于集群是对应用进行监控,因此其它的相关服务器就会接管这个应用,提高了应用系统的稳定性。      2 常见问题   应用系统升级到集群服务器环境下,碰到的主要问题是Hibernate代理的主键在插入时,主键重复异常信息明显增多。通过对应用系统源代码进行分析,发现出现的问题主要为以下两方面。   2.1 Hibernate的Generator配置为increment   increment方式为Hibernate提供的一种内置的常用的主键生成器策略,此方式的实现机制为在当前应用实例中维持一个变量,以保存着当前的最大值,之后每次需要生成主键的时候将此值加1作为主键。这种方式可能产生的问题是:如果当前有多个实例访问同一个数据库,那么由于各个实例各自维护主键状态,不同实例可能生成同样的主键,从而造成主键重复异常。因此,如果同一数据库有多个实例访问,此方式必须避免使用。   目前我们的应用系统环境为最简单的集群方式:两台was,一台数据库的方式。所以当有并发情况访问系统且两个请求又被分发给两台was时,假设当前数据库id最大为40,两台was分别会产生两条id为41的数据导致插入失败(Duplicate entry主键重复)。   Increment主键生成器的org.hibernate.id.IncrementGenerator类里面,是使用select max(columnName)from tableName的方式来获取。原来的程序一直运行很好,但是在用两个was来负载均衡后却出现问题。为什么?IncrementGenerator类里面的generate()方法虽然被声明成了synchronized,但现在两个Tomcat分别运行在两台服务器的两个独立的Java虚拟机里,显然问题在这里,synchronized只能在一个独立的Java虚拟机内部有效。所以,在两个Tomcat中用select max同时取主键,就相当于在没有synchronized的保护下,并发时就会取出相同的值,再insert就会发生dumplicate entry的错误。   2.2 Hibernate的cache配置策略问题   Hibernate的cache是他提高效率的主要原因,比如我load,save的各种数据都会在缓存起来,用id标识,当我下次再次查询的时候,它会把id的集合都查出来,然后在缓存中遍历,如果都遍历到了,将不再访问数据库。显然这在集群环境下,也是小概率事件,但是这不影响数据正确完整,真正影响数据的是read-write cache。   Hibernate的缓存分为一级缓存和二级缓存,二级缓存需要特殊配置,通常情况下不用,一级缓存就包括上一个段落说的情况,分为read-only cache和read-write cache。Read-only cache只读

文档评论(0)

3471161553 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档