網(wǎng)格計(jì)算一般分為兩種:數(shù)據(jù)網(wǎng)格和計(jì)算網(wǎng)格,簡(jiǎn)單的說數(shù)據(jù)網(wǎng)格就是把數(shù)據(jù)分布式存儲(chǔ),計(jì)算網(wǎng)格就是將任務(wù)分解為子認(rèn)為并行計(jì)算。
一個(gè)計(jì)算網(wǎng)格平臺(tái)的作用就是將任務(wù)分解開來,交給不同的結(jié)點(diǎn)機(jī)器運(yùn)行,然后把運(yùn)行結(jié)果匯聚起來。這就是Split and Aggregate。如下圖所示,一個(gè)job請(qǐng)求分解為三個(gè)sub-job,分別被不同的機(jī)器執(zhí)行,然后把結(jié)果匯聚,返回給調(diào)用的客戶。
GridGain是一個(gè)開源的java網(wǎng)格平臺(tái)。它集成了很多現(xiàn)成的框架,例如
JBoss
Spring
Spring AOP
JBoss AOP
AspectJ
JGroups
GridGain有兩個(gè)方法將應(yīng)用程序grid化:
第一種是使用AOP
假設(shè)有一個(gè)應(yīng)用
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化,只要簡(jiǎn)單的使用一個(gè)@Gridify的annotation即可,在Caller客戶端要啟動(dòng)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}這是最簡(jiǎn)單,不破壞原有業(yè)務(wù)邏輯的方法,還有一種方法如果要實(shí)現(xiàn)復(fù)雜些的任務(wù)分解,擴(kuò)展GridifyJobAdaptor基類,實(shí)現(xiàn)split 和aggregate 接口,具體請(qǐng)參考 http://216.93.179.140:8080/wiki/display/GG10UG/15-Minutes+Jump+Start
Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=1623536
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號(hào)聯(lián)系: 360901061
您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長非常感激您!手機(jī)微信長按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對(duì)您有幫助就好】元
