Frage zu einer 3-Tier Anwendung

Status
Nicht offen für weitere Antworten.

-MacNuke-

Bekanntes Mitglied
Hallo.

Da wir in der Firma unsere Software komplett neu schreiben müssen, arbeite ich gerade aus wie wir das hier nun genau anstellen.

Die letzte Zeit arbeitete ich mich in Java ein und auch in Hibernate. Wir hatten uns gedacht das wir halt Java/Swing mit Hibernate nutzen. Leider erfährt man ja erst nach eigenen Versuchen oder intensiver Suche im Netz nach all den Nachteilen dieses Vorhabens (in größeren Multi-User Netzwerken). Unterm Strich ist Hibernate für eine Client/Server (2-Tier, richtig?) nicht wirklich geeignet bzw. es ist ein nicht zu unterschätzender Aufwand.

Jetzt geht es halt darum andere Wege zu finden und auch hier im Forum stößt man auf "mache eine 3-Tier Anwendung". Hab mich auch informiert wie das nun so im Groben aussieht, aber man steht als Einzelner da ja nun vor einem riesigen Berg an Dokumentationen und Frameworks.

Eine 3-Tier Anwendung besteht dann ja quasi aus der Datenbank, einem Application-Server und der Oberfläche. Hibernate und der Java-Code laufen dann ja quasi auf dem Application-Server.

Hier die Frage wo ich noch nicht wirklich eine Antwort gefunden habe: Muss die Oberfläche nun zwangsläufig browserbasiert sein oder gibt es auch andere Möglichkeiten eine 3-Tier Anwendung zu erstellen?
 
M

maki

Gast
3 Schicht Architekturen sind prinzipiell 4 Schicht Architekturen ;)

Präsentation, Geschäftlogik, Anbindung an die DB inkl. Anpassung der Datenstrukturen und schliesslich die Datenbank selbst.

Ein Applicationserver ist nicht Vorraussetzung, diese Schichten sind logischer Natur.

Hibernate ist sehr häufig verwendet in dieser Art Anwendung, die Probleme samt möglicher Lösungen sind bekannt.
Auch müssen diese Anwendungen nicht notwendigerweise einen Browser als Client unterstützen.
 

foobar

Top Contributor
-MacNuke- hat gesagt.:
Die letzte Zeit arbeitete ich mich in Java ein und auch in Hibernate. Wir hatten uns gedacht das wir halt Java/Swing mit Hibernate nutzen. Leider erfährt man ja erst nach eigenen Versuchen oder intensiver Suche im Netz nach all den Nachteilen dieses Vorhabens (in größeren Multi-User Netzwerken). Unterm Strich ist Hibernate für eine Client/Server (2-Tier, richtig?) nicht wirklich geeignet bzw. es ist ein nicht zu unterschätzender Aufwand.
Die Lernkurve ist steil, aber es lohnt sich auf jeden Fall für Neuentwicklungen. Bei Altanwendungen mit historisch gewachsenem DBschema hat man mit ORM wenig Spaß.


-MacNuke- hat gesagt.:
Jetzt geht es halt darum andere Wege zu finden und auch hier im Forum stößt man auf "mache eine 3-Tier Anwendung". Hab mich auch informiert wie das nun so im Groben aussieht, aber man steht als Einzelner da ja nun vor einem riesigen Berg an Dokumentationen und Frameworks.
Eine 3-Tier Anwendung besteht dann ja quasi aus der Datenbank, einem Application-Server und der Oberfläche. Hibernate und der Java-Code laufen dann ja quasi auf dem Application-Server.
Guck dir mal das Springframweork an. Das ist elcihtgewichtig und macht die Integration von Hibernate sehr einfach.

-MacNuke- hat gesagt.:
Hier die Frage wo ich noch nicht wirklich eine Antwort gefunden habe: Muss die Oberfläche nun zwangsläufig browserbasiert sein oder gibt es auch andere Möglichkeiten eine 3-Tier Anwendung zu erstellen?
Nein, dein Client kann eine Webapp eine Swinganwendung oder auch eine RCP-Anwendung sein. Das spielt überhaupt keine Rolle. Du kannst die Clients durch verschiedene Remotetechnologien wie RMI,SOAP,REST etc. anbinden.
 

-MacNuke-

Bekanntes Mitglied
Das klingt schon mal beruhigender. Aber jetzt habe ich noch ein paar mehr Wörter wo ich mich einlesen muss :D

Also bei der Anwendung fangen wir quasi noch mal an. Die jetzige Lösung hat weder eine SQL-Datenbank, noch basiert die Anwendung auf SQL-Befehlen und ein paar Sachen sind grundlegende Design-Fehlentscheidungen die uns momentan von einigen Erweiterungen abhalten. Diese rein zu korrigieren käme einem Re-Write gleich. Zumal die Umgebung nicht mehr weiterentwickelt wird, vom Hersteller. Daher -> wir müssen weg.

Ich muss also auf nichts rücksicht nehmen, außer das die Bedienung der neuen Anwendung nicht allzu stark von der jetzigen abweicht. Weil die wird bei unseren Kunden immer hoch gelobt.

So. Soviel dazu. :D

Also Tests mit Hibernate und Java habe ich ja schon genug gemacht. Mein Problem war dann immer das ein Client dann nicht immer aktuelle Daten hatte usw. Das sind halt die Hibernate-Caches. Klar kann man die abschalten, aber dazu habe ich in anderen Foren gefunden, dass ich mich dann auf extreme Performance-Probleme einstellen kann (bis zu Sekundenbereichen). Und ich halte mich nicht für was besonderes, also werde ich über kurz oder lang auch in diese Probleme rennen ;)

Das will ich halt dann von Anfang an vermeiden. Darum wohl empfohlen eine 3-Tier Anwendung. Das passt auch besser, da auf dem Application-Server soweit ich weiß nur ein Hibernate-Cache vorhanden ist, den alle nutzen und somit alle auf den richtigen Daten arbeiten.

Oder bin ich mit dem Application-Server (z.B. Glassfish) jetzt auf dem falschen Weg? Weil irgendwie muss doch auf dem Server was laufen, was die Sachen ausführt, oder? ^^

Die Frage ob es denn eine Webanwendung wird, ist noch nicht ganz geklärt. Toolkits wie GWT sehen ja schon mal ganz gut aus, aber die Dokumentationen dazu sind auch recht spärlich. Und Sachen wie Tapestry sehen sehr.... groß aus :D

Bisher kenne ich nur Swing und habe bisher auch nur Swing-Anwendungen mit Java gemacht, daher bevorzuge ich sicher das, klar, aber ich will auch nicht allzu verbohrt sein. Noch ist in meinem Kopf Webanwendung = ultrakompliziert, wenn ich eine Webanwendung haben will, die sich wie eine Swing-Anwendung bedient (also ohne Page-Refreshs (AJAX?)) :D

Naja, mal weiter reinlesen in die Sache... muss ich morgen mal ein bisschen ordnen...
 

foobar

Top Contributor
Oder bin ich mit dem Application-Server (z.B. Glassfish) jetzt auf dem falschen Weg? Weil irgendwie muss doch auf dem Server was laufen, was die Sachen ausführt, oder?
Glassfish ist ein Applicationserver für JEE Anwendungen. Das ist eine Alternative zu Spring bzw. umgekehrt *g*

Also Tests mit Hibernate und Java habe ich ja schon genug gemacht. Mein Problem war dann immer das ein Client dann nicht immer aktuelle Daten hatte usw. Das sind halt die Hibernate-Caches. Klar kann man die abschalten, aber dazu habe ich in anderen Foren gefunden, dass ich mich dann auf extreme Performance-Probleme einstellen kann (bis zu Sekundenbereichen). Und ich halte mich nicht für was besonderes, also werde ich über kurz oder lang auch in diese Probleme rennen
Du hattest wohl langlaufende Sessions auf den Clients. Das lässt sich aber leicht lösen. Du kannst nur auf den Secondlevel-Cache verzichten den Firstlevel-Cache (Session) gibt es immer.
 

-MacNuke-

Bekanntes Mitglied
foobar hat gesagt.:
Glassfish ist ein Applicationserver für JEE Anwendungen. Das ist eine Alternative zu Spring bzw. umgekehrt *g*

Hmmm... OK...

...ich glaube ich lese erst mal noch ein bisschen rum, bevor ich weiterfrage ;) Ich hab momentan nicht so wirklich den Plan :D
 

foobar

Top Contributor
-MacNuke- hat gesagt.:
...ich glaube ich lese erst mal noch ein bisschen rum, bevor ich weiterfrage ;) Ich hab momentan nicht so wirklich den Plan :D

Das geht uns allen so *g* Ständig gibt es irgendwelchen neuen Apis, Frameworks und haste nicht geshen. Da weiß man bald gar nicht mehr was man überhaupt noch nutzen soll.
 

robertpic71

Bekanntes Mitglied
Noch zu Hibernate: Bei mir ist der Secondlevel-Cache per default abgeschalten - das sollte keine Probleme machen.

Ich habe so einen ähnlichen Entscheidungsprozess auch vor 2 Jahren durchgemacht, hier nur gaaanz grob ein paar Möglichkeiten:

1.) Desktopanwendung (Swing/SWT/RCP)
mit Hibernateanbindung
- kein Secondlevelcache
- Hibernateengine erhöht Anforderungen an den Client
+ GUI ohne Kompromisse möglich
- zwischen Businesslogik und Datenbank liegen mitunter in andern Bundesländern..

2.) Desktopanw. (Swing..) + Applikationsserver über RMI
+ Hibernate läuft am Server
+ Hibernate kann Secondlevelcache nutzen
+ GUI wie bei 1.)
+ Businesslogik am Server

Programmtechnisch schaut das so aus, dass für die Manager, DAO's.. Klassen noch ein
Interface bereitgestellt weden muss und diese vom Server dann auch Remote angeboten werden.
Im Desktopprogramm holst erzeugst du die Businessklassen nicht selber, sondern holst sie
dir z.b. von einem JNDI-Client, der diese wiederum vom Server holt.

3.) Ajax-Web-Anwendung
+ Hibernate läuft am Server
+ Hibernate kann Secondlevelcache nutzen
+/- schöne GUI mit Ajax möglich, aber an Swing/SWT kommt es nicht ganz ran
+ Businesslogik am Server
+ keine Deploymentsorgen
- je nach Framework aufwändiger Erstellung
- höhere Serveranforderungen
+ man kann (!) linkfähige Anwendungen erhalten bzw. leicht zu anderen
Webanwendungen verzweigen

Unser Knockout-Kriterium für 1. und 2. waren die 500 Network-Clients welche nur via Remotedesktop (Citrix, RDB, X11) oder per nativen Browser arbeiten können. 500 x Remotedesktop heißt 500 JVM's am Server...
Weiters läßt sich in eine Webanwendung leichter mit den bereits vorhandenen Webanwendungen migrieren.

Das Problem bei den Ajax-Frameworks ist, dass es da viele davon gibt und sich noch kein Gewinner abzeichnet. Aber bisher jedes Framework war mMn noch übersichtlicher und einfacher als JSF + Ajaxzusatz.

Wir verwenden jetzt das Framework ZK mit Hibernate und Spring. Das Framework bietet weitgehend das Desktopprogrammiermodel an (Komponenten, GUI-Events..) und bietet auch zusätzlich die Möglichkeit die GUI mit XML zu beschreiben und dabei noch die Vorzüge von WebAnwendungen (z.B. EL's) zu vereinen.

/Robert
 

-MacNuke-

Bekanntes Mitglied
Wow, vielen Dank für die Zusammenfassung :)

Das mit Remote Desktop und der Masse an JVMs habe ich ja z.B. gar nicht bedacht...

... wird warscheinlich die Entscheidung beeinflussen. Aber das werde ich in der Firma am Montag besprechen :)
 

ARadauer

Top Contributor
Programmtechnisch schaut das so aus, dass für die Manager, DAO's.. Klassen noch ein
Interface bereitgestellt weden muss und diese vom Server dann auch Remote angeboten werden.
Im Desktopprogramm holst erzeugst du die Businessklassen nicht selber, sondern holst sie
dir z.b. von einem JNDI-Client, der diese wiederum vom Server holt.
hier ist spring auch ziehmlich hilfreich... hab eine anwendung die von der client seite auf einen service zugreift. dieser service kapselt die ganze business logik und den db zugriff über hibernate. zum entwickeln zutz ich den server am client, der client benutzt einfach die klassen im eclipse projekt... eine änderung in der spring konfig und der client greift über rmi auf den service am server zu... feine sache..
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
B Generelle Frage bei einer Webanwendung / Reduzierung von DB Abfragen Allgemeine Java-Themen 1
P Kurze Frage: aus einer File die Zeilenanzahl auslesen Allgemeine Java-Themen 9
M Frage zum Auslesen einer Datei auf nem Server Allgemeine Java-Themen 4
L Frage zu java.util.regex und Einlesen einer Datei Allgemeine Java-Themen 2
N Frage zu einer Rekursion Allgemeine Java-Themen 4
KonradN Mal eine Frage zu Binary Serialization Allgemeine Java-Themen 15
8u3631984 Frage zu Java Streams min / max Allgemeine Java-Themen 17
8u3631984 Frage Performance bei Linked List und Array List Allgemeine Java-Themen 5
H Frage regex greater than less than Allgemeine Java-Themen 7
berserkerdq2 Frage zu IntelliJ und JavaFX Allgemeine Java-Themen 1
W Timer Konzept-Frage Allgemeine Java-Themen 16
T Eine Frage des Designs Allgemeine Java-Themen 2
C Frage zu eigenem TableCellRenderer Allgemeine Java-Themen 11
C Programmvorstellung & Frage zum Thema Geschäftsform Allgemeine Java-Themen 51
J Frage zu System.getproperties. Allgemeine Java-Themen 60
molat100 wie kann man die Frage beantworten Allgemeine Java-Themen 1
pkm Frage zur Präzision von Calendar.WEEK_OF_YEAR Allgemeine Java-Themen 12
J Eine Frage zu den Threads und Task Allgemeine Java-Themen 1
pkm Frage nach eventuellem syntaktischen Zucker bei der Konkatenation von ArrayLists Allgemeine Java-Themen 4
M Frage-Antwortspiel wie Wer wird Millionär Allgemeine Java-Themen 1
F Frage zu System.in Allgemeine Java-Themen 3
marcooooo Frage zum Beispiel im Anhang Allgemeine Java-Themen 16
T Meine Frage lautet wie ich 2 CSV Dateien miteinander in Java verbinde und Spalten die zueinander gehören durch den gleichen Key zusammen ausgebe? Allgemeine Java-Themen 5
S Noch eine Design-Frage zu Setter Allgemeine Java-Themen 6
B For-Loop Frage Allgemeine Java-Themen 21
L Java frage Allgemeine Java-Themen 3
bueseb84 Frage zu Mock und UpperBound Allgemeine Java-Themen 2
M Frage zum Konstruktor Allgemeine Java-Themen 2
W Best Practice Frage zur Umsetzung MVC Allgemeine Java-Themen 9
P String-Verschlüsselung - Frage zur Sicherheit Allgemeine Java-Themen 21
B Frage zu Unit-Tests Allgemeine Java-Themen 6
T Allgemeine Frage: GUI für 3D-Visualisierung Allgemeine Java-Themen 5
R Allgemeine Frage zu RMI bei MVC Allgemeine Java-Themen 2
O Frage zum Runtimeverhalten von Java ... Allgemeine Java-Themen 2
H Rundreise frage (Algorithmus) Allgemeine Java-Themen 18
D Frage zu Vererbung Allgemeine Java-Themen 5
J Frage zu regulärem Ausdruck Allgemeine Java-Themen 2
M Allgemeine Frage: Wie lernt man Java / Programmieren von Grund auf? Allgemeine Java-Themen 7
rentasad Design-Frage - Interfaces, Klassen, statische Methoden Allgemeine Java-Themen 3
S Frage zur JLS Allgemeine Java-Themen 0
J Verständnis Frage zur Instanz, Objekte, Instanzierung, Referenz Allgemeine Java-Themen 14
A Methoden Allgemeine Java Frage Allgemeine Java-Themen 3
E String Frage Allgemeine Java-Themen 9
I bin neu bei GitHub, Frage zur Sicherheit Allgemeine Java-Themen 14
C J2V8 NodeJs Java Bride Problem und Frage!?!? Allgemeine Java-Themen 1
C KeyListener Frage Allgemeine Java-Themen 3
T Frage zu UML in Java programmieren Allgemeine Java-Themen 1
R Konstanten initialisieren - FRAGE Allgemeine Java-Themen 3
MTJ004 FTP Frage zu FTP Speicherung Java-Android-FTP Allgemeine Java-Themen 5
J Frage zum Entwurf / json-Datenmodell Allgemeine Java-Themen 8
A Frage zu meinem Code Allgemeine Java-Themen 2
RalleYTN Classpath Nur ne kleine Frage zur MANIFEST.MF Allgemeine Java-Themen 4
T Frage zu Access Modifiers Allgemeine Java-Themen 6
W Input/Output Frage zu pdfbox und FileUtils Allgemeine Java-Themen 2
O Frage zur Implementierungsweise Allgemeine Java-Themen 4
B Frage zu Bitshift Allgemeine Java-Themen 3
J Java Zufallsgenerator (6 aus 49) Frage Allgemeine Java-Themen 7
L Frage zu RIA und GWT Allgemeine Java-Themen 0
P Concurrency Frage Allgemeine Java-Themen 8
M Frage zu Enumerations Allgemeine Java-Themen 2
F Unlimited Strength Policy. Frage Verbreitung der Anwendung Allgemeine Java-Themen 1
F Frage zur Library JTS Allgemeine Java-Themen 5
S Java Design Frage Allgemeine Java-Themen 10
E Reflection? Frage Allgemeine Java-Themen 4
C FileInputStream frage Allgemeine Java-Themen 6
G Polymorphie Programmdesign Frage Allgemeine Java-Themen 20
Uzi21 Frage zu NetBeans ( Console) Allgemeine Java-Themen 11
D Classpath Frage zum Java Resource Loading Allgemeine Java-Themen 2
G Frage zu JPA Allgemeine Java-Themen 1
S Methoden Frage Allgemeine Java-Themen 2
P MVC - Frage zu Model Allgemeine Java-Themen 4
K Frage zu Locks Allgemeine Java-Themen 1
S Frage zu abstract Allgemeine Java-Themen 5
M ArrayList<String> Frage Allgemeine Java-Themen 7
M OOP Design Frage Allgemeine Java-Themen 2
N Frage zur while-Schleife Allgemeine Java-Themen 18
T Best Practice Auslesen von Zeichenketten (Frage, Antworten, usw) Allgemeine Java-Themen 4
C Eine Frage zur Bearbeitungszeit Allgemeine Java-Themen 8
H Frage wegen Heap-Speicher Allgemeine Java-Themen 2
T Garbage Collection Frage Allgemeine Java-Themen 15
D Frage zu Java und Umlauten / charsets Allgemeine Java-Themen 2
B Frage zu Java und OpenGL? Allgemeine Java-Themen 3
Q Kapselung Allgemeine Design- Frage Allgemeine Java-Themen 8
A eine test thread.join() frage Allgemeine Java-Themen 2
DStrohma LayoutManager Frage zum GridBagLayout Allgemeine Java-Themen 4
F Frage zu Regex möglich Allgemeine Java-Themen 4
H XML-File mit Java erzeugt Frage Allgemeine Java-Themen 10
D Frage und Antwort Programm, Problem bei Methodenaufruf Allgemeine Java-Themen 3
J NetBeans Frage bezüglich der Scanner-Klasse Allgemeine Java-Themen 6
H Java Vector Frage Allgemeine Java-Themen 9
W Frage... Allgemeine Java-Themen 29
R Frage zur topologischen Sortierung Allgemeine Java-Themen 2
H Frage zu weka.core.Instance Allgemeine Java-Themen 3
Y Kleine Frage zu String.split Allgemeine Java-Themen 3
T Frage zu Klassendesing Allgemeine Java-Themen 3
W Frage zu Refactoring statischer Methoden Allgemeine Java-Themen 4
C Eclipse Wichtige frage Allgemeine Java-Themen 5
H Frage zu java.weka.core.Instances Allgemeine Java-Themen 3
S Frage zu Format Modifiers in Log4j Allgemeine Java-Themen 11
H Frage zu clone() Allgemeine Java-Themen 5

Ähnliche Java Themen

Neue Themen


Oben