META-INF/persistence.xml in einer war-Datei

fsicher

Bekanntes Mitglied
Hallo allerseits

Ich möchte ein WebService mir JAX-RS (REST) implementieren und auf Tomcat 7.x laufen lassen. Dabei verwende ich auch Hibernate als OR Mapper. In einem gewöhnlichen Projekt müsste die persistence.xml Datei im Verzeichnis META-INF sein, das sich seinerseits im ROOT-Verzeichnis befindet (in eclipse im src-Verzeichnis). Nun, jetzt muss ich meine App in eine war-Datei verpacken. Wo kommt jetzt META-INF/persistence.xml hin? Denn, ein META-INF ist schon im APP-ROOT vorhanden (MANIFEST.MF)! Kommt die persistence.xml dort? Habe zwar versucht, Tomcat konnte aber danach überhaupt nicht starten. Auch mit WEB-INF/META-INF/persistence.xml hat es nicht geklappt, mit WEB-INF/classes/META-INF/persistence.xml auch nicht.

Kann mir jemand einen Tipp geben? Das Dumme ist, dass ich die Fehlermeldung nicht lesen kann: CommandPrompt wird sofort geschlossen: ein "pause" eintrag in startup.bat hilft nicht, in Log-Dateien sehe ich nur, dass mit dem deployen den Anwendung gestartet wurde: keine weitere Einträge vorhanden. Aus die Versuche mit Logging-Level-Anpassung (FINEST / ALL) in conf/loging.properties haben nicht mehr gebracht. Auch das Umleiten der Ausgabe in eine andere Datei hat nicht geholfen.

Danke für jeden Tipp.
 
M

maki

Gast
APPROOT/META-INF wäre imho richtig, neben WEB-INF

Solltest Tomcat von der Kommandozeile aus starten, dann verschwindet die Konsole nciht und du kannst die Fehlermeldung lesen, oder Tomcat über die IDE starten während du entwickelst.
 

mvitz

Top Contributor
classes/META-INF/persistence.xml müsste allerdings auch ohne Probleme funktionieren. Vermutlich hast du ein noch sehr viel größeres Problem, denn die startup.bat sollte sich eigentlich nicht von selbst schließen...
 

fsicher

Bekanntes Mitglied
Danke für die schnelle Antwort.

Habe es noch eimal versucht mit APPROOT/META-INF/persistence.xml. Jetzt startet er, wird aber nach dem Versuch, meine Anwendung zu deployen, beendet. Obwohl ich es von der Befehlszeile starte, wird CommandPrompt geschlossen!

In der Hoffnung, die Fehlermeldung zu sehen, habe ich jetzt Tomcat aus eclipse JEE gestartet. Die Meldung ist jetzt wie folgt:

[XML]
...
INFO: Deploying web application directory ROOT
06.06.2011 13:05:00 org.apache.catalina.startup.HostConfig deployDirectory
INFO: Deploying web application directory shopping
java.lang.OutOfMemoryError: PermGen space
Exception in thread "main" java.lang.OutOfMemoryError: PermGen space[/XML]

Ich bin mir nicht sicher, ob die wirklich zutrifft! Denn, im CommandPrompt war eine klassische Fehlermeldung zu sehen (ca. 20 Zeilen). Das hier könnte evtl. eclipse-Problem sein.

====================================================================

Wenn ich meine Anwendung aus webapps entferne, funktioniert Tomcat problemlos: habe noch zwei weitere REST-WebServices am laufen! Und, die WEB-INF/web.xml sieht wie folgt aus:

[XML]
<servlet>

<servlet-name>Shopping-REST-Servlet</servlet-name>
<servlet-class>com.sun.jersey.spi.container.servlet.ServletContainer</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>Shopping-REST-Servlet</servlet-name>
<url-pattern>/rest/shopping/*</url-pattern>
</servlet-mapping>
</web-app>
[/XML]

Ich habe web.xml an sich nur koppiert und servlet-name und url-mapping angepasst.

EDIT

Es hängt in der Tat mit Speicher zusammen!!! Hier die Fehlermeldung:

[XML]INFO: Deploying web application directory ROOT
06.06.2011 13:25:27 org.apache.catalina.startup.HostConfig deployDirectory
INFO: Deploying web application directory shopping
java.lang.OutOfMemoryError: PermGen space
at java.lang.ClassLoader.defineClass1(Native Method)
at java.lang.ClassLoader.defineClassCond(ClassLoader.java:632)
at java.lang.ClassLoader.defineClass(ClassLoader.java:616)
at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:141)
at org.apache.catalina.loader.WebappClassLoader.findClassInternal(WebappClassLoader.java:2818)
at org.apache.catalina.loader.WebappClassLoader.findClass(WebappClassLoader.java:1148)
at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1643)
at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1521)
at org.apache.catalina.startup.ContextConfig.checkHandlesTypes(ContextConfig.java:1956)
at org.apache.catalina.startup.ContextConfig.processAnnotationsStream(ContextConfig.java:1919)
at org.apache.catalina.startup.ContextConfig.processAnnotationsJar(ContextConfig.java:1806)
at org.apache.catalina.startup.ContextConfig.processAnnotationsUrl(ContextConfig.java:1765)
at org.apache.catalina.startup.ContextConfig.processAnnotations(ContextConfig.java:1751)
at org.apache.catalina.startup.ContextConfig.webConfig(ContextConfig.java:1255)
at org.apache.catalina.startup.ContextConfig.configureStart(ContextConfig.java:882)
at org.apache.catalina.startup.ContextConfig.lifecycleEvent(ContextConfig.java:317)
at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:119)
at org.apache.catalina.util.LifecycleBase.fireLifecycleEvent(LifecycleBase.java:89)
at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5081)
at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:145)
at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:812)
at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:787)
at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:607)
at org.apache.catalina.startup.HostConfig.deployDirectory(HostConfig.java:1055)
at org.apache.catalina.startup.HostConfig.deployDirectories(HostConfig.java:978)
at org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:472)
at org.apache.catalina.startup.HostConfig.start(HostConfig.java:1322)
at org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:311)
at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:119)
at org.apache.catalina.util.LifecycleBase.fireLifecycleEvent(LifecycleBase.java:89)
at org.apache.catalina.util.LifecycleBase.setStateInternal(LifecycleBase.java:379)
at org.apache.catalina.util.LifecycleBase.setState(LifecycleBase.java:324)[/XML]

Am Arbeitsspeicher kann es nicht liegen: habe 8 GB RAM! Muss bzw. kann man irgendwo etwas konfigurieren, damit Tomcat-JVM mehr Speicher bekommt?
 
Zuletzt bearbeitet:

fsicher

Bekanntes Mitglied
Ich bin etwas weiter gekommen:
- Tomcat läuft
- Deployment funktioniert
- die persistence.xml muss in APPROOT/WEB-INF/classes/META-INF sein

Ich kann sehen, wie die Anfrage kommt. Leider scheitere ich beim Versuch, die EntityManagerFactory zu erzeugen:

Java:
entityManagerFactory = Persistence.createEntityManagerFactory("shopping");

Die persistence.xml enthält folgende Zeilen:

[XML]
...
<persistence-unit name="shopping" transaction-type="RESOURCE_LOCAL">

<provider>org.hibernate.ejb.HibernatePersistence</provider>

<class>rest.shopping.domain.Customer</class>

...
[/XML]

Um sicher zu sein, dass mit OR-Mapper-Teil alles in Ordnung ist, habe ich diesen Teil in einem separaten Projekt getestet: es funktioniert einwandfrei. Wenn ich es aber in Tomcat ausführen möchte, geht es nicht!

Es fällt auf, dass Tomcat relativ lange braucht, bis er startet: ca. 40 Sekunden. Im lib-Directory meiner Anwendung habe ich alle Hibernate- und jersey-jar-Dateien. Dazu kommt noch der Treiber für PostgreSQL: alles in allem, ca. 13.5 MB. Die Fehlermeldung, die ich bekomme, sieht wie folgt aus:

[XML]
...
06.06.2011 22:04:39 org.apache.catalina.startup.Catalina start
INFO: Server startup in 38544 ms
59 ["http-bio-8080"-exec-3] INFO org.hibernate.annotations.common.Version - Hibernate Commons Annotations 3.2.0.Final
63 ["http-bio-8080"-exec-3] INFO org.hibernate.cfg.Environment - Hibernate 3.6.1.Final
67 ["http-bio-8080"-exec-3] INFO org.hibernate.cfg.Environment - hibernate.properties not found
74 ["http-bio-8080"-exec-3] INFO org.hibernate.cfg.Environment - Bytecode provider name : javassist
75 ["http-bio-8080"-exec-3] INFO org.hibernate.cfg.Environment - using JDK 1.4 java.sql.Timestamp handling
104 ["http-bio-8080"-exec-3] INFO org.hibernate.ejb.Version - Hibernate EntityManager 3.6.1.Final

EntityManagerFactory konnte nicht angelegt werden!

java.lang.OutOfMemoryError: PermGen space
Exception in thread ""http-bio-8080"-exec-3" java.lang.OutOfMemoryError: PermGen space
...
[/XML]

Was könnte ich jetzt noch machen? Bin für jeden Tipp dankbar.
 

hexx

Mitglied
Code:
java.lang.OutOfMemoryError: PermGen space
Exception in thread ""http-bio-8080"-exec-3" java.lang.OutOfMemoryError: PermGen space

Da steht der Fehler doch ziemlich explizit: Deine Anwendung/ der TC-Server braucht mehr Arbeitsspeicher, als momentan zur Verfügung steht. Dafür gibt es die Optionen -Xmx / -Xms bzw. -XX:MaxPermSize / -XX:permSize. (Bei der Sun/Oracle HotSpot VM)

Hier gibt es einen ganz gute Einführung in die Speicherarchitektur von Java: Java OutOfMemoryError – Eine Tragödie in sieben Akten | blog.codecentric.de

Für den Tomcat kannst du die Optionen in der Umgebungsvariablen JAVA_OPTS angeben: FAQ/Memory - Tomcat Wiki
 

fsicher

Bekanntes Mitglied
Code:
java.lang.OutOfMemoryError: PermGen space
Exception in thread ""http-bio-8080"-exec-3" java.lang.OutOfMemoryError: PermGen space

Da steht der Fehler doch ziemlich explizit: Deine Anwendung/ der TC-Server braucht mehr Arbeitsspeicher, als momentan zur Verfügung steht. Dafür gibt es die Optionen -Xmx / -Xms bzw. -XX:MaxPermSize / -XX:permSize. (Bei der Sun/Oracle HotSpot VM)

Hier gibt es einen ganz gute Einführung in die Speicherarchitektur von Java: Java OutOfMemoryError – Eine Tragödie in sieben Akten | blog.codecentric.de

Für den Tomcat kannst du die Optionen in der Umgebungsvariablen JAVA_OPTS angeben: FAQ/Memory - Tomcat Wiki


Auch diese Übung (unter vielen anderen) habe ich gemacht (Anpassungen von JAVA_OPTS), hat aber auch nicht geholfen. Erst als ich die vorhandene Tomcat-Installation entfernt und Tomcat neu installiert habe, hat es funktioniert: keine Fehlermeldungen, keine Probleme. Die Anwendung funktioniert wie erwartet: WebService-Methoden können aufgerufen werden, Objekte können in PostgresSQL mit Hilfe von Hibernate gespeichert, updatet, gesucht und gelöscht werden.

Sicher ist es etwas komisch, dass man da so lange sucht, wenn man weiss, dass Tomcat in 3 Minuten neu istalliert ist. Aber, da die anderen RESTfull-Anwendungen problemlos funktionierten, sobald die neue Anwendung aus webapps entfernt wird, war ich der Meinung, dass es nicht am Tomcat liegen kann. Ein Irrtum, wie es sich herausgestellt hat. Wo aber das Problem wirklich war, kann ich nicht sagen. Am Speicher wird es wohl nicht liegen. Denn, die neue Installatin habe ich (wie üblich) bei default-Einstellungen belassen.

Vielen Dank.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
I Meta Tags vergleichen mit Html Vorgabe Java Basics - Anfänger-Themen 8
D org.w3c.Document -> meta Java Basics - Anfänger-Themen 5
G persistence.xml in ausführbare jar einbinden Java Basics - Anfänger-Themen 11
L Java Persistence API - Update Befehl? Java Basics - Anfänger-Themen 5
M Ausgabe einer ArrayList ensteht nur als Hashcode, nicht als Objekt Java Basics - Anfänger-Themen 16
D 2 ArrayListen gleich sortieren bzw. eine Liste anhand einer anderen Sortieren Java Basics - Anfänger-Themen 6
ixChronos Letzten 4 Ziffern einer großen Zahl ausgeben Java Basics - Anfänger-Themen 3
P Objekt einer Methode eines anderen Objektes übergeben Java Basics - Anfänger-Themen 5
L Variablenwerte aus einer Methode übergeben Java Basics - Anfänger-Themen 2
E Arrays in einer ArrayList miteinander vergleichen Java Basics - Anfänger-Themen 12
Simon16 Java ArrayListe von einer Klasse sortieren Java Basics - Anfänger-Themen 2
Shadowrunner Variablen Gibt es eine Möglichkeit die Ziffern/Stellen einer Zahl fest zu legen? Java Basics - Anfänger-Themen 3
D remove Object von einer Liste von Obejcts Java Basics - Anfänger-Themen 3
FunkyPhil94 Wert in einer Lambda Funktion erhöhen Java Basics - Anfänger-Themen 3
T Aufruf der Methode einer Oberklasse, wenn sie in der Unterklasse überschrieben ist. Polymorphie. Java Basics - Anfänger-Themen 2
B Kommunikation mit Seriellen Schnittstellen + Integration einer lib Java Basics - Anfänger-Themen 1
A Daten aus einer HashMap aus einer DB speichern und mit neuen Werten vergleichen Java Basics - Anfänger-Themen 8
P Welches SDK für das erstellen einer ausführbaren Datei? Java Basics - Anfänger-Themen 4
D Länge einer Liste aufrufen. Java Basics - Anfänger-Themen 19
J Klassen Instanzen einer Klasse in einer anderen unabhängigen Klasse nutzen Java Basics - Anfänger-Themen 4
B Alle Strings bis zu einer Maimallänge aufzählen, die Bedingung erfüllen Java Basics - Anfänger-Themen 13
marcelnedza Finde meinen Fehler in einer Methode nicht, Java Karol Java Basics - Anfänger-Themen 15
Soranix Erste Schritte Struktur als Anfänger // Von einer Klasse auf ein Objekt einer anderen Klasse zugreifen. Java Basics - Anfänger-Themen 6
MoxMorris Wie macht man String[] = String[] aus einer anderer Methode? Java Basics - Anfänger-Themen 18
T Fibonacci mit einer Hilfsmethode berechnen Java Basics - Anfänger-Themen 10
S Hilfe zu einer Aufgabe Java Basics - Anfänger-Themen 5
M Radius von einer ellipse bestimmen Java Basics - Anfänger-Themen 7
Say Fehlenden Code finden in einer while-Schleife? Java Basics - Anfänger-Themen 11
M Zufallszahl generieren mit einer linken und rechten Grenze Java Basics - Anfänger-Themen 3
N Was Passiert mit dem Namen einer Variable, wenn man diese einer Liste Hinzufügt Java Basics - Anfänger-Themen 16
_user_q Wie eine Methode/Funktion aus einer Klasse mit Constructor aufrufen? Java Basics - Anfänger-Themen 20
W String einer Textdatei in einzelne Stringobjekte pro Zeile aufteilen Java Basics - Anfänger-Themen 14
W Objekte einer ArrayList in txt-datei schreiben mit Paths? Java Basics - Anfänger-Themen 2
S Best Practice Fragen zu Projektstruktur einer Datenbank-Abfrage-App (MVC) Java Basics - Anfänger-Themen 13
T Variable von Objekten in einer Methode überprüfen Java Basics - Anfänger-Themen 26
nelsonmandela Problem bei Ausgabe einer Switch - Case Funktion Java Basics - Anfänger-Themen 5
S Textausgabe in einer For-Schleife Java Basics - Anfänger-Themen 12
M Spezifischen Wert einer Zeile aus .txt Datei entnehmen Java Basics - Anfänger-Themen 15
B Popups mit Klicksabfangen zumAusfüllen einer .ods Datei Java Basics - Anfänger-Themen 0
M RandomAccessFile int und String gleichzeitig in einer Datei Java Basics - Anfänger-Themen 49
E Suchfunktion in einer Liste Java Basics - Anfänger-Themen 39
T ungeordnete Werte-Paare in einer Liste Java Basics - Anfänger-Themen 7
FireHorses Einen Command erst nach einer Chateingabe aktivieren Java Basics - Anfänger-Themen 1
frager2345 Singleton-Muster Java ->Nur eine Instanz einer Klasse erzeugen können Java Basics - Anfänger-Themen 45
F wie kann ich die Position des letzten Vokals innerhalb einer Zeichenkette ermitteln? Java Basics - Anfänger-Themen 5
H Kapselung protected aber in einer Kindklasse nicht zugänglich Java Basics - Anfänger-Themen 5
R Methoden Werte einer ArrayList als Parameter übergeben. Java Basics - Anfänger-Themen 4
B Den Dateipfad einer Java Datei durch Code in Selbiger finden? Java Basics - Anfänger-Themen 10
LilliCherry Array in einer Zeile ausgeben Java Basics - Anfänger-Themen 6
B Attribute eines Objekts einer Klasse durch statische Methode einer 2. Klasse ändern? Java Basics - Anfänger-Themen 32
L Dauerhaftes Speichern einer Eingabe bei einer ArrayList Java Basics - Anfänger-Themen 26
V Hilfe bei Implementierung einer boolean Methode Java Basics - Anfänger-Themen 6
G Position einer unbekannten 3-stelligen-Zahl in einem String finden Java Basics - Anfänger-Themen 15
stormyark Fehler beim überschreiben einer Variable Java Basics - Anfänger-Themen 1
H Kompliziertes Sortieren einer ArrayList mit Objekten(Sortieren nach X und Y) Java Basics - Anfänger-Themen 11
T Permanentes speichern von Objekten in einer ArrayList Java Basics - Anfänger-Themen 6
Saiko Zeilen einer Datei einlesen Java Basics - Anfänger-Themen 3
H Erste Schritte Nach einer Zahl n soll n Mal der String untereinander ausgegeben werden Java Basics - Anfänger-Themen 3
G zwei Instanzen einer Klasse Java Basics - Anfänger-Themen 29
sserio Prüfziffer einer ISBN Nummer herrausfinden. Java Basics - Anfänger-Themen 14
J Benennung einer mir unbekannten Java - Ausdrucksweise Java Basics - Anfänger-Themen 5
LFB In einer For-Schleife alles in einer Zeile ausgeben Java Basics - Anfänger-Themen 14
sserio Wie kann man nach einer Klasse fragen? Java Basics - Anfänger-Themen 12
berserkerdq2 Wann soll ich den Stream schließen, wenn ich das in einer Methode habe? Java Basics - Anfänger-Themen 8
berserkerdq2 Wie gebe ich den Pfad zu einer Datei an, die in einem Ordner in Eclipse ist? Java Basics - Anfänger-Themen 1
M Variable in einer Schleife initialisieren Java Basics - Anfänger-Themen 46
D EinMalEins mithilfe einer for-Schleife und Array Java Basics - Anfänger-Themen 1
J int innerhalb einer Datei ändern Java Basics - Anfänger-Themen 1
D Hilfe bei einer Aufgabe mit for-Schleife Java Basics - Anfänger-Themen 6
Neuling47 Ich zerbreche mit den kopf an einer Aufgabe Java Basics - Anfänger-Themen 61
H Mit setter-Methode JLabel in einer andern Klasse ändern. Java Basics - Anfänger-Themen 40
J Zelleninhalt einer Jtable löschen Java Basics - Anfänger-Themen 2
Robert_Klaus Hamster java Simulation Hilfe bei einer Aufgabe Java Basics - Anfänger-Themen 5
stormyark 4 Bit in einer for-schleife funktioniert nicht Java Basics - Anfänger-Themen 3
F Werte in einer Arraylist Zählen Java Basics - Anfänger-Themen 2
M ArrayList mit einer Schleife befüllen Java Basics - Anfänger-Themen 2
A Ein Array bearbeiten und in einer anderen Methode nutzen Java Basics - Anfänger-Themen 6
A Ergebnis einer Methode bei einer anderen verwenden Java Basics - Anfänger-Themen 13
I Interface von einer EJB Klasse, um Code zu reduzieren Java Basics - Anfänger-Themen 1
M Interface als Parameter einer Klasse Java Basics - Anfänger-Themen 8
I Liste von Infos von einer eigenen Annotation in Liste speichern Java Basics - Anfänger-Themen 0
M Wie kann ich den Index i von einer LinkedList überprüfen? Java Basics - Anfänger-Themen 36
M Wie kann die Implementation einer Methode den Wert eines Attributs vermindern? Java Basics - Anfänger-Themen 3
M Wie verknüpfe ich eine Bedingung mit einer Methode ohne if-Verzweigung & Bedingungsoperator? Java Basics - Anfänger-Themen 2
P Doppelte werte in einer Liste zählen Java Basics - Anfänger-Themen 11
javapingu Jeglichen Inhalt einer Textdatei nach Zeile n löschen Java Basics - Anfänger-Themen 8
D mehrere Berechnungen in einer Methode Java Basics - Anfänger-Themen 9
P Iterieren mit einer Foreach in Lambdaschreibweise und Counter. Java Basics - Anfänger-Themen 1
M Methoden Wert einer Variable geht verloren? Java Basics - Anfänger-Themen 6
W Wie ziehe ich von einer bestimmten Zahl, Zahlen ab, bis mein Ergebnis null beträgt? Java Basics - Anfänger-Themen 10
X Was ist der Unterschied zwischen materialisierten und nichtmaterialisierten Attributen einer Klasse? Java Basics - Anfänger-Themen 1
U Wie ein Attribut von einer Klassenmethode in der Klasse speichern= Java Basics - Anfänger-Themen 2
M Wie richte ich eine Diagonale an Robotern in einer World ein? Java Basics - Anfänger-Themen 15
YAZZ BlueJ Bewegung einer Figur im Kreis Java Basics - Anfänger-Themen 4
O Ich habe einen String und soll mit matches schauen, ob ein Buchstabe zu einer geraden ANzahl im String vorkommt, wie soll das gehen? Java Basics - Anfänger-Themen 7
A Verarbeiten einer Excel Datei durch das java-Programm Java Basics - Anfänger-Themen 3
B GUI extension mit einer Liste verbinden Java Basics - Anfänger-Themen 1
O Wie erstelle ich eine Instanz in einer Klasse für die ich die Instanz will? Java Basics - Anfänger-Themen 4
S Hilfe bei Programmierung einer Hotelabrechnung Java Basics - Anfänger-Themen 5
W Verschiedene Methoden in einer Klasse in der Main aufrufen? Java Basics - Anfänger-Themen 8

Ähnliche Java Themen

Neue Themen


Oben