Verlagerung von JavaAnwendungen in die Datenbank Markus Fiegler ORDIX AG [email protected] Copyright by ORDIX AG Verlagerung von Java-Anwendungen in die Datenbank Agenda Agenda: • • • • • • • • • Einführung und Motivation Java Stored Procedures Besonderheiten der OracleJVM Laden der Java-Klassen in die DB Resolving-Konzept Veröffentlichung von Java-Klassen in der Datenbank Anwendungsmöglichkeiten von Java Stored Procedures Java Native Interface Resümee Copyright by ORDIX AG Verlagerung von Java-Anwendungen in die Datenbank Einführung und Motivation Warum Java in der Datenbank? • Java ist eine Programmiersprache für Client, Server, Komponenten (JavaBeans) und Stored Procedures. • Vorteile wie z. B. Bytecode-Verifikation, Vererbung, Abstraktion, Automatische Garbage Collection... können genutzt werden. • Java ist sicher und robust, z. B. keine Zeiger, kein direkter Zugriff auf Adressen im Speicherbereich. • Erweiterung der Datenbank-Funktionalität um JavaFunktionsbibliotheken • Datenbankunabhängigkeit (JDBC-Treiber) • Minimierung der Netzlast • Verbesserung der Performance Copyright by ORDIX AG Verlagerung von Java-Anwendungen in die Datenbank Java Stored Procedures • Datenbankunabhängigkeit mit Java Stored Procedures Oracle DB2 Sybase ... Java Stored Procedures Java Stored Procedures Java Stored Procedures Java Stored Procedures Java Stored Procedures Copyright by ORDIX AG Verlagerung von Java-Anwendungen in die Datenbank OracleJVM • OracleJVM ist eine in den Kernel von Oracle implementierte Java Virtual Machine (JVM). • Ab Oracle 10g stehen J2SE 1.4 und JDBC 3.0 in der Datenbank zur Verfügung. • Die Java-Systemklassen befinden sich in einem $ORACLE_HOME/javavm/admin Verzeichnis auf dem Datenbankrechner. • Native Compiler Copyright by ORDIX AG Verlagerung von Java-Anwendungen in die Datenbank Besonderheiten der OracleJVM Bei der Entwicklung von Java-Anwendungen für die OracleJVM muss man auf folgende Besonderheiten achten: • Jede statische Methode kann als Programmeinstiegspunkt verwendet werden. • Es gibt keine Unterstützung für GUI-Komponenten wie AWT und Swing. • Multithreading wird nicht unterstützt. • Es muss der serverseitige JDBC-Treiber verwendet werden. Copyright by ORDIX AG Verlagerung von Java-Anwendungen in die Datenbank Serverseitige JDBC-Treiber Bei der Verwendung des datenbankinternen JDBC-Treibers müssen folgende Punkte berücksichtigt werden: • Der serverseitige JDBC-Treiber muss im Programm nicht registriert werden, da dieser bereits im Oracle Server integriert ist. • Die DB-Verbindung kann nicht physisch geschlossen werden. • Die Verwendung von Auto-Commits wird nicht unterstützt. • Eine Verbindung zu einer entfernten Datenbank ist mit dem serverseitigen JDBC-Treiber nicht möglich. • Die JDBC-Datenbankverbindung wird mit der Zeichenkette "jdbc:default:connection:" ermittelt, z. B. DriverManager.getConnection("jdbc:default:connection:"). Copyright by ORDIX AG Verlagerung von Java-Anwendungen in die Datenbank Beispiel einer JavaDatenbankanwendung import java.sql.*; import oracle.sql.*; import oracle.jdbc.driver.*; public class Mitarbeiter extends Object { public static void setGehalt(int ma_nr, int gehalt) { try { DriverManager.registerDriver(new oracle.jdbc.driver.OracleDriver()); Connection conn = DriverManager.getConnection( "jdbc:oracle:thin:@localhost:1521:orcl10","mf","mf"); String sqlUpdate = "UPDATE ma SET gehalt = ? WHERE ma_nr = ?"; PreparedStatement pstmt = conn.prepareStatement(sqlUpdate); pstmt.setInt(1, gehalt); pstmt.setInt(2, ma_nr); pstmt.executeUpdate(); conn.close(); pstmt.close(); } catch(Exception e) { e.printStackTrace(); } } public static void main(String[] args) { setGehalt(1, 900); } } Copyright by ORDIX AG Verlagerung von Java-Anwendungen in die Datenbank Für die Ausführung in DB angepasste Java-Datenbankanwendung import java.sql.*; import oracle.sql.*; import oracle.jdbc.driver.*; public class Mitarbeiter extends Object { public static void setGehalt(int ma_nr, int gehalt) { try { //DriverManager.registerDriver(new oracle.jdbc.driver.OracleDriver()); Connection conn = DriverManager.getConnection( "jdbc:default:connection:"); String sqlUpdate = "UPDATE ma SET gehalt = ? WHERE ma_nr = ?"; PreparedStatement pstmt = conn.prepareStatement(sqlUpdate); pstmt.setInt(1, gehalt); pstmt.setInt(2, ma_nr); pstmt.executeUpdate(); //conn.close(); pstmt.close(); } catch(Exception e) { e.printStackTrace(); } } //public static void main(String[] args) { setGehalt(1, 900); } } Copyright by ORDIX AG Verlagerung von Java-Anwendungen in die Datenbank Laden der Java-Klassen in die DB Es können folgende Dateiarten in ein Datenbankschema geladen werden: • Java-Sourcecode-Datei (*.java) • Java-Class-Datei (*.class) • Java-Ressource-Datei (*.jar bzw. *.zip) Copyright by ORDIX AG Verlagerung von Java-Anwendungen in die Datenbank Laden der Java-Klassen in die DB .java Datei .class Datei .jar Datei loadjava Oracle-DB Java Compiler Java Source Java Class Java Resource DB-Schema Copyright by ORDIX AG Verlagerung von Java-Anwendungen in die Datenbank Laden der Java-Klassen in die DB • Auf der Betriebssystemebene: loadjava -user mf/mf@orcl10 -resolve -verbose C:\java\Jora.class • Im SQL Plus: exec dbms_java.loadjava('-resolve -verbose C:\java\Jora.class') Voraussetzung: exec dbms_java.grant_permission('MF', 'java.io.FilePermission','C:\java\*','read') Copyright by ORDIX AG Verlagerung von Java-Anwendungen in die Datenbank Java-Klassen aus der DB entfernen • Auf der Betriebssystemebene: dropjava -user mf/mf@orcl10 -verbose Jora • Im SQL Plus: exec dbms_java.dropjava('-verbose Jora') Copyright by ORDIX AG Verlagerung von Java-Anwendungen in die Datenbank Java 2 Security-Konzept • Zugriff auf Ressourcen wird mit einer Java-Policy Tabelle im Schema SYS sichergestellt. • Die Rechte lassen sich über USER_JAVA_POLICY bzw. DBA_JAVA_POLICY abfragen. • Das DBMS_JAVA Paket enthält Prozeduren für die Verwaltung von Rechten. • Mit JAVA_ADMIN Rolle können Rechte für Java-Anwendungen administriert werden. Copyright by ORDIX AG Verlagerung von Java-Anwendungen in die Datenbank Java 2 Security-Konzept • Es können unter anderem Rechte, gemäß dem Java 2 SecurityKonzept, zur folgenden Rechte-Klassen verwaltet werden: − java.io.FilePermission − java.net.SocketPermission − java.lang.RuntimePermission − java.net.NetPermission − oracle.aurora.rdbms.security.PolicyTablePermission − ... Copyright by ORDIX AG Verlagerung von Java-Anwendungen in die Datenbank Java 2 Security-Konzept • Auszug aus der DBA_JAVA_POLICY View: KIND -------GRANT RESTRICT GRANT GRANT ... GRANTEE ------MF PUBLIC SYS SYSTEM TYPE_NAME --------------------------java.io.FilePermission java.lang.RuntimePermission java.lang.RuntimePermission java.io.FilePermission Copyright by ORDIX AG NAME -------------------C:\java loadLibrary.* loadLibrary.corejava <<ALL FILES>> ACTION ENABLED SEQ ------ ------- --read ENABLED 182 ENABLED 71 ENABLED 61 read ENABLED 101 Verlagerung von Java-Anwendungen in die Datenbank DBMS_JAVA • Das DBMS_JAVA Package verfügt unter anderem über folgende Prozeduren bzw. Funktionen: dbms_java.loadjava(...) dbms_java.dropjava(...) dbms_java.grant_permission(...) dbms_java.restrict_permission(...) dbms_java.disable_permission(...) dbms_java.enable_permission(...) dbms_java.delete_permission(...) dbms_java.set_output(...) dbms_java.longname(...) dbms_java.shortname(...) ... Copyright by ORDIX AG Verlagerung von Java-Anwendungen in die Datenbank Resolving-Konzept • Resolving-Konzept ist eine Alternative zum CLASSPATH-Konzept. • Suchreihenfolge: Schema des Datenbankbenutzers, SYS • Resolving-Liste • DBA_JAVA_RESOLVERS enthält eine Übersicht über die vorhandenen Resolving-Listen. • Eine Resolving-Liste bezieht sich immer nur auf eine Java-Klasse. Beispiel: loadjava -resolver ((*BK)(*MF)(*PUBLIC)) ... Copyright by ORDIX AG Verlagerung von Java-Anwendungen in die Datenbank Resolving-Konzept • Beispiel mit einer Resolving-Liste: CREATE AND COMPILE JAVA SOURCE NAMED mf.StartProg RESOLVER ((*BK)(*MF)(*PUBLIC)) AS public class StartProg { public static void setGehalt(int ma_nr, int gehalt) { Mitarbeiter.setGehalt(ma_nr, gehalt); } } / Copyright by ORDIX AG Verlagerung von Java-Anwendungen in die Datenbank Veröffentlichung von Java-Klassen in der Datenbank • Signaturen der Java-Methoden einer Java-Klasse werden im Data Dictionary veröffentlicht. werden abgebildet Java-Methode PL/SQL-Wrapper • PL/SQL-Wrapper werden auch als Aufrufspezifikationen, Call Specs oder Java Stored Procedures bezeichnet. Copyright by ORDIX AG Verlagerung von Java-Anwendungen in die Datenbank Veröffentlichung von Java-Klassen in der Datenbank Die PL/SQL-Wrapper können auf folgende Art und Weise definiert werden: • Aufrufspezifikation auf höchster Ebene, d. h. auf derselben hierarchischen Ebene wie andere Objekte wie z. B. Tabellen oder Sichten • Aufrufspezifikation als PL/SQL Package-Prozedur • Aufrufspezifikation als Methode eines Objekttyps Beispiel eines PL/SQL-Wrappers: CREATE OR REPLACE PROCEDURE rechne_java( bis IN NUMBER) AS LANGUAGE JAVA NAME 'Test.rechne(int)'; / Copyright by ORDIX AG Verlagerung von Java-Anwendungen in die Datenbank Parameterübergabe zwischen PL/SQL und Java • In der Datenbankprogrammiersprache PL/SQL können die Parameter einer Prozedur mit folgenden Modi definiert werden: − IN (nur lesen) − OUT (nur schreiben) − IN OUT (lesen und schreiben) • Die primitiven Java-Datentypen (Übergabe als Wert) werden als IN Parameter in PL/SQL abgebildet. • Java-Objekte (Übergabe als Referenz) werden als IN OUT Parameter in PL/SQL umgesetzt. Copyright by ORDIX AG Verlagerung von Java-Anwendungen in die Datenbank Parameterübergabe zwischen PL/SQL und Java • Zuordnungen der Java- und PL/SQL-Datentypen SQL-Typ Java-Typ CHAR, LONG, VARCHAR2 oracle.sql.CHAR, java.lang.String ... DATE oracle.sql.DATE, java.sql.Date ... NUMBER oracle.sql.NUMBER, java.lang.Integer, java.lang.Float, short, double ... BLOB oracle.sql.BLOB ... ... ... Copyright by ORDIX AG Verlagerung von Java-Anwendungen in die Datenbank Aufruf der Java Stored Procedures Oracle Datenbank Oracle Forms Oracle Net Java Applikation ODBC Client Copyright by ORDIX AG Oracle Net Oracle Net Java Stored Procedure PL/SQL Stored Procedure Verlagerung von Java-Anwendungen in die Datenbank Exception Handling • Alle Java-Exceptions werden mit ORA-29532 an SQL bzw. PL/SQL weitergereicht: eingeschränktes Exception Handling SQL> exec test('b') Test$EWrongValue at Test.starte_test(Test:10) BEGIN test('b'); END; * FEHLER in Zeile 1: ORA-29532: Java-Aufruf durch nicht abgefangene Java-Exception beendet: Test$EWrongValue ORA-06512: in "MF.TEST", Zeile 1 ORA-06512: in Zeile 1 Copyright by ORDIX AG Verlagerung von Java-Anwendungen in die Datenbank Anwendungsmöglichkeiten von Java Stored Procedures • Umfangreiche Java-Funktionsbibliotheken (API) können genutzt werden: - Zugriff auf Dateien (java.io) - Dateikomprimierung (java.util.zip) - Logging Mechanismen - Assertions - ... • Java kann für rechenintensive Operationen verwendet werden. Copyright by ORDIX AG Verlagerung von Java-Anwendungen in die Datenbank Anwendungsmöglichkeiten von Java Stored Procedures • Integration verschiedener EDV-Systeme Andere EDVSysteme RPC JVM RMI J2EE Applikationsmodule Datenbanken verschiedener Hersteller HTTP JDBC Java Stored Procedures Copyright by ORDIX AG Verlagerung von Java-Anwendungen in die Datenbank Java Native Interface • Aufruf einer JDBC-Anwendung vor 10g JDBC-Anwendung PL/SQL-Wrapper Java-Klasse OracleJVM Copyright by ORDIX AG Verlagerung von Java-Anwendungen in die Datenbank Java Native Interface • Aufruf einer JDBC-Anwendung ab 10g JDBC-Anwendung mit Client-Stub Java Native Interface Java-Klasse OracleJVM Copyright by ORDIX AG Verlagerung von Java-Anwendungen in die Datenbank Java Native Interface • Java Native Interface ermöglicht einen direkten Zugriff auf public static Methoden einer Java-Klasse in der OracleJVM. • Mit JPublisher lassen sich Client-Proxy Klassen erzeugen. jpub -u user/passwd@db -java=Klasse.java • Zugriff auf serverseitige Java-Methoden über die Client-Proxy Klassen (client-side stub API). • Die Client-Proxy Klassen werden im Anwendungscode mit einer JDBC-Connection als Parameter instanziert. Copyright by ORDIX AG Verlagerung von Java-Anwendungen in die Datenbank Java Native Interface Vorteile bei der Verwendung von Java Native Interface: • PL/SQL-Wrapper kann entfallen • Keine Einschränkungen bei der Verwendung von ParameterDatentypen • Datenkonvertierung Java - PL/SQL- Java nicht nötig • Besseres Exception-Handling wegen Java - Java. Copyright by ORDIX AG Verlagerung von Java-Anwendungen in die Datenbank Resümee • Mit Java in der Datenbank kann die Funktionalität einer Datenbank deutlich erweitert werden. • Java Stored Procedures sind datenbankunabhängig. • Durch die Verwendung von Java Stored Procedures: − sinkt die Programmausführungszeit − die Netzlast wird minimiert − wird eine gute Performance erzielt. • Java und PL/SQL schließen sich für die serverseitige DBProgrammierung nicht aus, sondern können sich ergänzen. • Java Native Interface ist eine nützliche Erweiterung. Copyright by ORDIX AG Verlagerung von Java-Anwendungen in die Datenbank
© Copyright 2025 ExpyDoc