java - Spring、Hibernate 检查我的 Maven Shade JAR 中的每个 jar

标签 java spring hibernate maven maven-shade-plugin

当从 java -jar foo.jar 运行我的 jar 时,会出现数千条这样的行,因此应用程序至少需要 1 分钟才能启动。

2012-10-04 09:31:56,543 [AWT-EventQueue-0] DEBUG org.hibernate.ejb.packaging.AbstractJarVisitor - Filtering: org.springframework.context.annotation.DependsOn
2012-10-04 09:31:56,546 [AWT-EventQueue-0] DEBUG org.hibernate.ejb.packaging.AbstractJarVisitor - Filtering: org.springframework.context.annotation.EnableAspectJAutoProxy
2012-10-04 09:31:56,548 [AWT-EventQueue-0] DEBUG org.hibernate.ejb.packaging.AbstractJarVisitor - Filtering: org.springframework.context.annotation.EnableLoadTimeWeaving$AspectJWeaving
2012-10-04 09:31:56,553 [AWT-EventQueue-0] DEBUG org.hibernate.ejb.packaging.AbstractJarVisitor - Filtering: org.springframework.context.annotation.EnableLoadTimeWeaving
2012-10-04 09:31:56,558 [AWT-EventQueue-0] DEBUG org.hibernate.ejb.packaging.AbstractJarVisitor - Filtering: org.springframework.context.annotation.FilterType
2012-10-04 09:31:56,561 [AWT-EventQueue-0] DEBUG org.hibernate.ejb.packaging.AbstractJarVisitor - Filtering: org.springframework.context.annotation.Import
2012-10-04 09:31:56,563 [AWT-EventQueue-0] DEBUG org.hibernate.ejb.packaging.AbstractJarVisitor - Filtering: org.springframework.context.annotation.ImportAware
2012-10-04 09:31:56,567 [AWT-EventQueue-0] DEBUG org.hibernate.ejb.packaging.AbstractJarVisitor - Filtering: org.springframework.context.annotation.ImportBeanDefinitionRegistrar
2012-10-04 09:31:56,571 [AWT-EventQueue-0] DEBUG org.hibernate.ejb.packaging.AbstractJarVisitor - Filtering: org.springframework.context.annotation.ImportResource
2012-10-04 09:31:56,575 [AWT-EventQueue-0] DEBUG org.hibernate.ejb.packaging.AbstractJarVisitor - Filtering: org.springframework.context.annotation.ImportSelector
2012-10-04 09:31:56,578 [AWT-EventQueue-0] DEBUG org.hibernate.ejb.packaging.AbstractJarVisitor - Filtering: org.springframework.context.annotation.Jsr330ScopeMetadataResolver
2012-10-04 09:31:56,581 [AWT-EventQueue-0] DEBUG org.hibernate.ejb.packaging.AbstractJarVisitor - Filtering: org.springframework.context.annotation.Lazy
2012-10-04 09:31:56,585 [AWT-EventQueue-0] DEBUG org.hibernate.ejb.packaging.AbstractJarVisitor - Filtering: org.springframework.context.annotation.LoadTimeWeavingConfiguration
2012-10-04 09:31:56,589 [AWT-EventQueue-0] DEBUG org.hibernate.ejb.packaging.AbstractJarVisitor - Filtering: org.springframework.context.annotation.LoadTimeWeavingConfigurer
2012-10-04 09:31:56,593 [AWT-EventQueue-0] DEBUG org.hibernate.ejb.packaging.AbstractJarVisitor - Filtering: org.springframework.context.annotation.MetadataUtils
2012-10-04 09:31:56,596 [AWT-EventQueue-0] DEBUG org.hibernate.ejb.packaging.AbstractJarVisitor - Filtering: org.springframework.context.annotation.Primary

我正在使用 Maven Shade 创建 JAR:

<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-shade-plugin</artifactId>
<version>2.0</version>

Spring 和 Hibernate 配置:

<bean id="entityManagerFactory" 
      class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
  <property name="dataSource" ref="dataSource"/>
</bean>
<bean id="transactionManager"
      class="org.springframework.orm.jpa.JpaTransactionManager">
  <property name="entityManagerFactory" ref="entityManagerFactory"/>
</bean>
<tx:annotation-driven transaction-manager="transactionManager"/>

如何过滤它以不搜索 POM 下载的所有 JAR?

编辑:

完整的 Spring 配置:

<beans xmlns="http://www.springframework.org/schema/beans"
   xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
   xmlns:context="http://www.springframework.org/schema/context"
   xmlns:tx="http://www.springframework.org/schema/tx"
   xsi:schemaLocation="http://www.springframework.org/schema/beans
    http://www.springframework.org/schema/beans/spring-beans-3.1.xsd
    http://www.springframework.org/schema/context
    http://www.springframework.org/schema/context/spring-context-3.1.xsd
    http://www.springframework.org/schema/tx
    http://www.springframework.org/schema/tx/spring-tx-3.1.xsd">

<context:component-scan base-package="my.foo.bar" />

<context:property-placeholder location="classpath:/config/database.properties"/>

<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
    <property name="driverClassName" value="${database.driverClassName}"/>
    <property name="url" value="${database.url}"/>
    <property name="username" value="${database.username}"/>
    <property name="password" value="${database.password}"/>
</bean>

<bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
    <property name="dataSource" ref="dataSource"/>
</bean>
<bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager">
    <property name="entityManagerFactory" ref="entityManagerFactory"/>
</bean>
<tx:annotation-driven transaction-manager="transactionManager"/>

完全坚持:

 <?xml version="1.0" encoding="UTF-8" standalone="no"?>
<persistence xmlns="http://java.sun.com/xml/ns/persistence"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_1_0.xsd"
         version="1.0">
<persistence-unit name="persistenceUnit">
    <provider>org.hibernate.ejb.HibernatePersistence</provider>
    <properties>
        <property name="hibernate.dialect" value="dialect.ImprovedH2Dialect"/>
        <property name="hibernate.default_schema" value="ags" />
        <property name="hibernate.show_sql" value="true"/>
        <!-- value="create" to build a new database on each run; value="update" to modify an existing database; value="create-drop" means the same as "create" but also drops tables when Hibernate closes; value="validate" makes no changes to the database -->
        <property name="hibernate.hbm2ddl.auto" value="create"/>
        <property name="hibernate.ejb.naming_strategy" value="org.hibernate.cfg.ImprovedNamingStrategy"/>
        <property name="hibernate.connection.charSet" value="UTF-8"/>
    </properties>
</persistence-unit>

最佳答案

您需要调整persistence.xml中的一些设置,添加:

<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<persistence xmlns="http://java.sun.com/xml/ns/persistence"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_1_0.xsd"
         version="1.0">
<persistence-unit name="persistenceUnit">
    <provider>org.hibernate.ejb.HibernatePersistence</provider>
    <class>my.foo.bar</class>
    <exclude-unlisted-classes>true</exclude-unlisted-classes>
    <properties>
        <property name="hibernate.dialect" value="dialect.ImprovedH2Dialect"/>
        <property name="hibernate.default_schema" value="ags" />
        <property name="hibernate.show_sql" value="true"/>
        <!-- value="create" to build a new database on each run; value="update" to modify an existing database; value="create-drop" means the same as "create" but also drops tables when Hibernate closes; value="validate" makes no changes to the database -->
        <property name="hibernate.hbm2ddl.auto" value="create"/>
        <property name="hibernate.ejb.naming_strategy" value="org.hibernate.cfg.ImprovedNamingStrategy"/>
        <property name="hibernate.connection.charSet" value="UTF-8"/>
    </properties>
</persistence-unit> 

并指定所有实体类。

参见http://docs.jboss.org/hibernate/entitymanager/3.6/reference/en/html/configuration.html

关于java - Spring、Hibernate 检查我的 Maven Shade JAR 中的每个 jar,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12721623/

相关文章:

sql - 使用GORM在Grails中使用一对多引用有效地检索对象

java - 如何使用H2和JPA创建数据库备份?

java - 具有条件内容的绑定(bind)标签?

java - Spring MVC - 找不到元素 'mvc:annotation-drive' 的声明

适用于 Android ADB 的 Java 库

java - 为持久性注释继承的属性

java - 获取@Scheduled内的fixedDelay值

hibernate - 在合并值中执行@Formula

java - 如何从 java 中的 html 获取特定值?

java - 如何使用 Selenium 网格使用远程计算机节点浏览器直接将文件下载到我的集线器计算机(我的项目代码工作区所在的位置)?