Welche Gläser sollte ich in Java EE in das Bibliotheksverzeichnis stellen?

Ich habe ein Java EE-Projekt. Das Projekt wird mit maven in ein .ear-Archiv eingebaut. Es gibt ein Bibliotheksglas mit einer JPA 2-Persistenzeinheit, die sich im Bibliotheksverzeichnis des Ohrs befindet (so dass es von mehreren anderen Modulen verwendet werden kann).

Beim Hinzufügen einer Implementierung von Shiros Berechtigungsschnittstelle als Entität in dieser Persistenzeinheit hatte ich Probleme, das Ohr für eine korrekte Bereitstellung zu bewegen, da die Shiro-Klassen in der Persistenzeinheit nicht verfügbar waren. Irgendwann stellte sich heraus, dass ich alle Abhängigkeiten (die auch für transitive Abhängigkeiten gelten) des Bibliotheksglases im Bibliotheksverzeichnis ablegen musste, damit es bereitgestellt werden konnte.

Das endgültige Layout sieht also ungefähr so ​​aus:

ear
`- lib
   `- persistence-unit.jar
    - shiro-core.jar
    - slf4j-api.jar
 - module1
 - moduleN
 - library1.jar
 - libraryN.jar

Nun zu den Fragen:

Gibt es Richtlinien für das, was im Bibliotheksverzeichnis abgelegt werden soll, und ist meine Lösung im Allgemeinen akzeptabel?Warum stehen den Gläsern im lib-Verzeichnis die Bibliotheken im Stammverzeichnis des Ohrs nicht zur Verfügung?Warum findet maven das nicht automatisch heraus?

EDIT: pom.xml fürs Ohr

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <artifactId>ear</artifactId>
    <packaging>ear</packaging>

    <parent>
        <groupId>com.example</groupId>
        <artifactId>project</artifactId>
        <version>1.0-SNAPSHOT</version>
    </parent>

    <build>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-ear-plugin</artifactId>
                <version>2.7</version>
                <configuration>
                    <modules>
                        <webModule>
                            <!-- ... -->
                        </webModule>
                        <ejbModule>
                            <!-- ... -->
                        </ejbModule>
                        <jarModule>
                            <groupId>com.example</groupId>
                            <artifactId>persistence-unit</artifactId>
                            <bundleDir>lib</bundleDir>
                        </jarModule>

                        <-- I added these to get the deployment working -->
                        <jarModule>
                            <groupId>org.apache.shiro</groupId>
                            <artifactId>shiro-core</artifactId>
                            <bundleDir>lib</bundleDir>
                        </jarModule>
                        <jarModule>
                            <groupId>org.slf4j</groupId>
                            <artifactId>slf4j-api</artifactId>
                            <bundleDir>lib</bundleDir>
                        </jarModule>
                    </modules>
                </configuration>
            </plugin>
        </plugins>
    </build>

    <dependencies>
        <dependency>
            <groupId>com.example</groupId>
            <artifactId>persistence-unit</artifactId>
        </dependency>
        <dependency>
            <!-- ... -->
            <type>war</type>
        </dependency>
        <dependency>
            <!-- ... -->
            <type>ejb</type>
        </dependency>

        <dependency>
            <groupId>org.apache.shiro</groupId>
            <artifactId>shiro-core</artifactId>
        </dependency>
    </dependencies>
</project>

Und für die Persistenz-Einheit:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <artifactId>persistence-unit</artifactId>
    <packaging>jar</packaging>

    <parent>
        <groupId>com.example</groupId>
        <artifactId>project</artifactId>
        <version>1.0-SNAPSHOT</version>
    </parent>

    <dependencies>
        <dependency>
            <groupId>org.jboss.spec</groupId>
            <artifactId>jboss-javaee-6.0</artifactId>
            <type>pom</type>
            <scope>provided</scope>
        </dependency>
        <dependency>
            <groupId>org.apache.shiro</groupId>
            <artifactId>shiro-core</artifactId>
        </dependency>
    </dependencies>
</project>

Antworten auf die Frage(3)

Ihre Antwort auf die Frage