版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
分布協(xié)同計(jì)算基礎(chǔ)第二章:分布式算法(2)
---領(lǐng)導(dǎo)者選舉張錫哲副教授計(jì)算機(jī)應(yīng)用技術(shù)研究所東北大學(xué)信息科學(xué)與工程學(xué)院選舉問(wèn)題Ifweareusingoneprocessasacoordinatorforasharedresource……h(huán)owdoweselectthatoneprocess?Often,thereisnoownerormasterthatisautomaticallyconsideredascoordinator選舉問(wèn)題Manydistributedsystemsareclientserverbased,withoneserver/coordinator(leader),andmultipleclientsWhathappensiftheleaderfails?ElectanewoneCannotassumeonlyoneprocessdetectsthecrashTheelectionshouldgetalloftheprocessestoagreethatonenodeisaleader選舉誰(shuí)?Basicidea:Ifeachprocesshasauniqueidentity,andtheidentitiesareorderedElectthenon-crashednodewithminimum/maximumidentity選舉算法旳應(yīng)用whenacentralizedalgorithmistobe
executedinadistributedsystemforinstance,afterasystemcrashwhenitis
unknownwhichnodesareworking什么是選舉
“tostartfromaconfigurationwhereall
processesareinthesamestateandarriveat
aconfigurationwhereexactlyoneprocessis
theleader”
Goal:toobtainlowmessagecomplexity選舉算法旳定義Formally,analgorithmisanelectionalgorithmiff:EachprocesshasthesamelocalalgorithmThealgorithmisdecentralizedItcanbeinitiatedbyanynumberofprocessesinthesystemItreachesaterminalconfiguration,andineachreachableterminalconfigurationoneprocessisinstateleaderandtherestareinthestatelost假設(shè)FullyasynchronoussystemNoglobalclock,transmissiontimesarbitraryEveryprocesshasauniqueidentityIdentitiesaretotallyorderedBecausewehavefinitenumberofprocesses:MaxidentityandMinidentityavailable(extremevalues)RemarkProcessorsareinoneofthreestates:undecided,leader,lostInitiallyeveryprocessisintheundecidedstateWhenleavingtheundecidedstate,aprocessorgoesintoaterminatedstate(leaderorlost)環(huán)網(wǎng)上旳選舉單向環(huán)雙向環(huán)LeLann77,O(N2)Chang-Roberts79Ω(N2),Θ(NlogN)Hirshbergetal.80Ω(NlogN)Petersen/Dolevetal.82Ω(NlogN)11環(huán)網(wǎng)上旳選舉ThefirsteverelectionalgorithmwasdoneforringsbyLeLannSimpleidea:LeteveryinitiatorsendatokenwiththeiridentityaroundthewholeringNodesarenotallowedtoinitiateaftertheyreceiveatoken(example…)12ExampleNodesarenotallowedtoinitiateamessageaftertheyreceiveatoken(example…)35198267initiator13ExampleNodesarenotallowedtoinitiateamessageaftertheyreceiveatoken(example…)35198267initiator14ExampleNodesarenotallowedtoinitiateamessageaftertheyreceiveatoken(example…)35198267initiatornotallowedtoinitiate15ExampleNodesarenotallowedtoinitiateamessageaftertheyreceiveatoken(example…)35198267initiatornotallowedtoinitiatenotallowedtoinitiate16ExampleNodesarenotallowedtoinitiateamessageaftertheyreceiveatoken(example…)35198267initiatornotallowedtoinitiatenotallowedtoinitiatenotallowedtoinitiate17ExampleNodesarenotallowedtoinitiateamessageaftertheyreceiveatoken(example…)35198267initiatornotallowedtoinitiatenotallowedtoinitiateinitiatornotallowedtoinitiate18ExampleNodesarenotallowedtoinitiateamessageaftertheyreceiveatoken(example…)35198267initiatornotallowedtoinitiatenotallowedtoinitiateinitiatornotallowedtoinitiatenotallowedtoinitiate19ExampleNodesarenotallowedtoinitiateamessageaftertheyreceiveatoken(example…)35198267initiatornotallowedtoinitiatenotallowedtoinitiateinitiatornotallowedtoinitiatenotallowedtoinitiatenotallowedtoinitiate20LeLann’sringelectionWheneveranodereceivesbackitsid,ithasseeneveryotherinitiatorsidAssumingFIFOchannelsLeteverynodekeepalistofeveryidentifierseen(listp)Ifnon-initiator,state=lostimmediatelyIfinitiator,whenownidreceived:state=leaderifmin{listp}=pstate=lost
otherwiseLeLann’sAlgorithmNon-initiatorsjustforwardandloseInitiallyonlyknowmyselfSendmyid,andwaitRepeatforwardingandcollectingidsuntilwereceiveouridTermination:didwewinorlose22MessageComplexityWorstcaseiseverynodeisinitiator(N)EveryinitiatorsendsNmessagesGivesatotalofN2messages23時(shí)間復(fù)雜度AssumelastinitiatorfstartsattimeN-1fterminatesafteritstokenhascirculatedthering,NstepsTimecomplexity2N-135198267initiatorlastinitiator24Chang-Roberts算法ChangandRobertscameupwithasmallimprovementIdea:Whenanodereceivesatokenwithlargeridthanitself,whyshoulditkeepforwardingit?Itisawaste,weknowthatthatidwillneverwin!Letsdroptokenswithlargeridsthanourselves!25HowtomakeitworkButifwedropatokenwithids,nodeswillbewaitingforeveronitstokentocomebackHowdowesolvethat?26HowtomakeitworkIfnodestokenisdropped,itwillanywayreceiveanothertokenwithloweridInthatcase,sshouldsetstate=lostChangandRobertsAlgoNon-initiatorsjustforwardandloseInitiatorsendsitstokenWhilenotleader,keepreceivingtokensIfmytokencomes,thenIwonOtherwise,onlyforwardifit’sloweridthanmeandlose28ChangRoberts-ExampleNodes1,3,6areinitiators6913Non-initiatorLostWon6Initiator132901753264ChangRobertsAnalysisWorstcasecomplexitysameasLeLann’sTimeComplexity:2N-1MessageComplexity:O(N2)ConsideredasortedringwithNinitiators8times7times6times5times4times3times2times1times30Furtherimprovements?Letthenon-initiatorsalsofilterloweridsDonotjustcomparewithyourid,comparewiththelowestidyouhaveseen!HSRingElectionHirschbergSinclairAlgorithm(ringmodification)O(N2)isalotofmessages.HereisamodificationthatisO(NlogN).Assumptions:theringsizecanbeunknown.Thecommunicationsmustbebidirectional.Allnodesstartmoreorlessatthesametime.Eachnodeoperatesinphasesandsendsouttokens.Thetokenscarryhop-countsanddirectionflagsinadditiontotheIDofthesender.3
ID=3,2hops
clockwise
ID=3,2hops
counterclckwsHSRingElectionPhasesarenumbered0,1,2,3,…Ineachphase,k,nodejsendsouttokensujcontainingitsIDinbothdirections.Thetokenstravel2khopsthenreturntotheiroriginj.Ifbothtokensmakeitback,processjcontinueswiththenextphase(incrementsk).Ifbothtokensdonotmakeitback,processjsimplywaitstobetoldwhotheresultsoftheelection.33xxiPhase0:20Phase1:21Phase2:22TrajectoryofsuccessivetokensoriginatingatprocessiHSRingElection6-34HSRingElectionIfaprocessmreceivesatokenujgoingintheoutbounddirection,itcomparesthetoken’sIDwithitsown.IfithasalargerID,itsimplydiscardsthetoken.IfithasasmallerID,itrelaysthetokenasrequested.IfitisequaltothetokenID,ithasreceiveditsowntokenintheoutbounddirection,sothetokenhasgonecleararoundtheringandtheprocessdeclaresitselfleader.Allprocessesalwaysrelayinboundtokens.4ID=3,2hopsclockwise非形式化描述Eachprocessioperatesinphases0,1,2,....Ineachphasel,processisendsout"tokens"containingitsUIDuiinbothdirections.Theseareintendedtotraveldistance2l,thenreturntotheirorigini.Ifbothtokensmakeitbacksafely,processicontinueswiththefollowingphase.However,thetokensmightnotmakeitbacksafely.Whileauitokenisproceedingintheoutbounddirection,eachotherprocessjonui'spathcomparesuiwithitsownUIDuj.Ifui<uj,thenjsimplydiscardsthetoken,whereasifui>uj,thenjrelaysui.Ifui=uj,thenitmeansthatprocessjhasreceiveditsownUIDbeforethetokenhasturnedaround,soprocessjelectsitselfastheleader.Allprocessalwaysrelayalltokensintheinbounddirection.HSRingElection一種例子Fordemonstrationpurposes,wewillignoretheasynchronousnatureofthesystemandassumethatallnodesoperateatthesamespeedandatthesametime.InitialnetworkconfigurationwithUIDvaluesinblue.015225314456544134Initialconfiguration.BluenumbersareUIDvaluesThealgorithmstartsinphase0,andeachnodewillsendanoutboundmessagetoitsneighbors.Themessageisintendedtotraveladistanceof20
hops.ThenodesthatreceivedaninboundmessagewithitsOWNUIDfrombothneighborsarequalifiedtoproceedtothenextphase.Theyareindicatedingray.015225314456544134Thenodeseligibletocontinuetophase2Nowweadvancetophase1,andeachactivenodewillsendanoutboundmessagetoitsneighbors.Themessagethistimeisintendedtotraveladistanceof21
hops.Thestraightarrowsrepresentsoutboundandthecurvedarrowsrepresentsinbound.
015225314456544134Phase1.Onlynode4receivesaninboundmessagefrombothneighbors34345656Phase2.Onlynode4isactiveinphase2.Itistheonlynodethatcaninitiateamessage.Themessageisintendedtotravel22
hops.Outgoingmessagessentbynode4intheclockwisedirectionareinpink.Outgoingmessagesinthecounter-clockwisedirectionareingreen.Straightlinesareoutgoingmessages,curvedlinesareincoming.015225314456544134Phase2.Node4onceagainreceivesbothinboundmessageswithownUID5656Phase3.Onlynode4isactiveinphase2.Itistheonlynodethatcaninitiateamessage.Itsmessagesareintendedtotravel23
hops.015225314456544134Phase3.Node4changesitsstatustoleader.43AnalysisofHSRingElectionMessageComplexity:Eachmsgbelongstoaparticularphaseandisinitiatedbyaparticularproc.Probedistanceinphaseiis2iNumberofmsgsinitiatedbyaproc.inphaseiisatmost4*2i(probesandrepliesinbothdirections)44AnalysisofHSRingElectionHowmanyprocs.initiateprobesinphasei?Fori=0,everyproc.doesFori>0,everyproc.thatisa"winner"inphasei-1does"winner"meanshaslargestidinits2i-1neighborhood45AnalysisofHSRingElectionMaximumnumberofphasei-1winnersoccurswhentheyarepackedasdenselyaspossible:totalnumberofphasei-1winnersisatmostn/(2i-1+1)46AnalysisofHSRingElectionHowmanyphasesarethere?Ateachphasethenumberof(phase)winnersiscutinhalf(atleast)Soafteratmostlog2
nphases,onlyonewinnerisleft.47AnalysisofHSRingElectionTotalnumberofmessagesissum,overallphases,ofnumberofwinnersatthatphasetimesnumberofmessagesoriginatedbythatwinner:phase0msgsmsgsforphases1tolognterminationmsgsFranklin算法Allactiveidentitiescomparethemselveswiththe
closestactiveneighbortotheleftandtotherightTheidentityremainsactiveifitisthelocalmin.Peterson/Dolev-Klawe-RodehPetersonLeader-ElectionAlgorithmArbitraryelectionofleaderusingcomparisonofUID’susingunidirectionalcommunicationAlgorithmrunsinphasesinwhicheachprocessisassignedtoactiveorpassivemode(allprocessesstartasactive)ThenumberofactiveprocessesisreducedbyafactoroftwoduringeachphaseSummary:AtthebeginningofeachphaseeachactiveprocessisendsitsUIDtwostepsclockwise.ThenprocessicomparesitsownUIDtothetwoUIDsitreceived.Ifui-1<ui-2andui-1<ui,processiremainsactiveadoptingtheUIDofitscounterclockwiseneighborOtherwiseprocessibecomesarelayPetersonLeaderElectionExamplei11UID=9i10UID=4i9UID=5i12UID=7i8UID=11i7UID=12i6UID=3i5UID=2i4UID=6i3UID=1i2UID=10i1UID=8nPhase1Phase2Phase3Phase4187,9---2108,7---3110,8109,12--461,10---526,1610,91012,101212,12632,6---7123,2---81112,3126,10--9511,12---1045,11---1194,5---1279,4912,61210,12-PetersonLeader-ElectionExamplePetersonLeader-ElectionAlgorithmAnyactiveprocesssurvivesaphaseonlyiftheactiveprocesstoitsleftdoesnotsurvivethatphase.Henceofmactiveprocessesduringaphase,atmostm/2willsurviveform>1.TherecanbeatmostlogNphasestoreachoneactiveprocess.Duringaphaseeveryprocesssends(andreceive)twomessages,andonthelastphasetheloneactiveprocesssendsonemessagewhichisrelayedaroundtothemaximumforatotalof2NlogN+N.5455同步環(huán)中旳選舉Hereisasimplealgorithm.Grouproundsintophases,eachphasecontainingn
roundsInphasei,theprocessorwithidi,ifthereisone,sendsamessagearoundtheringandiselected.56ExampleofSimpleSynchronousAlgorithmn=4,thesmallestidis7.Inphases0through6(correspondingtorounds1through28),nomessageiseversent.Atbeginningofphase7(round29),processorwithid7sendsmessagewhichisforwardedaroundthering.Reliesonsynchronyandknowingn57AnalysisofSimpleAlgorithmCorrectness:Easytosee.Messagecomplexity:
O(n),whichisoptimalTimecomplexity:
O(n*m),wheremisthesmallestidinthering.notboundedbyanyfunctionofn!58AnotherSynchronousAlgorithmWorksinaslightlyweakermodelthantheprevioussynchronousalgorithm:processorsmightnotallstartatsameround;aprocessoreitherwakesupspontaneouslyorwhenitfirstgetsamessageuniform(doesnotrelyonknowingn)59AnotherSynchronousAlgorithmAprocessorthatwakesupspontaneouslyisactive;sendsitsidinafast
message(oneedgeperround)Aprocessorthatwakesupwhenreceivingamsgisrelay;neverinthecompetitionAfastmessagecarryingidmbecomesslow
ifitreachesanactiveprocessor;startstravelingatoneedgeper2mroundsAprocessoronlyforwardsamsgwhoseidissmallerthananyidishaspreviouslysentIfaproc.getsitsownidback,electsself60AnalysisofSynchronousAlgorithmCorrectness:convinceyourselfthattheactiveprocessorwithsmallestidiselected.Messagecomplexity:Winner'smsgisthefastest.Whileittraversesthering,othermsgsareslower,sotheyareovertakenandstoppedbeforetoomanymessagesaresent.61MessageComplexityDividemsgsintothreekinds:fastmsgsslowmsgssentwhiletheleader'smsgisfastslowmsgssentwhiletheleader'smsgisslowNext,countthenumberofeachtypeofmsg.62
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 《水環(huán)境調(diào)查方法》課件
- 2020年安徽省中考英語(yǔ)試卷及答案解析
- 小學(xué)一年級(jí)20以內(nèi)加減法試題口算速算練習(xí)題
- 《護(hù)士禮儀行為規(guī)范》課件
- 《物業(yè)服務(wù)內(nèi)涵》課件
- 銀銅合金焊接知識(shí)點(diǎn)
- 地產(chǎn)建筑行業(yè)技術(shù)工作總結(jié)
- 會(huì)計(jì)行業(yè)會(huì)計(jì)人員培訓(xùn)總結(jié)
- 精神科護(hù)士的綜合總結(jié)
- 零售業(yè)務(wù)員工作總結(jié)
- 2024年度陶瓷產(chǎn)品代理銷售與品牌戰(zhàn)略合作協(xié)議3篇
- 中國(guó)農(nóng)業(yè)銀行信用借款合同
- ISO 56001-2024《創(chuàng)新管理體系-要求》專業(yè)解讀與應(yīng)用實(shí)踐指導(dǎo)材料之9:“5領(lǐng)導(dǎo)作用-5.3創(chuàng)新戰(zhàn)略”(雷澤佳編制-2025B0)
- 江蘇省連云港市2023-2024學(xué)年八年級(jí)上學(xué)期期末數(shù)學(xué)試題(原卷版)
- 2024版旅游景區(qū)旅游巴士租賃合同3篇
- LINUX網(wǎng)絡(luò)操作系統(tǒng)知到智慧樹章節(jié)測(cè)試課后答案2024年秋湖北交通職業(yè)技術(shù)學(xué)院
- 河北省邯鄲市2023-2024學(xué)年高一上學(xué)期期末質(zhì)量檢測(cè)地理試題 附答案
- 醫(yī)療機(jī)構(gòu)競(jìng)業(yè)限制協(xié)議
- 2024年度物業(yè)管理公司員工獎(jiǎng)懲制度3篇
- 【MOOC】藥理學(xué)-華中科技大學(xué) 中國(guó)大學(xué)慕課MOOC答案
- 交通疏導(dǎo)安全教育培訓(xùn)
評(píng)論
0/150
提交評(píng)論