网格计算一般分为两种:数据网格和计算网格,简单的说数据网格就是把数据分布式存储,计算网格就是将任务分解为子认为并行计算。一个计算网格平台的作用就是将任" />

使用开源Grid平台-GridGain实现网格计算

系统 1647 0
<iframe align="top" marginwidth="0" marginheight="0" src="http://www.zealware.com/csdnblog01.html" frameborder="0" width="728" scrolling="no" height="90"></iframe>

网格计算一般分为两种:数据网格和计算网格,简单的说数据网格就是把数据分布式存储,计算网格就是将任务分解为子认为并行计算。

一个计算网格平台的作用就是将任务分解开来,交给不同的结点机器运行,然后把运行结果汇聚起来。这就是Split and Aggregate。如下图所示,一个job请求分解为三个sub-job,分别被不同的机器执行,然后把结果汇聚,返回给调用的客户。

使用开源Grid平台-GridGain实现网格计算

GridGain是一个开源的java网格平台。它集成了很多现成的框架,例如

JBoss
Spring
Spring AOP
JBoss AOP
AspectJ
JGroups

GridGain有两个方法将应用程序grid化:

第一种是使用AOP

假设有一个应用

01 class BizLogic{
02 publicstatic Resultprocess(Stringparam){
03…
04}
05}
06
07 class Caller{
08 publicstatic void Main(String[]args){
09BizLogic.process(args[0]);
10}
11}

如果要把process grid化,只要简单的使用一个@Gridify的annotation即可,在Caller客户端要启动GridFactory

01 class BizLogic{
02 @Gridify ( ) Here
03 publicstatic Resultprocess(Stringparam){
04…
05}
06}
07
08 class Caller{
09 publicstatic void Main(String[]args){
10GridFactory.start(); Here
11
12 try {
13BizLogic.process(args[0]);
14}
15 finally {
16GridFactory.stop(); Here
17}
18}
19}

这是最简单,不破坏原有业务逻辑的方法,还有一种方法如果要实现复杂些的任务分解,扩展GridifyJobAdaptor基类,实现split 和aggregate 接口,具体请参考 http://216.93.179.140:8080/wiki/display/GG10UG/15-Minutes+Jump+Start



Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=1623536


使用开源Grid平台-GridGain实现网格计算


更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描下面二维码支持博主2元、5元、10元、20元等您想捐的金额吧,狠狠点击下面给点支持吧,站长非常感激您!手机微信长按不能支付解决办法:请将微信支付二维码保存到相册,切换到微信,然后点击微信右上角扫一扫功能,选择支付二维码完成支付。

【本文对您有帮助就好】

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描上面二维码支持博主2元、5元、10元、自定义金额等您想捐的金额吧,站长会非常 感谢您的哦!!!

发表我的评论
最新评论 总共0条评论