如何在wildfly 10 standalone.xml中定义hibernate.c3p0连接池

时间:2016-11-30 12:08:56

标签: java mysql hibernate jpa wildfly

我有一个问题是在长时间空闲时间后与Mysql DB连接丢失,即我得到不同类型的错误,包括"最大数据包允许大小"错误,"最后一个数据包收到8499970毫秒前"错误等 我正在使用Hibernate-JPA和JPA版本2.0

目前Wildfly standalone.xml中的数据源配置为:

<datasources>

                <datasource jndi-name="java:/MySQLDS" pool-name="MySQLDS" enabled="true" use-java-context="true">
                    <connection-url>jdbc:mysql://localhost:3306/opera</connection-url>
                    <driver>mysqlDriver</driver>
                    <security>
                        <user-name>admin</user-name>
                        <password>admin</password>
                    </security>
                </datasource>
                <drivers>

                    <driver name="mysqlDriver" module="com.mysql">
                        <xa-datasource-class>com.mysql.jdbc.Driver</xa-datasource-class>
                    </driver>
                </drivers>
            </datasources>

persistence.xml文件看起来像这样:

 <persistence version="2.0"
        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_2_0.xsd">
        <persistence-unit name="metadatatool-persistence">
         <jta-data-source>java:/MySQLDS</jta-data-source>
            <provider>org.hibernate.ejb.HibernatePersistence</provider>
    <properties>
                <!-- Hibernate properties -->
                <property name="hibernate.show_sql" value="false" />
                <property name="hibernate.format_sql" value="false" />
                <property name="hibernate.dialect" value="org.hibernate.dialect.MySQLDialect" />


                <!-- Configuring Connection Pool -->
                <property name="hibernate.c3p0.min_size" value="5" />
                <property name="hibernate.c3p0.max_size" value="20" />
                <property name="hibernate.c3p0.timeout" value="600" />
                <property name="hibernate.c3p0.max_statements" value="2000" />
                <property name="hibernate.c3p0.idle_test_period" value="30" />
                <property name="hibernat.c3p0.automaticTestTable" value="conTestTable" />
            </properties>
    </persistence-unit>
    </persistence>

我已将c3p0-4.1.1-final Jar包含在我的项目中,但看起来它不起作用我在空闲时间后仍然没有连接错误,我无法一步一步找到正确的解决方案

修改

我在persistence.xml中定义了另一个属性我不知道它是否可行

<property name="hibernate.connection.url"
                value="jdbc:mysql://192.168.1.1:3306/opera?zeroDateTimeBehavior=convertToNull&amp;autoReconnect=true;reconnectAtTxEnd=true;autoReconnectForPools=true" />
        <property name="hibernate.connection.username" value="root" />

编辑更新 我使用了上面定义的属性,我现在没有得到连接错误,但我确实在下面的日志文件中发现了一个错误,部署工作正常

error is:  java.lang.IllegalStateException: UT000010: Session not found BDnAhOKBakcD8h9izG1Dembs0DFHWwWgYFVYPEKm

此属性中使用的连接字符串是否是正确的方法?我可以面对哪些副作用?

2 个答案:

答案 0 :(得分:2)

没有必要在任何完整的Java EE实现中配置您自己的连接池实现(例如c3po),例如WildFly / JBoss EAP,WebSphere,GlassFish等。

所有这些服务器都为您提供连接池实现和管理工具来配置它们。

在WildFly中,您可以在管理控制台中使用DataSource配置进行设置,也可以使用CLI。请参阅WildFly 10 DataSource configuration

您应该能够将persistence.xml缩减为:

<persistence version="2.0"
        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_2_0.xsd">
    <persistence-unit name="metadatatool-persistence">
        <jta-data-source>java:/MySQLDS</jta-data-source>
        <properties>
            <!-- Hibernate properties -->
            <property name="hibernate.show_sql" value="false" />
            <property name="hibernate.format_sql" value="false" />
        </properties>
    </persistence-unit>
</persistence>

为了方便起见,我在那里留下了SQL生成属性,尽管在false时始终不需要它们。

在此之后,您需要确保正确配置了DataSource。

<datasource jta="true" 
            jndi-name="java:/MySQLDS"
            pool-name="MySQLDS" enabled="true" use-ccm="true">
    <connection-url>jdbc:mysql://localhost:3306/opera</connection-url>
    <driver-class>com.mysql.jdbc.Driver</driver-class>
    <driver> mysqlDriver </driver>
    <security>
        <user-name>admin</user-name>
        <password>admin</password>
    </security>
    <validation>
        <valid-connection-checker
            class-name="org.jboss.jca.adapters.jdbc.extensions.mysql.MySQLValidConnectionChecker"/>
        <background-validation>true</background-validation>
        <exception-sorter
            class-name="org.jboss.jca.adapters.jdbc.extensions.mysql.MySQLExceptionSorter"/>
    </validation>
</datasource>

请注意您缺少的连接验证配置。当通过管理控制台设置DataSource时,这是免费添加的。

您不应该手动修改standalone.xml文件。

答案 1 :(得分:0)

这就是我通常做的事情:

<jee:jndi-lookup id="dataSource" jndi-name="java:/MySQLDS"/>

然后在持久化上下文中使用数据源:

 <property name="dataSource" ref="dataSource"/>

查看spring docs