• Keine Ergebnisse gefunden

Middleware für die Entwicklung verteilter, insbesondere Web-basierter Anwendungssystemen dar“

N/A
N/A
Protected

Academic year: 2022

Aktie "Middleware für die Entwicklung verteilter, insbesondere Web-basierter Anwendungssystemen dar“"

Copied!
46
0
0

Wird geladen.... (Jetzt Volltext ansehen)

Volltext

(1)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de

Netzprogrammierung

Organisation und Einleitung

Prof. Dr.-Ing. Robert Tolksdorf Freie Universität Berlin

Institut für Informatik

Netzbasierte Informationssysteme mailto: tolk@inf.fu-berlin.de

http://www.robert-tolksdorf.de

(2)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de

Organisatorisches

(3)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de 3

Veranstaltungsinhalt

• „Die Vorlesung stellt Prinzipien, Sprachen und

Middleware für die Entwicklung verteilter, insbesondere Web-basierter Anwendungssystemen dar“

Ausrichtung praktisch auf Netzprogrammierung, weniger auf

• Netztechnik

• Konzepte Verteilter Systeme

• Eigenschaften Verteilter Algorithmen

• Anwendung verteilter Systeme

(4)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de 4

Unterlagen

• Folien im Netz unter

http://www.ag-nbi.de/lehre/0708/V_NP

• In den Foliensätzen Verweise auf Quellen

(5)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de 5

Bücher

• Titel mit vorlesungsbezogenen Inhalten:

• Heinzl, Steffen, Mathes, Markus. Middleware in Java. ISBN:

3-528-05912-5. Vieweg Verlag 2005.

• Heiko Wöhr. Web-Technologien. ISBN 3-89864-247-X dpunkt.verlag 2004

• Bengel, Günther. Grundkurs Verteilte Systeme. ISBN 3- 528-25738-5. Vieweg 2004.

• Andrew S. Tanenbaum, Maarten van Stehen. Verteilte Systeme. ISBN 3-8273-7057-4 Pearson 2004

• Mathias Lother, Cornelius Wille, Fritz Zbrog, Reiner

Dumke. Web Engineering, ISBN 3-8273-7080-9. Pearson 2004

• Frank Buschmann, Kevlin Henney, Douglas C. Schmidt.

Pattern-Oriented Software Architecture: A Pattern

Language for Distributed Computing. ISBN 0470059028.

Wiley & Sons. 2007.

• Verbindlich ist Inhalt der Vorlesungsfolien

(6)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de 6

Übungsbetrieb

• Zwei Übungen bei

• Sven Ketelsen (ketelsen@inf.fu-berlin.de) und

• Jana Rekittke (rekittke@inf.fu-berlin.de):

• Mi 16-18h

• Mi 18-20h

• Zusatztermin

• Dort:

• Weitere Fragen

• Hinweise untereinander zu Übungaufgaben

• Übungsblätter

• Enthalten praktische Aufgaben, die bewertet werden

• Enthalten Fragen zur weiteren Diskussion und zur eigenen Beantwortung

(7)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de 7

Leistungsnachweis

• Leistungsnachweis

• Note des Leistungsnachweises ist die individuelle Klausurnote

• Voraussetzung für Klausur:

Regelmäßige und aktive Teilnahme an Veranstaltung

• Aktive Teilnahme:

Regelmäßige Teilnahme

Abgabe aller Übungsblätter in Gruppen

Bestehen von n-1 Übungsblättern

(8)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de 8

Formalitäten

Für BSc Studierende ist eine verbindliche Anmeldung zur Veranstaltung notwendig

Ohne diese Anmeldung dürfen keine Leistungen erbracht werden

• Verbindliche Anmeldung mit Unterschrift in der nächsten

Woche

(9)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de 9

Kommunikationswege

• Mailingliste

• nbi_v_np@lists.spline.inf.fu-berlin.de

• Eintragung über

http://lists.spline.inf.fu-berlin.de/mailman/listinfo/nbi_v_np

Verbindliche Ankündigungen zur Veranstaltung

• Allgemeine Nachfragen der Teilnehmer

• Gegenseitige Kommunikation unter Teilnehmern

• Mit Robert Tolksdorf

• tolk@inf.fu-berlin.de

• http://www.robert-tolksdorf.de/sprechstunde

Bevorzugt: Elektronische Nachfrage

(10)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de

Netzprogrammierung

(11)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de 11

Verteiltes System

• Def.: Ein verteiltes System ist ein Rechnersystem in dem Komponenten durch Kommunikation über ein Netzwerk zusammenarbeiten

• Beispiele:

• Data Warehouses in Unternehmen

• Web

• Telefonnetz

• …

(12)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de 12

Nichtverteilte Systeme

• Isoliertes System

• Zentralisiertes System

• „Dumme“ Terminals nutzen

einen Server mit Datenbank etc.

• Programme auf Server nebenläufig

• Terminals sind nur Anzeigegeräte

• „Netzwerk“ ist

lediglich Draht zur Zeichenübermittlung (seriell, Telefon)

• „Null Client“, Host-basiertes Computing

(13)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de 13

Verteiltes System

• Server bietet Clients Dienste an

• Client-Komponenten sind unterschiedlich „schlau“ / „dick“

• Peer-to-Peer

• Komponenten sind gleichberechtigt

(14)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de 14

Eigenschaften Verteilter Systeme

• Systeme sind immer aus verschiedenen, oft

unabgängigen Komponenten zusammengesetzt

• vgl.: PC – Komponenten nicht unabhängig

• Komponenten müssen integriert sein, so dass sie möglichst homogen erscheinen

• Bedingt zusätzliche Komplexität

• Räumliche Verteilung dieser Komponenten

• Bedingt Vernetzung und Kommunikation

• Komponenten sind einzeln von Fehlern betroffen

• Bedingt Fehlersichtbarkeit für andere Komponenten

• Komponentenheterogeneität teilweise transparent

• Vereinfacht Systemgestaltung

• Komponenten als autonome Partner in Interaktionen

• Bedingt Nebenläufigkeit

(15)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de 15

Vorteile Verteilter Systeme

• Bessere Leistung

Besseres Kosten-/Leistungsverhältnis durch

Kostengünstige einfache Komponenten (PCs)

Günstige Vernetzungs- und Kommunikationskosten

Günstigere Erweiterung mit Spezialmaschinen

Bessere Antwortzeiten durch Lastverteilung

• Bessere Organisation

Entsprechend notwendiger örtlicher Verteilung, z.B. Telefonnetz

Entsprechend der Systemgestaltung und den Anforderungen verteilter Organisationen

Gemeinsame Nutzung von Ressourcen (Leistung und Daten)

Kommunikation in System erlaubt Kommunikation zwischen Nutzern (Mail, CSCW)

Entsprechend der Systemgestaltung und den Anforderungen virtueller Organisationen

(16)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de 16

Vorteile Verteilter Systeme

• Bessere Zuverlässigkeit

• Bessere Skalierbarkeit

Doppelte Anforderung -> doppelte Maschinenanzahl (theoretisch!)

Bessere Zuverlässigkeit durch verteilten Fehlerauftritt und mehrfach vorhandene Ressourcen und Kopien von Daten

• Deshalb auch Gesamtausfall unwahrscheinlich

• Inkrementeller Ausbau möglich, da flexibler Entwurf

• Deshalb auch einfachere Wartung -> Teilausfälle beheben

• ...

(17)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de 17

Probleme verteilter Systeme

• Inhärent höhere Komplexität

• Komponenten an unterschiedlichen Orten

• Komponenten in unterschiedlichen Adressräumen

• Komponenten schwerer zu koordinieren, da Netzwerkkommunikation asynchron und nicht- deterministisch

• Zusätzliche Komplexitäten

• Softwaretechnik weniger ausgereift

Portabilität von APIs?

Verteilte Debugger?

Zu niedrige Abstraktion populärer Sprachen

C!

Skaliert nicht zu mehreren Maschinene

(18)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de 18

Probleme verteilter Systeme

• Höhere Abhängigkeiten

• Leistung ist abhängig von Netzwerkverfügbarkeit und dessen Qualität (Latenz, Bandbreite etc.)

• Erheblich mehr logische und physische Angriffspunkte

• Methodische Problematik

• Analyse und Design ist auf sequentielle nicht verteilte Software zugeschnitten

• Zusätzlicher Aufwand beim Testen durch nichtdeterministisches Netzverhalten

• Qualitätsanforderungen nicht genug beachtet

-> Video

• Wiederholte Neudefinition von Plattformen

CORBA

RMI

Web-Services

(19)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de 19

Fragen bei Verteilten Systemen

• Probleme/Herausforderungen/Fragen:

• Interaktionsmodell

Wer initiiert eine Interaktion?

Wie findet ein Klient einen Server?

• Skalierbarkeit

Wie realisiert man Systeme mit sehr hohen Zugriffszahlen?

Wie realisiert man sehr große Systeme mit sehr vielen Komponenten?

• Entwicklung

Wie schreibt man einfach und korrekt Anwendungen dafür?

Standardisierung

• Sicherheit

• ...

(20)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de 20

Middleware

• „Die Vorlesung stellt Prinzipien, Sprachen und

Middleware für die Entwicklung verteilter, insbesondere Web-basierter Anwendungssystemen dar“

• Middleware stellt Technologien, Abstraktionen,

Schnittstellen bereit mit der netzbasierte Systeme

realisiert werden können

(21)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de 21

Technologien für verteilte Systeme:

Direktvernetzung

• Kommunikation über gemeinsamen Speicher

• -> Virtual Shared Memory / Distributed Shared Memory

Socketkommunikation

Netzwerk Netzwerk Prozess 1

„gemeinsamer“ Speicher

Prozess 2

Prozess 1 Prozess 2

0A98

103D

(22)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de 22

Technologien für verteilte Systeme:

Direktvernetzung

• Ad-Hoc Kommunikation generiert wenig Overhead weil sie sehr maschinennah ist

• Kommunikation wie benötigt

• Schnell

• Ad-Hoc Kommunikation generiert Abhängigkeiten weil sie sehr maschinennah ist

• Programmierung an APIs gebunden

• Portabilitätsprobleme zwischen APIs / Betriebssystemen

• Paradigmenbruch zur sonstigen Programmierung

Objekte vs. Sockets!

(23)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de 23

Technologien für verteilte Systeme:

Strukturierte Kommunikation

• Hochsprachen strukturieren Programmablauf

• Insbesondere durch Abstraktionsmechanismen

• Implementiert durch Prozeduraufrufe

Remote Procedure Call RPC strukturiert Kommunikation

• Ablauf des Aufrufs

• Übermittlung von Parametern und Ergebnissen (Typen!)

• Abstrahiert von Repräsentation und Netzwerknutzung

Netzwerk Netzwerk Prozess 1

x=f(10); Prozess 2

int f(int i);

1.

f(10)

2.20 0A98

103D

(24)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de 24

Technologien für verteilte Systeme:

Strukturierte Kommunikation

• Ein RPC muss an eine Maschine adressiert sein

• Rechner1239:f(10);

• Einem RPC System ist also seine Verteiltheit bewusst

• Sie muss auch gehandhabt werden

• Sie ist also verteilungsnah

• Wünschenswert

• Ortsunabhängigkeit, einheitliches Programmiermodell

-> Aber: Fehlermöglichkeit immer gegeben

• Neuverteilung von Komponenten

-> Nutzung erweiterter Hardware

• Integration von Altanwendungen

-> z.B. in anderen Sprachen

• Integration heterogener Komponenten

Enterprise Application Integration!

(25)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de 25

Technologien für verteilte Systeme:

Middleware

Anwendung 1 Anwendung 2

Middleware Middleware

Betriebssystem A Betriebssystem B

Netzwerk Netzwerk

Gewinn: Anwendungen kommunizieren

(26)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de 26

Middleware: Kleber zur Verbindung von Anwendungen

• Für Anwendung erscheint verteiltes System homogener als es tatsächlich ist

• Beispiel:

Objekte können genutzt werden unabhängig von ihrem Ort

Notwendig:

Ortsunterschiede maskieren, transparent machen

Ortstransparenz durch Middleware-Dienste, die

Methodenaufruf zum richtigen Ort transportieren ohne

dass der Nutzer das tun muss

(27)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de 27

Verteilungstransparenzen nach ODP

„Transparency: The property of masking from applications the details and the differences in mechanisms used to overcome problems caused by distribution.“ [ISO Referenzmodell Open Distributed Processing, Part1]

Aspekte die ganz oder teilweise transparent sein können:

Heterogeneität der beteiligten Software

Heterogeneität der beteiligten Hardware

Ort und Bewegung der beteiligten Komponenten

Mechanismen zur Fehlerbehandlung relativ zu Qualitätserfordernissen

„Distribution transparencies are used to hide aspects of ODP systems that arise through their distribution. Within an ODP system, the ODP infrastructure supports a set of distribution transparencies. The applications determine those

transparencies that they need and that must be provided by the infrastructure. Other aspects of distribution are handled by the applications themselves.“ [ODP Part1]

(28)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de 28

Transparenzen nach ODP Verteilung verbergen

• Zugriffstransparenz (access transparency)

• Auf alle Ressourcen und Dienste wird gleich zugegriffen

Maskiert unterschiedliche Datenrepräsentationen

Maskiert unterschiedliche Aufrufmechanismen

Maskiert unterschiedliche genutzte Programmiersprachen

• Wichtigste und notwendige Transparenz

• Ortstransparenz (location transparency)

• Ort von Ressourcen und Diensten ist nicht bekannt

Maskiert die Nutzung von Ortsinformationen beim Auffinden anderer Objekte

• Ermöglicht rein logische Sicht auf Namen im System

• Keine Ortsinformationen zur Nutzung von Namen nötig

(29)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de 29

Weitere Transparenzen Verteilung verbergen

• Nebenläufigkeitstransparenz

• Auf Ressourcen kann nebenläufig zugegriffen werden

Maskiert die Nutzung von Synchronisationsmechanismen bei der Implementierung der Zugriffe

• Skalierungstransparenz

• Das System ist erweiterbar

Maskiert Rekonfigurationen der Hard- und Softwarebasis

• System ist für Benutzer also

• homogen statt heterogen

• lokal statt verteilt

• exklusiv genutzt statt gemeinsam genutzt

• immer gleich statt rekonfiguriert

(30)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de 30

Transparenzen nach ODP Verteilung verbergen

Persistenztransparenz (persistence transparency)

• Objekte erscheinen immer zugänglich

Maskiert die Aktivierung und Deaktivierung von Objekten zu Klienten und zum Objekt selber

• Durch Persistenz überlebt ein Objekt Zeiten in denen ein System nicht ausführt, speichert, kommuniziert etc.

• Objekte erscheinen immer verfügbar

Transaktionstransparenz (transaction transparency)

• Transaktionen funktionieren immer ganz oder gar nicht

Maskiert Koordination von Aktivitäten auf Objekten durch die Konsistenz erhalten bleibt

• Beinhaltet Planung, Überwachung, Wiederrufen von Aktivitäten

• Transparenz erfordert die Verfeinerung der Spezifikation von Objekten um transaktionale Eigenschaften

(31)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de 31

Transparenzen nach ODP Verteilung nutzen

• Migrationstransparenz (migration transparency)

• Prozesse und Ressourcen verschiebbar

Maskiert Ortsänderungen von Objekten

• Macht beispielsweise Lastausgleich transparent

• Mit Fehler- und Persistenztransparenz kombinierbar

• Relokationstransparenz (relocation transparency)

• Maskiert Änderungen des Ortes gebundener Schnittstellen

• Objekte können während der Interaktion mit Klienten verschoben oder ersetzt werden

• Sichert Weiterarbeit auch trotz temporär inkonsistenter Sichten

(32)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de 32

Transparenzen nach ODP Verteilung nutzen

• Replikationstransparenz (replication transparency)

• Mehrfach vorhandene Objekte werden so zugegriffen als existieren nur ein Exemplar

Maskiert den Einsatz einer Gruppe von Objekten an einer Schnittstelle

• Erhöht Performanz und Verfügbarkeit

• Fehlertransparenz (failure transparency)

• System erscheint trotz Fehlern intakt

Maskiert Fehler und Wiederherstellung anderer Objekte

• Beispielmechanismen: Checkpointing, Transaktionen

• Falls vorhanden, ideale, fehlerfreie Welt für Programmierer

• System ist für Benutzer also auch

• unterbrechungsfrei statt fehlerbehaftet

• leistungsoptimiert statt nur zusammengeschaltet

(33)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de 33

Systemdienste

• Transparenzen werden vom System erzeugt

• Dazu sind Dienste unterschiedlichster Art notwendig

• Middleware umfasst:

• Rahmenwerk für Dienste

• Basisdienste

• APIs

• Implementierungen

• …

(34)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de 34

Beispiel: Java RMI

(35)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de 35

Beispiel: OMG CORBA/OMA

• Grundlegendes Prinzip:

[http://www.omg.org/gettingstarted/corbafaq.htm]

• Ergänzt mit Diensten:

[http://www.omg.org/gettingstarted/specintro.htm]

(36)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de 36

Beispiel: W3C Web Services

[Diagramme: Schild]

Web-Dienst

Inhalt: SOAP Schnittstellenbeschreibung mit WSDL

Funktionalität Transport:

HTTP(S), SMTP, FTP

Server Client

Nachfrager Anbieter

öffentliches Verzeichnis

WSDL-

Beschreibung WSDL-

Beschreibung

SOAP-Nachrichten

*Universal Description, Discovery and Integration

UDDI*

(37)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de 37

Middleware

• Klassen von Middleware

• Remote Procedure Call:

Synchroner, entfernter Prozeduraufruf

• Distributed Object Middleware:

Synchroner, entfernter Methodenaufruf an Objekten

• Distributed Tuples:

Tuplespace als asynchrones Blackboard-artiges Koordinationsmedium

• Message-Oriented Middleware:

Mailbox-Metapher für asynchrone Entkoppelung

[David E. Bakken. Middleware. Encyclopedia of Distributed Computing, Kluwer 2001]

(38)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de 38

Web-basierte Anwendungssystemen

• „Die Vorlesung stellt Prinzipien, Sprachen und

Middleware für die Entwicklung verteilter, insbesondere

Web-basierter Anwendungssystemen dar“

(39)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de 39

Web als Verteiltes System

• Eine Web-basierte Anwendung ist verteiltes System

• Jede Komponente kann auf anderem Rechner sein:

Web Server with product

information

Intermediate proxy

Web crawler as client

Web browser as client

X

Web Server offering a search engine

Indexed Web pages

(40)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de 40

Middleware für

Web-basierte Anwendungen

• HTTP, HTML etc als Middleware

• Allerdings nicht hinreichend integriert

Client Server

CGI program (phone.cgi) Database

Results encoded in HTML and sent by HTTP (<html><body><i>2345-78</i>…) Inputs encoded in URL and sent by HTTP (like http://www.x.y/phone.cgi?name=Mike)

Inputs encoded in environment ($QUERY_STRING=‘name=Mike‘)

Inputs translated to query (SELECT…) Query results (<Mike,2345-78>)

Results translated to HTML in stdout (<html><body><i>2345-78</i>…)

(41)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de 41

Web-Technologien und Verteiltheit

• Weite Bereiche der Web-Technologien beschäftigen sich mit Verteiltheit

Web browser

X

Proxy Cache

Document database

X

X

Web Server

Firewall

(42)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de 42

Schichtensicht (n-Tier)

DBMS-Server DBMS-Server

Anwendungsserver

Server

Webserver

Anwendungsserver

Klient Klient

Klient

Vier Schichten Drei Schichten

Zwei Schichten

(43)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de 43

Literatur

Richard M. Adler. Distributed Coordination Models for

Client/Server Computing. IEEE Computer (Vol. 28, No. 4) April 1995. pp. 14-22.

David E. Bakken. Middleware. Encyclopedia of Distributed Computing, Kluwer 2001.

http://www.eecs.wsu.edu/~bakken/middleware.pdf

ISO/IEC JTC1/SC21/WG7 ITU-T X.901 | ISO/IEC 10746-x.

Basic Reference Model of Open Distributed Processing.

Ted G. Lewis. Where Is Client/Server Software Headed? IEEE Computer (Vol. 28, No. 4) April 1995. pp. 49-55.

Milan Milenkovic, Scott H. Robinson, Rob C. Knauerhase,

David Barkai, Sharad Garg, Vijay Tewari, Todd A. Anderson, Mic Bowman. Toward Internet Distributed Computing. IEEE Computer (Vol. 36, No. 5) May 2003. pp. 38-46

Johann Schlichter. Skript zur Vorlesung Distributed

Applications. Institut für Informatik. TU München, März 2002 http://www11.informatik.tu-muenchen.de/lehre/lectures/

ss2002/va/extension/latex/va_course_student.pdf

(44)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de

Vorlesungsüberblick

(45)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de 45

Vorlesungsblöcke

• Organisation und Einführung

• Direkte Vernetzung

• Sockets, Basis der Kommunikation im Internet

• Internet Dienste

• Internet Dienste in Java

• Web Programmierung

• HTTP-Kommunikation in Java (Zustand, Sicherheit etc.)

• Serverseitige Ausführung: CGI, Servlets, SSI, JSP

• HTML und Verarbeitung

• XML, XML-Verarbeitung

• Clientenseitige Ausführung: Javascript, Applets

(46)

AG Netzbasierte Informationssysteme http://www.ag-nbi.de 46

Vorlesungsblöcke

• Fernaufrufe

• Remote Procedure Call, Konzepte und Grundelemente

• RMI in Java, entfernter Objektaufruf

• CORBA, sprachunabhängige Nutzung verteilter Objekte

• Weitere Modelle

• Koordinationssprachen, entkoppelter Kommunikation und Koordination

• Peer-to-Peer, Aufhebung der Client/Server Rollen

• Agenten, autonome netzbasierte Entitäten

• Klausur (Nachklausur…)

Referenzen

ÄHNLICHE DOKUMENTE

§ enthält alle nachfolgenden Geschwister des Kontextknotens; falls der Kontextknoten ein Attribut- oder Namensraumknoten ist, ist diese Achse leer.

 Benennen Sie anhand der vorgestellten Anwendungen des Semantic Web, wo Mehrwert durch diese Technologien entsteht, den man nicht mehr. herkömmlichen Informationssystemen

Beachten Sie hierbei, dass Sie nicht auf das automatische Hot-Deployment (JWS) von Axis zurückgreifen, sondern den Web Service als kompilierte Klasse über den zu erstellenden

Als Ergebnis sollen sie dann drei Lucene Indexes erhalten, in dem man durch Eingabe eines Suchtextes Ihre HTML Daten, XML Daten und (f nf) Bilder finden kann.. Aufgabe 23:

In der Nutch Web Anwendung soll es dann möglich sein, eine (gerankte) Liste von Seiten zu bekommen, die Outlinks zu einer genannten Seite haben (die URL der Seite kann benutzt

Implementieren sie ein grafisches User Interface, das die NASA World Wind 3D Engine API (http://worldwind.arc.nasa.gov/index.html) nutzt, um die vom ACM Literatur Portal extrahierten

• Daten werden an sehr vielen Stellen entlang der Cache- Hierarchie in Kopien gehalten.. AG Netzbasierte Informationssysteme

void open(in DOMString method, in DOMString url, in boolean async, in DOMString user, in DOMString password);. void setRequestHeader(in DOMString header, in