MyException - 我的异常网
当前位置:我的异常网» J2EE » 怎么在多服务器结构下处理hibernate一级缓存造成的

怎么在多服务器结构下处理hibernate一级缓存造成的不同步

www.MyException.Cn  网友分享于:2015-08-26  浏览:71次
如何在多服务器结构下处理hibernate一级缓存造成的不同步
问题描述:
现有一大并发量连续买卖操作涉及到帐务的收支记录,帐务操作分为入账和出账两种。
某个时间段某位用户的10笔帐务流水记录如下:
  发生时间 入账/出账 发生金额 之前帐户余额 之后帐户余额
1 2008-1-12 8:19 2 1 50.7 49.7
2 2008-1-12 8:19 2 1 49.7 48.7
3 2008-1-12 8:19 2 1 48.7 47.7
4 2008-1-12 8:20 2 1 47.7 46.7
5 2008-1-12 8:20 2 1 46.7 45.7
6 2008-1-12 8:20 2 1 45.7 44.7
7 2008-1-12 8:20 1 10 44.7 54.7
8 2008-1-12 8:21 2 1 48.7 47.7
9 2008-1-12 8:21 2 1 47.7 46.7
10 2008-1-12 8:51 2 1 46.7 45.7
*在上表记录中2为出账,1为入账。
上面第8笔交易出现了帐户余额错误,其“之前帐户余额”应为54.7。
所有交易的帐户余额都是在事务处理过程中由帐户接口内部查询出来的,与外部用户操作无关,与用户相关的只有发生金额;
且用户在这些交易过程中没有其它任何涉及到帐户余额改变的操作,即便有也会在流水帐数据上体现出来。

问题产生原因分析:
网站采用多服务器(>10台)+负载平衡设备,用户每次的request都由负载平衡设备随机分配到某台服务器。
数据操作采用了hibernate组件,没有开启lazy。怀疑造成该问题原因是hibernate一级缓存的被动更新方式。
从上表数据可看出,第2笔交易后余额为48.7(假设该笔交易被负载平衡分配到服务器1),因此推断3-7笔交易不是在服务器1上进行的,从而导致第8笔交易被分配服务器1上时,由于连续交易间隔时间短,读取了没有及时更新的hibernate缓存数据(get方法获取)。

问:如何在多服务器结构下处理各个服务器hibernate数据一级缓存同步?

如果实在不行只能不使用hibernate了。


------解决方案--------------------
挺复杂啊。。。丁页。。。学习ing........
------解决方案--------------------
up
------解决方案--------------------
关注中,建议参考下孙卫琴精通Hibernate中对事务处理的那部分,以前大概看过两眼,跟你问的好像有关,没细研究。
------解决方案--------------------
这个需要分布式的事务处理。
------解决方案--------------------
1 采用乐观锁,此方法修改最少,但可能某些事务会提交失败
2 修改你的代码,在事务中锁定数据库的数据,行,多行甚至表, 也就是悲观锁
3 Hibernate采用 ehCache, 配置 ehcache的分布式属性。 推荐
------解决方案--------------------
个人认为分布式事务和这个没有关系,如果你的事务需要跨多个数据库服务器,倒是可以考虑。

其实乐观锁挺好的,就是每个数据加上一个版本啦,更新的时候hibernate会自动校验的
Version 就是这个。

具体的去搜索吧!
------解决方案--------------------
我不太清楚lz的database server是不是多台。

具体可以参考下面的链接:http://www.hibernate.org/201.html
引用:To get a free distributed cache for your Hibernate database integration, all you need to do is replace your existing Hibernate cache provider, typically EhCache, with the free GigaSpaces Community Edition, in 6 easy steps.
------解决方案--------------------
学习
------解决方案--------------------
占个位置
------解决方案--------------------
GigaSpaces的Master-Local Cache Topology应该可以实现你的功能。。 

文章评论

做程序猿的老婆应该注意的一些事情
做程序猿的老婆应该注意的一些事情
60个开发者不容错过的免费资源库
60个开发者不容错过的免费资源库
Java程序员必看电影
Java程序员必看电影
为什么程序员都是夜猫子
为什么程序员都是夜猫子
漫画:程序员的工作
漫画:程序员的工作
鲜为人知的编程真相
鲜为人知的编程真相
为啥Android手机总会越用越慢?
为啥Android手机总会越用越慢?
程序员的鄙视链
程序员的鄙视链
如何成为一名黑客
如何成为一名黑客
程序员必看的十大电影
程序员必看的十大电影
团队中“技术大拿”并非越多越好
团队中“技术大拿”并非越多越好
老程序员的下场
老程序员的下场
10个调试和排错的小建议
10个调试和排错的小建议
不懂技术不要对懂技术的人说这很容易实现
不懂技术不要对懂技术的人说这很容易实现
程序员应该关注的一些事儿
程序员应该关注的一些事儿
 程序员的样子
程序员的样子
5款最佳正则表达式编辑调试器
5款最佳正则表达式编辑调试器
程序员最害怕的5件事 你中招了吗?
程序员最害怕的5件事 你中招了吗?
中美印日四国程序员比较
中美印日四国程序员比较
那些性感的让人尖叫的程序员
那些性感的让人尖叫的程序员
要嫁就嫁程序猿—钱多话少死的早
要嫁就嫁程序猿—钱多话少死的早
亲爱的项目经理,我恨你
亲爱的项目经理,我恨你
程序员眼里IE浏览器是什么样的
程序员眼里IE浏览器是什么样的
程序员和编码员之间的区别
程序员和编码员之间的区别
什么才是优秀的用户界面设计
什么才是优秀的用户界面设计
当下全球最炙手可热的八位少年创业者
当下全球最炙手可热的八位少年创业者
那些争议最大的编程观点
那些争议最大的编程观点
代码女神横空出世
代码女神横空出世
“懒”出效率是程序员的美德
“懒”出效率是程序员的美德
10个帮程序员减压放松的网站
10个帮程序员减压放松的网站
我是如何打败拖延症的
我是如何打败拖延症的
初级 vs 高级开发者 哪个性价比更高?
初级 vs 高级开发者 哪个性价比更高?
旅行,写作,编程
旅行,写作,编程
写给自己也写给你 自己到底该何去何从
写给自己也写给你 自己到底该何去何从
看13位CEO、创始人和高管如何提高工作效率
看13位CEO、创始人和高管如何提高工作效率
程序猿的崛起——Growth Hacker
程序猿的崛起——Growth Hacker
一个程序员的时间管理
一个程序员的时间管理
聊聊HTTPS和SSL/TLS协议
聊聊HTTPS和SSL/TLS协议
科技史上最臭名昭著的13大罪犯
科技史上最臭名昭著的13大罪犯
程序员的一天:一寸光阴一寸金
程序员的一天:一寸光阴一寸金
编程语言是女人
编程语言是女人
Java 与 .NET 的平台发展之争
Java 与 .NET 的平台发展之争
程序员都该阅读的书
程序员都该阅读的书
2013年中国软件开发者薪资调查报告
2013年中国软件开发者薪资调查报告
总结2014中国互联网十大段子
总结2014中国互联网十大段子
Web开发者需具备的8个好习惯
Web开发者需具备的8个好习惯
2013年美国开发者薪资调查报告
2013年美国开发者薪资调查报告
我跳槽是因为他们的显示器更大
我跳槽是因为他们的显示器更大
“肮脏的”IT工作排行榜
“肮脏的”IT工作排行榜
软件开发程序错误异常ExceptionCopyright © 2009-2015 MyException 版权所有