使用openJPA MySQL进行运行时优化时出现异常

4

关于这个问题可能有很多疑问,我已经阅读了一些,但是答案仍然让我困惑。我对JPA还很陌生,我只是想测试一个简单的应用程序,以查看是否可以正确配置。这是一个独立的应用程序,意味着它不会与Web服务器或其他任何东西一起运行。实体类如下:

@Entity
public class Person{

    @Id
    private String userID = null;

    @Transient
    private UserState userState = null;

    private String email = null;
    private String name = null;


    public Person(){
        userID = null;
        email = null;
        name = null;
        userState = null;
    }

    public String getUserID() {
        return userID;
    }

    public void setUserID(String userID) {
        this.userID = userID;
    }

    public String getEmail() {
        return email;
    }

    public void setEmail(String email) {
        this.email = email;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public UserState getUserState() {
        return userState;
    }

    public void setUserState(UserState userState) {
        this.userState = userState;
    }

}

主函数:

public class PersistenceTest {

    public static void main(String[] args) {
        System.out.println("creating person");
        Person p = new Person();
        p.setUserID("GregR");
        p.setEmail("Gregory@company.de");
        p.setUserState(UserState.ACTIVE);
        System.out.println("done creating person GregR");


        EntityManagerFactory factory = Persistence.createEntityManagerFactory(PersonService.PERSISTENCE_UNIT_NAME);
        System.out.println("factory initialized");
        EntityManager manager = factory.createEntityManager();
        System.out.println("EntityManager initialized");
        PersonService service = new PersonService(manager);
        System.out.println("service initialized");

        System.out.println("Beginning transaction");
        manager.getTransaction().begin();
        System.out.println("Transaction begun");

        System.out.println("attempting to persist person");
        service.persistEntity(p);
        manager.getTransaction().commit();
        System.out.println("person persisted");

        System.out.println("beginning cleanup");
        manager.close();
        factory.close();
        System.out.println("Cleanup has completed");
    }
}

配置:

<?xml version="1.0"?>
<persistence xmlns="http://java.sun.com/xml/ns/persistence" version="1.0">
    <persistence-unit name="PersonService" transaction-type="RESOURCE_LOCAL">
        <provider>org.apache.openjpa.persistence.PersistenceProviderImpl</provider>
        <class>de.hol.persistable.entities.Person</class>
        <properties>
            <property name="javax.persistence.jdbc.driver" value="com.mysql.jdbc.Driver"/>
            <property name="javax.persistence.jdbc.url" value="jdbc:mysql://localhost:3306/ConnectionWikisDB"/>
            <property name="javax.persistence.jdbc.user" value="GregR"/>
            <property name="javax.persistence.jdbc.password" value="myPassword"/>
        </properties>
    </persistence-unit>
</persistence>

控制台输出:
creating person
done creating person GReeder
factory initialized
47  PersonService  INFO   [main] openjpa.Runtime - Starting OpenJPA 2.3.0
110  PersonService  INFO   [main] openjpa.jdbc.JDBC - Using dictionary class "org.apache.openjpa.jdbc.sql.MySQLDictionary".
306  PersonService  INFO   [main] openjpa.jdbc.JDBC - Connected to MySQL version 5.5 using JDBC driver MySQL-AB JDBC Driver version mysql-connector-java-5.0.8 ( Revision: ${svn.Revision} ). 
Exception in thread "main" <openjpa-2.3.0-r422266:1540826 nonfatal user error> org.apache.openjpa.persistence.ArgumentException: This configuration disallows runtime optimization, but the following listed types were not enhanced at build time or at class load time with a javaagent: "
de.hol.persistable.entities.Person".
    at org.apache.openjpa.enhance.ManagedClassSubclasser.prepareUnenhancedClasses(ManagedClassSubclasser.java:115)
    at org.apache.openjpa.kernel.AbstractBrokerFactory.loadPersistentTypes(AbstractBrokerFactory.java:312)
    at org.apache.openjpa.kernel.AbstractBrokerFactory.initializeBroker(AbstractBrokerFactory.java:236)
    at org.apache.openjpa.kernel.AbstractBrokerFactory.newBroker(AbstractBrokerFactory.java:212)
    at org.apache.openjpa.kernel.DelegatingBrokerFactory.newBroker(DelegatingBrokerFactory.java:155)
    at org.apache.openjpa.persistence.EntityManagerFactoryImpl.createEntityManager(EntityManagerFactoryImpl.java:226)
    at org.apache.openjpa.persistence.EntityManagerFactoryImpl.createEntityManager(EntityManagerFactoryImpl.java:153)
    at org.apache.openjpa.persistence.EntityManagerFactoryImpl.createEntityManager(EntityManagerFactoryImpl.java:59)
    at de.hol.persistable.PersistenceTest.main(PersistenceTest.java:24)

我的问题
1. 我猜主要问题是,我做错了什么。我非常新手,试图让这个独立应用程序工作,以便我可以将其扩展为真正的实际使用。
2. 是否还有其他配置缺失除了persistence.xml文件?
3. 对于独立应用程序,解决此错误的最简单方法是什么?

提前致谢!


“Person”实体的包名是什么? - Zaw Than oo
为了这篇文章,我必须对其进行匿名处理。我确信persistance.xml文件中的完整类名是正确的。我的服务类与实体类不在同一个包中。它们分别位于de.hol.hct.persistable.entities.*和de.hol.hct.persistable.services.*,其中服务类是具有crud细节的类。 - Greg
所以你还没有对那个类进行字节码增强。 - Neil Stockton
您需要使用javaagent在构建时间或运行时增强您的类。我建议您查看此链接:http://openjpa.apache.org/entity-enhancement.html - Magic Wand
奇怪。我无法重现它,因为我在 http://openjpa.apache.org/builds/2.3.0/apache-openjpa/docs/ref_guide_pc_enhance.html#ref_guide_pc_enhance_dynamic 上,没有使用增强器。你使用的 JVM 版本是什么? - zbig
1
Java版本“1.7.0_45” Java(TM) SE Runtime Environment(版本1.7.0_45-b18) Java HotSpot(TM) 64位服务器虚拟机(版本24.45-b08,混合模式)- 但是一旦我添加了javaagent配置,它就可以正常运行。 - Greg
3个回答

7

我看到你有主类,因此我假设你在Java SE环境中使用它。使其正常工作的最简单方法是在命令行中定义-javaagent,像这样:

java -jar myJAR.jar -javaagent:openjpa-all-2.3.0.jar

也可以通过Eclipse实现:运行->运行配置->在“Java应用程序”中找到您的应用程序->参数->VM参数->添加
-javaagent:/full/path/to/openjpa-all-2.3.0.jar

有没有一种方法可以在Eclipse中进行配置,以便自动设置为使用此javaagent,从而允许从IDE中使用“运行”和“调试”按钮? - Greg
非常感谢!我仍然遇到异常,但至少那个问题已经解决了! - Greg

0

通过检查[ManagedClassSubclasser]1代码,您可以看到这更像是一个警告。如果您想消除此异常并记录警告,请执行以下操作:

<property name="openjpa.RuntimeUnenhancedClasses" value="warn"/>

不幸的是,这只是将问题推迟了几行,因为该类没有增强。 - Greg

0

我想分享一下我遇到类似问题时的经验。如果你正在使用Tomcat,它并没有完全实现OpenJPA的规范,你需要单独提供增强功能。关于增强功能,请按照此链接上的说明进行操作http://openjpa.apache.org/enhancement-with-eclipse.html。这样就可以解决问题了。 注意:我知道你没有使用任何服务器,但是如果你想使用Tomcat,那么你需要按照链接中的步骤进行操作。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接