Ein Blick unter die Motorhaube von Oracle APEX Patrick Wolf, Sphinx IT Consulting DOAG Konferenz Nürnberg, 22.11.2007 Agenda • Architekturübersicht • mod_plsql/Embedded PL/SQL Gateway • Connection Pool • Oracle APEX Sessions • Oracle APEX Engine • Oracle APEX News von der Oracle Open World in SF Über Sphinx IT Consulting • Gegründet 1993 • Erstellung von Individualsoftware • Consulting im Bereich Datenbanken & Java Middleware • Spezialist im Oracle Umfeld • Weitere Informationen auf http://www.sphinx.at/ Über Patrick Wolf • Solution Architect bei Sphinx IT Consulting • Oracle APEX Developer of the Year 2007 und Oracle ACE • Betreibt einen APEX Blog – http://inside-apex.blogspot.com • Autor des ApexLib Frameworks – http://apexlib.sourceforge.net/ • Autor des Oracle APEX Builder Plugins • Zu erreichen unter [email protected] Architekturübersicht • 3-Tier mit eigenem Web Server (OHS oder Oracle Application Server) und mod_plsql • 2-Tier mit integriertem Web Server in der Datenbank und Embedded PL/SQL Gateway • Oracle APEX Engine 3-Tier mit eigenem Web Server 3-Tier mit eigenem Web Server • Vorteile: – Statische Dateien schneller ausliefern – HTTPS Overhead belastet nicht Datenbank CPU – Security: Datenbankrechner ist nicht direkt nach außen sichtbar (Reverse Proxy eine andere Möglichkeit) – mod_rewrite – mod_gzip/mod_deflate – ... • Nachteile – Zusätzlicher Rechner zum Installieren und Administrieren – Kaum belastet 2-Tier mit integriertem Web Server 2-Tier mit integriertem Web Server • Vorteile: – Out-of-the-Box mit Oracle XE und 11g – Kein zusätzlicher Rechner zum Installieren und Administrieren • Nachteile – Statische Dateien langsamer da aus Datenbank gelesen – HTTPS Overhead belastet Datenbank CPU – Security: Datenbankrechner direkt nach außen sichtbar – Kein mod_rewrite, mod_gzip, ... mod_plsql/Embedded PL/SQL Gateway • Mapping eines URLs -> DAD Konfiguration -> Datenbank -> APEX Instanz dad.conf Konfiguration: z.B. mit <Location /pls/apex> • Connection Pool Verwaltung • PL/SQL Prozedur Aufruf in der Datenbank • Weiterleitung der Ausgabe an den Browser • Konfiguration – Bei mod_plsql: Mit dads.conf am Apache Web Server (Name anders bei älteren Versionen des Application Servers). Siehe Oracle APEX Installationsanleitung. – Bei Embedded PL/SQL Gateway: Mit Package DBMS_EPG Connection Pool • Immer mit dem User APEX_PUBLIC_USER/HTMLDB_PUBLIC_USER/ANONYMOUS/im DAD konfigurierten User • Schnellerer Verbindungsaufbau da DB Sessions wiederbenutzt werden können • Limitierung der gleichzeitigen Datenbank Sessions nicht einer dezidierten • Oracle APEX Session ist Datenbank Session zugeordnet! Großer Unterschied zu C/S Anwendungen wie Oracle Forms! Oracle APEX ist Stateless! • Konfigurationsinformationen: – mod_plsql Configuration Parameters - http://download.oracle.com/docs/cd/B19306_01/server.102/b14190/ confmods.htm#i1055414 – Controlling Database Processes for Each mod_plsql Request - http://download.oracle.com/docs/cd/A97336_01/comm.102/a87562/ apptroub.htm#631218 – PlsqlIdleSessionCleanupInterval – PlsqlMaxRequestsPerSession
Description: