Design Patterns und CORBA
Transcription
Design Patterns und CORBA
Design Patterns und CORBA Heiko Abraham abraham@informatik.uni-freiburg.de 21. Januar 2001 Seminarvortrag “Softwarearchitekturen” Universität Freiburg 1 Seminar ’Softwarearchitekturen’ Inhalt 1. Einleitung Beispiel 2. CORBA - Überblick Eckpunkte Architektur 3. Entwurf mit CORBA 4. CORBA und Design Patterns Skallierung Beispiele 5. Zusammenfassung H.Abraham 2 Seminar ’Softwarearchitekturen’ 1. Einleitung Beispiel: Informationsdienst Situation: vernetzte und verteilte Systeme starke Heterogenität Datenbank 1 Intranet Internet Datenbank 2 rechnerseitig: Daten- und Funktionsverbund – Redundanz, Lastverteilung – Anforderungen: an die Softwarearchitektur ISP ApplicationsServer GSM Flexibilität Wiederverwertbarkeit/Wartbarkeit Interoperabilität H.Abraham 3 Seminar ’Softwarearchitekturen’ 1. Einleitung Beispiel: Informationsdienst Situation: vernetzte und verteilte Systeme starke Heterogenität Datenbank 1 Intranet Internet rechnerseitig: Datenbank 2 Daten- und Funktionsverbund – Redundanz, Lastverteilung – Anforderungen: an die Softwarearchitektur ISP ApplicationsServer GSM Flexibilität Wiederverwertbarkeit/Wartbarkeit Interoperabilität Middleware kann helfen H.Abraham 4 Seminar ’Softwarearchitekturen’ 1. Einleitung Beispiel: Informationsdienst Situation: Datenbank 1 vernetzte und verteilte Systeme starke Heterogenität Intranet Internet rechnerseitig: Datenbank 2 Daten- und Funktionsverbund – Redundanz, Lastverteilung – Anforderungen: ISP ApplicationsServer GSM an die Softwarearchitektur Flexibilität Wiederverwertbarkeit/Wartbarkeit Interoperabilität Middleware kann helfen H.Abraham Objekt-Bus und bestehende Technologie verwenden 5 Seminar ’Softwarearchitekturen’ Eckpunkte 2. CORBA - Überblick CORBA = Common Object Request Broker Architecture CORBA = Industriestandard, sehr stabil und offen CORBA = Spezifikationsprodukt der Object Managment Group (OMG) Festlegung der Object Managment Architecture (OMA) – Kommunikation von Objekten über Object Request Broker (ORB) – Definition der (Komponenten-) Schnittstellen, Interface Definition Language (IDL) – Definition von allgemeinen Diensten (CORBAservices) – Bestehende Technologien verwenden Objektorientiertes Modell für Client-Server-Architekturen verwenden Implementierung in mehrere Programmiersprachen möglich (Ada, Java, C++, C, Smalltalk, COBOL, Tcl, Perl) H.Abraham 6 Seminar ’Softwarearchitekturen’ Architektur 2.CORBA - Überblick Object Managment Architecture (OMA) anwendungsnahe Dienste zur Objektbearbeitung CORBAfacilities Application Objects Vertical Facilities Healthcare Finance spezifische AnwendungsDienste etc. Horizontal Facilities Distributed Documents Information Managment System Managment Task Managment allgemeine anwendungsübergreifende Dienste Properties Licensing Collections Query Externalization Persistence Relationships Time Security Concurrency Transactions Trader Life Cycle Naming Events Object Request Broker (ORB) allg. Dienste zur Objektbearbeitung CORBAservices H.Abraham 7 Seminar ’Softwarearchitekturen’ Architektur 2.CORBA - Überblick Kurz und kleingedruckt : die CORBAservices 1. Event-Service - Komponenten registrieren ihr Interesse an Ereignissen, die in einem Event-Channel gesammelt werden. 2. Naming-Service - ermöglicht es Objekten, andere Objekte über ihren Namen zu finden. 3. Life-Cycle-Service - Operationen zum kopieren, verschieben oder löschen von Objekten. 4. Trader-Service - stellt die "Gelben Seiten" für Objekte bereit. 5. Transaction-Service - stellt ein zweistufiges Bestätigungsprotokoll zur Verfügung, (flache / geschachtelte Transaktionen). 6. Concurrency-Control-Service - umfaßt einen Lock-Manager, der im Auftrag Sperrungen vornehmen kann. 7. Security-Service - Framework für Sicherheit ; (Vertraulichkeit, Integrität, Unwiderlegbarkeit und Abrechenbarkeit). 8. Time-Service - für Uhrzeitsynchronisation oder zum Auslösen von zeitgetriggerten Ereignissen in verteilten Anwendungen. 9. Relationship-Service - erlaubt es, dynamische Verknüpfungen zwischen Komponenten zu erstellen. 10. Persistence-Service - zum Speichern von Objekten in Datenbanken über einheitliche Schnittstelle. 11. Externalization-Service - eine Standardmethode, um mittels Streaming Daten zwischen Komponenten auszutauschen. 12. Query-Service - stellt Abfrageoperationen für Objekte bereit. 13. Collection-Service - ermöglicht es, Schnittstellen von Objekten in Collections zu sammeln und zu manipulieren. 14. Licensing-Service - bietet Möglichkeiten, die Nutzung der Komponenten abrechnen zu können. 15. Properties-Service - erlaubt es, Name-Wert-Paare mit beliebigen Komponenten zu assoziieren. H.Abraham 8 Seminar ’Softwarearchitekturen’ Architektur 2.CORBA - Überblick Komponenten von CORBA Object Implementation Client Dynamic Client IDL Interface Stubs Invocation ORB Interface ORB Interface Dynamic Static Skeleton Skeletons Invocation Object Adapter Interface Repository Object Request Broker Core ORB-Interface ist für alle ORBs identisch static IDL-Stubs und static IDL Skeletons existieren pro Objekt generell sind mehrere Object-Adapter möglich H.Abraham Implementation Repository 9 Seminar ’Softwarearchitekturen’ Architektur 2.Corba - Überblick Komponenten von CORBA - Operationsaufruf (mit Namensdienst) Object Implementation Client Dynamic Client IDL Interface Stubs ORB Interface ORB Interface Invocation Dynamic Static Skeleton Skeletons Invocation Object Adapter Request Interface Repository ... Naming .... ORB Implementation Repository find object, use name-service Key="IOR:01f3ffbf..." CORBAservice 316 Byte Möglichkeiten, die ein CORBA-ORB bietet statische und dynamische Methodenaufrufe Verknüpfungen auf Hochsprachenebene Ortstransparenz (ohne Programmieraufwand) Eingebaute Sicherheit (Dienste: Security, Transation, ...) Koexistenz mit existierenen Systemen (RPC, DCOM ...) H.Abraham 10 Seminar ’Softwarearchitekturen’ 3. Entwurf mit CORBA Motivation für Programmierer: Wie komme ich zum Code? Objekt-Spezifikation in IDL IDL-Compiler Client Stub Body Client Stub Klasse Server Skeleton Klasse erzeugen + Code implementieren erzeugen + Code implementieren Compiler / Linker Client Programm H.Abraham Server Skeleton Body Compiler / Linker Server Programm 11 Seminar ’Softwarearchitekturen’ Code-Beispiel (ORBit) 3.Entwurf mit CORBA Beispiel - eine Zufallszahl vom Server erfragen: interface Random { long lrand48(); }; File: random.idl Server Implementierung #include #include #include #include #include #include $ orbit-idl random.idl Client Implementierung #include #include #include #include automatisch generierte Files <stdio.h> <stdlib.h> <orb/orbit.h> "random.h" Client int main (int argc, char *argv[]) { CORBA_Enviroment ev; CORBA_ORB orb; CORBA_Object server; CORBA_long answer; Random random_client = CORBA_OBJECT_NIL; random-common.c random.h random-stubs.c <stdio.h> "stdlib.h" "string.h" "signal.h" "orb/orbit.h" "random.h" PortableServer_ServantBase__epv base_epv = { NULL, NULL, NULL }; POA_Random__epv random_epv = { NULL, Random_lrand48 }; POA_Random__vepv poa_random_vepv = { &base_epv, &random_epv }; POA_Random poa_random_servant = { NULL, &poa_random_vepv }; Server random-skels.c int main(int argc, char* argv[]) { CORBA_ORB orb; CORBA_Enviroment ev; PortableServer_ObjectId objid = {0, sizeof("myRandom"), "myRandom"}; PortableServer_POA poa; CORBA_char* objref; signal(SIGTERM, exit); CORBA_exception_init(&ev); orb=CORBA_ORB_init(&argc,argv,"orbit-local-orb".&ev); server=CORBA_ORB_string_to_object(orb, argv[1],&ev); if(!server) { printf("cannot bind\n"); return 1; } CORBA_exception_init(&ev); orb = CORBA_ORB_init(&argc, argv, "orbit-local-orb", &ev); POA_Random__init(&poa_random_servant, &ev); long rnd_num; rnd_num=Random_lrand48(server, &ev); printf("a random number: %d", rnd_num); poa = (PortableServer_POA)CORBA_ORB_resolve_initial_references(orb, "RootPOA", &ev); PortableServer_POAManager_activate(PortableServer_POA__get_the_POAManager(poa, &ev), &ev); PortableServer_POA_activate_object_with_id(poa, &objid, &poa_random_servant, &ev); CORBA_Object_release(server,&ev); CORBA_Object_release((CORBA_Object)orb, &ev); return 0; random_client = PortableServer_POA_servant_to_reference(poa, &poa_random_servant, &ev); if(!random_client) { printf("cannot get objref\n"); return 1; } objref = CORBA_ORB_object_to_string(orb, random_client, &ev); fprintf(stderr, "object-reference: %s\n", objref); CORBA_free(objref); }; File: random-client.c CORBA_ORB_run(orb, &ev); return 0; } CORBA_long Random_lrand48(Random _obj, CORBA_Enviroment * ev) { CORBA_long retval; retval = random(); return retval; } File: Bsp: ORBit-0.5.0 (C) H.Abraham Compiler / Linker Compiler / Linker Client Programm Server Programm File: random-client random-server.c File: random-server 12 Seminar ’Softwarearchitekturen’ 4. CORBA und Design Patterns Motivation: zuverlässige und “gute” Software-Entwicklung schnelle Entwicklungszyklen Wartbarkeit Technik um Softwareteile oder -komponenten wiederzuverwenden mittels Design Pattern: Darstellung erfolgreicher (OO)-Lösungen zu bestimmten wiederkehrenden Problemen Lösungen nicht als Code, sondern in sprachunabhängiger Form H.Abraham 13 Seminar ’Softwarearchitekturen’ 4.CORBA und Design Patterns Wie Patterns beschreiben? (nach Vortrag “Patterns”, Seite 11) ! Name und Klassifikation ! Zweck ! Motivation ! Anwendbarkeit ! Struktur ! Mitwirkende (Pattern) ! Folgen ! Implementation ! Beispiel-Code ! Anwendungsbeispiel ! Verwandte Patterns H.Abraham Was tut das Pattern? anhand eines Szenarios In welchen Situationen diese Pattern benutzen? Graphische Darstellung der Struktur des Pattern teilhabende Klassen und Objekte und ihre Aufgabe aus der Anwendung des Pattern Einige Tips, Sprachabhängigkeiten, Schwierigkeiten zur Illustration aus echtem System Unterschiede, Kombinationsmöglichkeiten 14 Seminar ’Softwarearchitekturen’ 4.CORBA und Design Patterns Skallierungsmodell Ansatz: [2] Design Patterns nach Most Applicable Scale ("hauptsächliche Anwendungsebene") in einem Skalierungsmodell ordnen Objects and Classes Verbund von Objekten Microarchitecture Wiederverwendung von Microarch. Framework Class Hierarchies einzelnes ausführbares Programm Application Programming - Object Wrapping Programme im Corba-Umfeld System Horizontal - Vertical - Metadata Organisatorische Einheit Enterprise Reference Models - Infrastructures - Policies Verbund von Enterprises Global Standards - Internet (blau = nicht weiter beschieben) H.Abraham 15 Seminar ’Softwarearchitekturen’ Skallierungsmodell-Detail 4.CORBA und Design Patterns Application Design Patterns Maximizing Parallism Improving Object Implementations Modifying Client Stubs and other Tricks System Design Patterns Prinziples of Object-Oriented Architecture Fundamental Structural Patterns Advanced System Design Patterns Using OMG CORBAServices Enterprise Design Patterns Building an Organizational Infrastructure Global Design Patterns Role of Open Systems Internet Design Patterns H.Abraham 16 Seminar ’Softwarearchitekturen’ 4.CORBA und Design Patterns Skallierungsmodell (2) Anmerkung: genannte Design Patterns orientiert an CORBA sind sehr allgemein gehalten allgemeines Ziel: gekapseltes Design besseres Objekt-Managment Kommunikation und Kooperation mit bestehenden Standards Performance-Gewinn senken des Netzwerk-Traffic H.Abraham 17 Seminar ’Softwarearchitekturen’ 4.CORBA und Design Patterns Pattern an folgende Beispiele (einfacht): ! ORBlet ! ORB Global Design Pattern ! Operating Enviroment ! Naming Service ! Distributed Callback Application Design Pattern Datenbank 1 Intranet Internet Datenbank 2 Bezug zum einleitenden Beispiel wird gesucht ' &%(' %"#&# %(# &# "# " "$# "$# $# " $# " $"$" ISP ApplicationsServer GSM H.Abraham 18 Seminar ’Softwarearchitekturen’ Beispiele 4.CORBA und Design Patterns Global Design Pattern - ORBlet Zweck: Zugriff auf CORBA-basierende Anwendungen und CORBAservices über WebBrowser Realisierung: benutze Java-Applet (enthält CORBA client stubs) ORB-Kommunikation über Internet Interoperability Protokoll (IIOP) asynchrone Aufrufe verwenden Struktur: ORB Java-Applet Browser Verteilte Anwendung (DBMS, Lotus, TP-Monitor) z.B.: Client-PC am ISP H.Abraham 19 Seminar ’Softwarearchitekturen’ Beispiele 4.CORBA und Design Patterns Global Design Pattern - ORBlet (2) Beispiel: Datenbank 1 Internet Intranet ORBit JacORB Anwendung CORBA-IIOP Java-Applet Corba-Server Browser hole HTML-Seite HTTP-Server ISP hole Applet hole HTML-Seite (benutze Pattern Standards, z.B. HTML3.2) hole Applet (Applet ist ein Pattern, das auf dem Pattern Java aufbaut) starte Applet (im WebBrowser) CORBA-IIOP H.Abraham 20 Seminar ’Softwarearchitekturen’ Beispiele 4.CORBA und Design Patterns Enterprise Design Pattern - ORB Zweck: (transparentes) verteiltes Arbeiten (mit Objekten) in heterogener Umgebung. unabhängig von Betriebssystem, Implementierungssprache und Lokalität Realisierung: ORB als vermittelnder Agent zwischen Client und Server ) OMA Application Objects CORBAfacilitiesObjects Application Interface CORBAfacility Interface CORBA-Object Request Broker CORBAservice Interface CORBAservicesObjects H.Abraham 21 Seminar ’Softwarearchitekturen’ Beispiele 4.CORBA und Design Patterns Enterprise Design Pattern - ORB (2) Folgen: separate Kompilation notwendig reduzieren der Komplexität der Anwendung separieren der Anwendung von der Infrastruktur etwas Overhead Ausblick: über Half-Bridge die ORBs transparent verbinden damit Lösung: administrativer Bedürfnisse, Diensttypen, Sicherheitsaspekte... Server Client Half Bridge Half Bridge DSI DII ORB A ORB B oder DCOM Domain A H.Abraham Domain B 22 Seminar ’Softwarearchitekturen’ Beispiele 4.CORBA und Design Patterns Enterprise Design Pattern - Operating Enviroment Zweck: Interoperabilität zwischen existierenden Produkten Realisierung: benutze Konvertierungs-Service und zentrale Datenbank UNIX Windows Conversion Service MS-Word 97 FrameMaker Communication Infrastructure Rich Text Format (RTF) Linux ApplixWare (Word) H.Abraham Windows WordPerfect Mac Document Database MS-Word 5.0 23 Seminar ’Softwarearchitekturen’ Beispiele 4.CORBA und Design Patterns Enterprise Design Pattern - Operating Enviroment (2) Folgen: Unabhängigkeit von Hersteller und Produkt genereller Informations-Import realisierbar Änderungen in Daten verifizierbar jede Einheit mit mehr Autonomie Unterstützung von speziellen Tools ( ) höhere Produktivität) Beispiel : einleitender Informationsdienst: “Kunde” kann angeben, welches Datenformat er wünscht, oder kann Konvertierungs-Service nutzen Kommunikation über ORB H.Abraham 24 Seminar ’Softwarearchitekturen’ Beispiele 4.CORBA und Design Patterns System Design Pattern - Naming Service Zweck: Objekt anhand eines Namens im Namensraum finden bestimmen Realisierung: nutze repository zum speichern von Namen und Objekt-Referenz Namensbindung relativ zwei Grundoperatoren: store(bind) und retrieve(resolve) Ort Mexico Japan Hawaii Ort.Mexico.Verkauf.Saft zusammengesetzter Name (compound name) Verkauf Objekt-Name Obst H.Abraham Saft Wein Kontextname 25 Seminar ’Softwarearchitekturen’ Beispiele 4.CORBA und Design Patterns System Design Pattern - Naming Service (2) Beispiel: implementierter ORB kennt einige “initial services” Beispiel - Code-Fragment (ORBit-C) int main (int argc, char *argv[]) { CORBA_Environment ev; CORBA_ORB orb; ... CosNaming_NamingContext name_srv; /* name server */ CosNaming_Name* serv_name; /* This holds the name of our server */ CosNaming_Name* serv2_name; /* This holds the name of our server2 */ factory fac, fac2; /* the server-side factory object */ ... orb = CORBA_ORB_init(&argc, argv, "orbit-local-orb", &ev); ... /* get the name server from the ORB */ name_srv = CORBA_ORB_resolve_initial_references(orb, "NameService", &ev); ... /* store(bind) the name of the object implementation */ CosNaming_NamingContext_bind(name_srv,serv_name, fac, &ev); ... /* retrieve(resolve) the reference of the object implementation */ serv2_name=create_name(“Ort.Mexico.Verkauf.Saft”); fac2 = CosNamingContext_resolve(name_srv, serv2_name, &ev); ... } H.Abraham 26 Seminar ’Softwarearchitekturen’ Beispiele 4.CORBA und Design Patterns Application Design Patterns - Distributed Callback Zweck: Client soll, während er auf einen Request wartet nicht blockieren Realisierung: synchrone Operatoren in (asynchrone) oneway-Operatoren umwandeln Client mit Callback-Interface ausstatten Struktur: 1) Client kehrt sofort zurück und arbeitet weiter 4) Client erhält das Ergebnis bei Abfrage der Event-Loop H.Abraham Operation Callback 2) Server bearbeitet den Request 3) Server ruft den Client und liefert das Ergebnis 27 Seminar ’Softwarearchitekturen’ Beispiele 4.CORBA und Design Patterns Application Design Patterns - Distributed Callback (2) Folgen: Client-Callbacks in verschieder Reihenfolgen nur primitive Fehlerbehandlung (keine Exceptions) Zustellung (oneway) nicht garantiert Implementierung: Ausgangsoperation (IDL): interface app { string get_info( in string my_data); }; konvertieren zu: interface app_callback; /* forward */ interface app { /* this interface defines the server object */ oneway void get_info( in string my_data, in app_callback my_callback); }; interface app_callback { /* this interface must be implemented by the client */ oneway void callback( in string return_value, in long status); }; H.Abraham 28 Seminar ’Softwarearchitekturen’ Beispiele 4.CORBA und Design Patterns Application Design Patterns - Distributed Callback (3) Beispiel: Konvertierungs-Service vom Informationsdienst get_pdf() Object1 1) Client 4) callback() 2) get_txt() H.Abraham 700ms 3) Object2 200ms 29 Seminar ’Softwarearchitekturen’ Beispiele 4.CORBA und Design Patterns 5. Zusammenfassung Zu CORBA: für viele Betriebssysteme / Hochsprachen (frei) verfügbar IDL-Schnittstelle nur mit Syntax Design Pattern und CORBA: Design Pattern nach Anwendungsebene skalliert Buch: leider bei gewisse Pattern zu abstrakten Formulierungen bzw. mageren Beispiele - damit kein erwünschter Praxisbezug Ziel von viele Pattern: Performance / Netzwerk-Traffic verbessern Gut: System-unabhängige Dienste vorhanden: (Naming, Event, Transaction, Lock...) – werden aber nur gering beachtet Fraglich: Sicherheitskonzept auf Ebene des verwendeten ORB (Speicherraum) H.Abraham 30 Seminar ’Softwarearchitekturen’ Beispiele 4.CORBA und Design Patterns Quellen [1] R. Orfali, D. Harkey, J. Edwards, Instant CORBA, Addison-Wesley, 1998, ISBN 3-8273-1325-2 [2] T. J. Mowbray und R. C. Malveau, CORBA Design Patterns, Wiley Computer Publishing, 1997, ISBN 0-471-15882-8 [3] John Siegel, CORBA - Fundamentals and Programming, Wiley Computer Publishing, 1996, ISBN 0-471-12148-7 [4] Folien “Patterns”, Seminar “Softwarearchitektur”, Nov. 2000, www.informatik.uni-freiburg.de Ein Überblick über einige ORBs gibt http://www.vex.net/˜ben/corba/index.html Abkürzungen CORBA = Common Object Request Broker Architecture DII = Dynamic Invocation Interface DSI = Dynamic Skeleton Invocation OMA = Object Managment Architecture OMG = Object Managment Group ORB = Object Request Broker RPC = Remote Procedure Call IDL = Interface Definition Language H.Abraham 31