Volné spojení - Loose coupling

v výpočetní a návrh systémů A volně vázané systém je takový, ve kterém každý z nich komponenty má nebo využívá malou nebo žádnou znalost definic jiných samostatných komponent. Podoblasti zahrnují spojka tříd, rozhraní, dat a služeb.[1] Volná spojka je opakem těsné spojky.

Výhody a nevýhody

Komponenty ve volně propojeném systému lze nahradit alternativními implementacemi, které poskytují stejné služby. Komponenty ve volně propojeném systému jsou méně omezeny na stejnou platformu, jazyk, operační systém nebo prostředí sestavení.

Pokud jsou systémy odděleny včas, je obtížné je také zajistit transakční integrita; jsou vyžadovány další koordinační protokoly. Replikace dat napříč různými systémy poskytuje volné propojení (v dostupnosti), ale vytváří problémy s údržbou konzistence (synchronizace dat ).

V integraci

Volná spojka v širším distribuovaný systém designu je dosaženo použitím transakcí, front poskytovaných middleware orientovaný na zprávy a standardy interoperability.[2]

Čtyři typy autonomie, které podporují volné propojení, jsou: referenční autonomie, časová autonomie, autonomie formátu, a autonomie platformy.[3]

Volná vazba je architektonický princip a cíl designu v architektury orientované na služby; jedenáct forem volné spojky a jejich těsné protějšky spojky jsou uvedeny v:[4]

  • fyzické připojení prostřednictvím mediátora,
  • asynchronní komunikace styl,
  • jednoduché běžné typy pouze v datový model,
  • slabý typ systému,
  • datově orientovaný a samostatné zprávy,
  • distribuované řízení logiky procesu,
  • dynamická vazba (spotřebitelů a poskytovatelů služeb),
  • nezávislost na platformě,
  • spíše kompenzace na obchodní úrovni než transakce na úrovni systému,
  • nasazení v různých časech,
  • implicitní upgrady ve verzi.

Enterprise Service Bus (ESB) middleware byl vynalezen, aby se dosáhlo uvolněné vazby ve více rozměrech;[5] Nadměrně navržené a nesprávně umístěné ESB však mohou mít také opačný účinek a vytvořit nežádoucí těsné propojení a centrální architektonický hotspot.

Architektura založená na událostech také se zaměřuje na podporu volného propojení.[6]

Metody pro snížení vazby

Volné propojení rozhraní lze vylepšit publikováním dat ve standardním formátu (například XML nebo JSON ).

Volné propojení mezi komponenty programu lze vylepšit použitím standardních datových typů v parametrech. Předávání přizpůsobených datových typů nebo objektů vyžaduje, aby obě komponenty měly znalosti o definici vlastních dat.

Volné propojení služeb lze vylepšit snížením informací předávaných do služby na klíčová data. Například služba, která odesílá dopis, je opakovaně použitelná, když je předán pouze identifikátor zákazníka a v rámci služby je získána adresa zákazníka. Tím se oddělují služby, protože služby není nutné volat v určitém pořadí (např. GetCustomerAddress, SendLetter).

Volné propojení integrace aplikací v kontextech automatizace obchodních procesů lze zvýšit sledováním modelu integrace prezentační vrstvy, ve kterém automatizační aplikace interagují se základními automatizovanými aplikacemi prostřednictvím prezentační vrstvy nebo grafického uživatelského rozhraní.

V programování

Spojení se týká míry přímého poznání, které má jedna složka jiné. Volná vazba ve výpočtech je interpretována jako zapouzdření vs. nezapouzdření.

Příklad těsného spojení nastane, když závislá třída obsahuje ukazatel přímo na konkrétní třídu, která poskytuje požadované chování. Závislost nelze nahradit ani změnit její „podpis“ bez nutnosti změny závislé třídy. K volnému propojení dojde, když závislá třída obsahuje ukazatel pouze na rozhraní, které pak může být implementováno jednou nebo mnoha konkrétními třídami. Závislost závislé třídy je na „kontraktu“ určeném rozhraním; definovaný seznam metod a / nebo vlastností, které musí implementační třídy poskytnout. Libovolná třída, která implementuje rozhraní, tak může uspokojit závislost závislé třídy, aniž by ji musela měnit. To umožňuje rozšiřitelnost v designu softwaru; lze napsat novou třídu implementující rozhraní, která nahradí aktuální závislost v některých nebo všech situacích, aniž by bylo nutné měnit závislou třídu; nové a staré třídy lze volně zaměňovat. Silné spojení to neumožňuje.

Tohle je UML diagram ilustrující příklad volný vazba mezi závislou třídou a sadou konkrétních tříd, které poskytují požadované chování:

Příklad volného spojení.JPG

Pro srovnání tento diagram ilustruje alternativní design s silný propojení mezi závislou třídou a poskytovatelem:

Příklad silného spojení.JPG

Jiné formy

Počítačové programovací jazyky, které mají představy o obou funkcích jako základní modul (viz Funkcionální programování ) nebo funkce jako objekty poskytují vynikající příklady volně spojeného programování. Funkční jazyky mají vzory Pokračování, Uzavření nebo generátory. Vidět Clojure a Lisp jako příklady funkčních programovacích jazyků. Objektově orientované jazyky jako Pokec a Rubín mít bloky kódu, zatímco Eiffelova má agenty. Základní myšlenkou je objektivizovat (zapouzdřit jako objekt) funkci nezávislou na jakémkoli jiném uzavírajícím konceptu (např. Oddělení funkce objektu od jakékoli přímé znalosti obklopujícího objektu). Vidět Prvotřídní funkce pro další nahlédnutí do funkcí jako objektů, které se kvalifikují jako jedna forma prvotřídní funkce.

Například v objektově orientovaném jazyce, když je na funkci objektu odkazováno jako na objekt (osvobozuje ho od jakékoli znalosti jeho obklopujícího objektu hostitele), lze nový objekt funkce předat, uložit a zavolat na Později. Objekty příjemce (jimž jsou tyto funkční objekty dány) mohou bezpečně spouštět (volat) obsaženou funkci podle svého vlastního pohodlí bez jakékoli přímé znalosti obklopujícího objektu hostitele. Tímto způsobem může program spouštět řetězce nebo skupiny funkčních objektů a zároveň bezpečně oddělit od přímého odkazu na obklopující hostitelský objekt.

Telefonní čísla jsou vynikajícím analogem a mohou snadno ilustrovat míru tohoto oddělení.

Například: Některá entita poskytuje jiné entitě telefonní číslo, na které může volat, aby mohla provést konkrétní práci. Když je číslo voláno, volající entita skutečně říká: „Prosím, udělejte tuto práci za mě.“ Odpojení nebo uvolněné spojení je okamžitě patrné. Subjekt přijímající číslo, které má volat, nemusí mít žádné znalosti o tom, odkud číslo pochází (např. Odkaz na dodavatele čísla). Na druhé straně je volající odpojen od konkrétních znalostí o tom, komu volají, kde jsou, a vědět, jak přijímač hovoru interně funguje.

Na příkladu, který nese příklad, může volající říci příjemci hovoru: „Prosím, udělejte tuto práci za mě. Až budete hotovi, zavolejte mi na toto číslo.“ „Číslo“ nabízené přijímači se označuje jako „zpětné volání“. Opět je zřejmá volná vazba nebo oddělená povaha tohoto funkčního objektu. Příjemce zpětného volání neví, co nebo komu je voláno. Ví pouze, že může uskutečnit hovor, a sám se rozhodne, kdy zavolat. Ve skutečnosti nemusí být zpětné volání vůbec tím, kdo zpětné volání poskytl. Tato úroveň indirection je to, co dělá funkční objekty vynikající technologií pro dosažení volně vázaných programů.

Spojení měřicích datových prvků

Stupeň uvolněné spojky lze měřit zaznamenáním počtu změn v datové prvky které by mohly nastat v odesílajícím nebo přijímajícím systému a které by určovaly, zda počítače budou i nadále správně komunikovat. Mezi tyto změny patří například tyto položky:

  1. Přidávání nových datových prvků do zpráv
  2. Změna pořadí datových prvků
  3. Změna názvů datových prvků
  4. Změna struktur datových prvků
  5. Vynechání datových prvků

Viz také

Reference

  1. ^ Loosely Coupled: The Missing Pieces of Web Services podle Doug Kaye
  2. ^ Pautasso C., Wilde E., Proč je web volně spojený?, Proc. WWW 2009
  3. ^ F. Leymann Volné propojení a architektonické důsledky Archivováno 2016-10-02 na Wayback Machine, Hlavní sdělení ESOCC 2016
  4. ^ N. Josuttis, SOA v praxi. O'Reilly, 2007, ISBN  978-0-596-52955-0.
  5. ^ M. Keen a kol., Vzory: Implementace SOA pomocí Enterprise Service Bus, IBM, 2004
  6. ^ Jak EDA rozšiřuje SOA a proč je to důležité Jack van Hoof