Živý distribuovaný objekt - Live distributed object

Ilustrace základních konceptů zahrnutých v definici živého distribuovaného objektu.

Živý distribuovaný objekt (také zkráceně jako živý objekt) odkazuje na běžící instanci a distribuováno multi-party (nebo peer-to-peer ) protokol, při pohledu z objektově orientovaný perspektiva, jako entita, která má odlišný identita, smět zapouzdřit vnitřní Stát a vlákna exekuce, a který vykazuje dobře definované externě viditelné chování.

Klíčové koncepty

Klíč programovací jazyk koncepty, jak jsou aplikovány na živé distribuované objekty, jsou definovány takto:

  • Identita. The identita živého distribuovaného objektu je určeno stejnými faktory, které rozlišují mezi instancemi stejného distribuovaného protokolu. Objekt se skládá ze skupiny softwarových komponent fyzicky prováděných na některé sadě fyzických strojů a zapojených do vzájemné komunikace, přičemž každá provádí kód distribuovaného protokolu se stejnou sadou základních parametrů, jako je název skupiny vícesměrového vysílání, identifikátor publikovat-přihlásit se k odběru, identita členské služby atd. Například publikovat-přihlásit se k odběru kanály a skupiny vícesměrového vysílání jsou příklady živých distribuovaných objektů: pro každý kanál nebo skupinu existuje jedna instance distribuovaného protokolu spuštěného mezi všemi počítači, které odesílají, přeposílají nebo přijímají data publikovaná v kanálu nebo vícesměrovém vysílání ve skupině. V tomto případě je identita objektu určena identifikátorem kanálu nebo skupiny kvalifikovanou s identitou distribuovaného systému, který daný kanál nebo skupinu poskytuje, řídí a spravuje. V případě vícesměrového vysílání může být identita systému určena například podle adresy členské služby (entita, která spravuje členství ve skupině vícesměrového vysílání).
  • Proxy (repliky). The proxy nebo a replika živého objektu je jednou z instancí softwarových komponent zapojených do provádění distribuovaného protokolu živého objektu. Objekt lze tedy alternativně definovat jako skupinu zástupců zabývajících se komunikací, společným udržováním nějakého distribuovaného stavu a koordinací jejich operací. Termín proxy zdůrazňuje skutečnost, že jediná softwarová součást sama o sobě nepředstavuje předmět; spíše slouží jako brána prostřednictvím kterého aplikace může získat přístup k určité funkčnosti nebo chování, které se rozprostírá přes sadu počítačů. V tomto smyslu koncept živého distribuovaného objektu proxy zobecňuje pojem a RPC, RMI nebo Vzdálená komunikace .NET proxy na straně klienta pahýl.
  • Chování. The chování živého distribuovaného objektu se vyznačuje množinou možných vzorů vnějších interakcí, se kterými se jeho proxy mohou zapojit do svých místních běhových prostředí. Tyto interakce jsou modelovány jako výměny explicitních událostí (zpráv).
  • Stát. The Stát živého distribuovaného objektu je definován jako součet všech interních, místních stavů jeho proxy. Podle definice je distribuován a replikován. Různé repliky stavu objektu mohou být silně nebo jen slabě konzistentní, v závislosti na sémantice protokolu: instance shoda Protokol bude mít stav svých replik silně konzistentní, zatímco instance a volby vůdce protokol bude mít slabě konzistentní stav. V tomto smyslu termín živý distribuovaný objekt zobecňuje pojem a replikovaný objekt; posledně jmenovaný je specifický typ živého distribuovaného objektu, který k dosažení silné konzistence mezi interními stavy svých replik používá protokol, jako je Paxos, virtuální synchronizace nebo replikace stavového stroje. Stav živého distribuovaného objektu je třeba chápat jako dynamický pojem: jako bod (nebo konzistentní řez) v proudu hodnot, nikoli jako konkrétní hodnota umístěná na daném místě v daném čase. Například externě viditelný stav volebního objektu vůdce by byl definován jako identita aktuálně zvoleného vůdce. Totožnost není uložena na žádném konkrétním místě; spíše se zhmotňuje jako proud zpráv ve formě zvolen (x) souběžně produkovaný proxy podílejícími se na provádění tohoto protokolu a současně spotřebovaný instancemi aplikace používající tento protokol na různých počítačích distribuovaných po síti.
  • Rozhraní (koncové body). The rozhraní živého distribuovaného objektu je definován typy rozhraní vystavených jeho proxy; mohou to zahrnovat kanály událostí a různé typy grafických uživatelských rozhraní. Rozhraní vystavená proxy se označují jako živý distribuovaný objekt koncové body. Termín instance koncového bodu odkazuje na jeden konkrétní kanál události nebo uživatelské rozhraní vystavené jediným konkrétním proxy serverem. Říct, že živý objekt vystavuje určitý koncový bod znamená, že každý z jeho proxy vystavuje instanci tohoto koncového bodu svému místnímu prostředí a každá z instancí koncového bodu nese události stejných typů (nebo se váže na stejný typ grafického zobrazení).
  • Reference. The odkaz k živému objektu je kompletní sada serializováno, přenosné pokyny pro konstrukci proxy. Na dereference odkaz znamená lokálně analyzovat a postupovat podle těchto pokynů na konkrétním počítači a vytvořit běžící proxy živého objektu. Takto definovaný odkaz na živý objekt hraje stejnou roli jako Java odkaz, C / C ++ ukazatel nebo webová služba je WSDL popis; obsahuje úplné informace dostatečné k lokalizovat daný objekt a komunikovat s ním. Protože živé distribuované objekty nemusí být umístěny na žádném konkrétním místě (ale spíše se rozprostírají napříč dynamicky se měnící sadou počítačů), nelze informace obsažené v odkazu živého distribuovaného objektu omezit pouze na adresu. Pokud je objekt identifikován nějakým druhem globálně jedinečného identifikátoru (jak by tomu mohlo být v případě témat publikování a odběru nebo skupin vícesměrového vysílání), musí odkaz určit, jak je tento identifikátor vyřešen, rekurzivním vložením odkazu na příslušný rozlišení jmen objekt.
  • Typy. The typ živého distribuovaného objektu určuje vzorce vnějších interakcí s objektem; je určen typy koncových bodů a grafických uživatelských rozhraní vystavených proxy objektu a vzory událostí, které se mohou v koncových bodech vyskytnout. Omezení, která typ objektu umístí na vzory událostí, se mohou rozprostřít po celé síti. Zadejte například atomový multicast může specifikovat, že pokud událost formuláře doručit (x) je generován jedním proxy serverem, podobnou událost musí nakonec vygenerovat všichni nezávadný proxy (proxy, která běží na počítačích, které nikdy nespadnou a nikdy nepřestanou fungovat nebo jsou z protokolu vyloučeny; přesná definice se může lišit). Stejně jako u typů v Jáva - jako jazyky, může existovat mnoho velmi odlišných implementací stejného typu. Tedy například chování charakteristické pro atomový multicast mohou být vystaveny instancemi distribuovaných protokolů, jako je virtuální synchronizace nebo Paxos.

Sémantiku a chování živých distribuovaných objektů lze charakterizovat z hlediska distribuované datové toky; sada zpráv nebo událostí, které se objevují v instancích koncového bodu živého objektu, tvoří tok distribuovaných dat[1].[2]

Dějiny

Rané myšlenky, které jsou základem konceptu živého distribuovaného objektu, byly ovlivněny bohatým souborem výzkumu objektově orientovaných prostředí, vložením programovacích jazyků a rámcovými kompozičními rámci, které se datují přinejmenším od herec model vyvinut na začátku 70. let; komplexní diskusi o příslušné předchozí práci lze nalézt v Ph.D. Krzysztofa Ostrowského disertační práce.[3]

Termín živý distribuovaný objekt byl poprvé použit neformálně v sérii prezentací na podzim roku 2006 na ICWS konference,[4] STC konference,[5] a na MSR laboratoře v Redmondu, WA,[6] a poté formálně definováno v roce 2007 v článku IEEE Internet Computing.[7] Původně se tento termín používal k označení typů dynamických, interaktivních Web obsah to není hostované na servery v datová centra, ale spíše uloženy na koncový uživatel je klient počítače a interně napájen z instancí spolehlivý vícesměrové vysílání protokoly. Slovo žít vyjádřil skutečnost, že zobrazené informace jsou dynamické, interaktivní, a představuje aktuální, aktuální, živý obsah, který odráží nedávné aktualizace provedené uživateli (na rozdíl od statického, pouze ke čtení, a archivní obsah, který byl předem smontován). Slovo distribuováno vyjádřil skutečnost, že informace nejsou hostovány, uloženy na serveru v datovém centru, ale jsou replikovány mezi počítači koncových uživatelů a aktualizovány v peer-to-peer móda prostřednictvím proudu zpráv vícesměrového vysílání, které mohou být vytvářeny přímo koncovými uživateli konzumujícími obsah; komplexnější diskusi o konceptu živých objektů v kontextu vývoje webu najdete v Krzysztof Ostrowski Ph.D. disertační práce.[3]

Obecnější definice uvedená výše byla poprvé navržena v roce 2008 v dokumentu zveřejněném na ECOOP konference.[8] Rozšíření termínu bylo motivováno potřebou modelovat živé objekty jako kompozice jiných objektů; v tomto smyslu byl koncept inspirován Pokec, který propagoval jednotnou perspektivu všechno je objekt, a Jini, který propagoval myšlenku, že služby jsou objekty. Při použití na živé distribuované objekty perspektiva určuje, že jejich součásti, které zahrnují instance distribuovaných vícestranových protokolů používaných interně k replikaci stavu, by měly být také modelovány jako živé distribuované objekty. Potřeba jednotnosti znamená, že definice živého distribuovaného objektu musí sjednotit pojmy, jako je živý webový obsah, streamy zpráv a instance distribuovaných protokolů více stran.

První implementace konceptu živého distribuovaného objektu, jak je definován v dokumentu ECOOP,[8] byly živé distribuované objekty [9] platforma vyvinutá Krzysztof Ostrowski na Cornell University. Platforma poskytovala sadu vizuálních nástrojů pro přetahování a skládání podobných hierarchických dokumentů webové stránky a obsahující XML -serializované odkazy na živé objekty. Vizuální obsah, například okna chatu, sdílený pracovní plochy a různé druhy mashupy lze skládat přetažením komponent představujících uživatelská rozhraní a instance protokolu do návrhového formuláře a jejich vzájemným propojením. Od okamžiku jeho vytvoření byla vyvinuta řada rozšíření pro vložení živých distribuovaných objektů Microsoft Office dokumenty,[10] a podporovat různé typy hostovaného obsahu, jako jsou Mapy Google.[11] Od března 2009 vývojáři platformu aktivně vyvíjejí.[12][13][14][15][16][17][18][19]

Viz také

Reference

  1. ^ Ostrowski, K., Birman, K., Dolev, D. a Sakoda, C. (2009). "Implementace spolehlivých proudů událostí ve velkých systémech prostřednictvím distribuovaných datových toků a rekurzivního delegování", 3. mezinárodní konference ACM o distribuovaných systémech založených na událostech (DEBS 2009), Nashville, TN, USA, 6. – 9. Července 2009, http://www.cs.cornell.edu/~krzys/krzys_debs2009.pdf
  2. ^ Ostrowski, K., Birman, K., Dolev, D. (2009). "Programování živých distribuovaných objektů s distribuovanými datovými toky", předloženo Mezinárodní konference o objektově orientovaném programování, systémech, jazycích a aplikacích (OOPSLA 2009), http://www.cs.cornell.edu/~krzys/krzys_oopsla2009.pdf
  3. ^ A b Ostrowski, K. (2008). "Živé distribuované objekty", Ph.D. Disertační práce, Cornell University, http://hdl.handle.net/1813/10881.
  4. ^ Ostrowski, K. a Birman, K., 'Extensible Web Services Architecture for Notification in Large-Scale Systems', IEEE International Conference on Web Services (ICWS 2006), Chicago, IL, září 2006, http://ieeexplore.ieee.org/xpls/abs_all.jsp?arnumber=4032049.
  5. ^ Ostrowski, K. a Birman, K., „Scalable Group Communication System for Scalable Trust“, první workshop ACM o škálovatelném důvěryhodném počítači (ACM STC 2006), Fairfax, VA, listopad 2006, http://portal.acm.org/citation.cfm?id=1179477.
  6. ^ Ostrowski, K., (2006). Škálovatelné multicast QuickSilver. Microsoft Research, Redmond, WA, listopad 2006. http://www.researchchannel.org/prog/displayevent.aspx?rID=7870&fID=2276.
  7. ^ Ostrowski, K., Birman, K. a Dolev, D. (2007). "Live Distributed Objects: Enabling the Active Web", IEEE Internet Computing, Listopad – prosinec 2007, 11 (6): 72-78, http://ieeexplore.ieee.org/xpl/freeabs_all.jsp?isnumber=4376216&arnumber=4376231.
  8. ^ A b Ostrowski, K., Birman, K., Dolev, D. a Ahnn, J. (2008). "Programování s živými distribuovanými objekty", Sborník z 22. evropské konference o objektově orientovaném programování, Paphos, Kypr, 7. – 11. Července 2008, J. Vitek, vyd., Přednášky z informatiky, sv. 5142, Springer-Verlag, Berlín, Heidelberg, 463-489, http://portal.acm.org/citation.cfm?id=1428508.1428536.
  9. ^ http://liveobjects.cs.cornell.edu
  10. ^ Ahnn, J., Birman, K., Ostrowski, K. a van Renesse, R. (2008). "Používání živých distribuovaných objektů pro automatizaci kanceláře", Sborník konference ACM / IFIP / USENIX Middleware '08 Conference Companion, Leuven, Belgie, 1. –05. Prosince 2008, Companion '08, ACM, New York, NY, 30-35, http://portal.acm.org/citation.cfm?id=1462735.1462743.
  11. ^ http://liveobjects.cs.cornell.edu/community/index.html
  12. ^ Ostrowski, K. a Birman, K. (2009). "Ukládání a přístup k živému obsahu Mashup v cloudu", 3. mezinárodní seminář ACM SIGOPS o distribuovaných systémech a middlewaru ve velkém měřítku (LADIS 2009), Big Sky, MT, USA. 11. října 2009, http://www.cs.cornell.edu/~krzys/krzys_ladis2009.pdf
  13. ^ Akdogan, A. a Polepalli, S. (2008). "Živé mapy", http://liveobjects.cs.cornell.edu/community/1/index.html
  14. ^ Kashyap, R. a Nagarajappa, D. (2008). "Cornell Yahoo! Živé objekty", http://liveobjects.cs.cornell.edu/community/2/index.html
  15. ^ Dong, X. a Zhang, Z. (2008). "Integrovat živé objekty s webovou službou Flickr", http://liveobjects.cs.cornell.edu/community/3/index.html
  16. ^ Prateek, U. (2008). "Živý objekt Goole Earth", http://liveobjects.cs.cornell.edu/community/4/index.html
  17. ^ Gupta, S. a Vora, H. (2008). "ALGE (živá aplikace Google Earth)", http://liveobjects.cs.cornell.edu/community/5/index.html
  18. ^ Mahajan, R. a Wakankar, S. (2008). "Distribuovaná Google Earth", http://liveobjects.cs.cornell.edu/community/6/index.html
  19. ^ Wadhwa, A., Sankar, H. a Subramaniyan, S. (2008). "Live UI Google Earth", http://liveobjects.cs.cornell.edu/community/7/index.html