我有一个问题是在长时间空闲时间后与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&autoReconnect=true;reconnectAtTxEnd=true;autoReconnectForPools=true" />
<property name="hibernate.connection.username" value="root" />
编辑更新 我使用了上面定义的属性,我现在没有得到连接错误,但我确实在下面的日志文件中发现了一个错误,部署工作正常
error is: java.lang.IllegalStateException: UT000010: Session not found BDnAhOKBakcD8h9izG1Dembs0DFHWwWgYFVYPEKm
此属性中使用的连接字符串是否是正确的方法?我可以面对哪些副作用?
答案 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"/>