`
maiguang
  • 浏览: 262416 次
  • 性别: Icon_minigender_1
  • 来自: 焦作
社区版块
存档分类
最新评论

C3P0 pools 使用中的一个问题解决

阅读更多
新开发的一个网站,每天早上来开就有访问数据库的操作就出现异常,数据库为Mysql。也就是说在运行中每个一段长的空闲时间就出现异常,异常为:
异常代码
** BEGIN NESTED EXCEPTION **

com.mysql.jdbc.CommunicationsException
MESSAGE: Communications link failure due to underlying exception:

** BEGIN NESTED EXCEPTION **

java.net.SocketException
MESSAGE: Software caused connection abort: socket write error

STACKTRACE:

java.net.SocketException: Software caused connection abort: socket write error
at java.net.SocketOutputStream.socketWrite0(Native Method)
at java.net.SocketOutputStream.socketWrite(SocketOutputStream.java:92)
at java.net.SocketOutputStream.write(SocketOutputStream.java:136)
at java.io.BufferedOutputStream.flushBuffer(BufferedOutputStream.java:65)
at java.io.BufferedOutputStream.flush(BufferedOutputStream.java:123)
at com.mysql.jdbc.MysqlIO.send(MysqlIO.java:2590)
at com.mysql.jdbc.MysqlIO.send(MysqlIO.java:2523)
at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:1517)
at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:1626)
at com.mysql.jdbc.Connection.execSQL(Connection.java:3031)
at com.mysql.jdbc.PreparedStatement.executeInternal(PreparedStatement.java:943)
at com.mysql.jdbc.PreparedStatement.executeQuery(PreparedStatement.java:1049)
at org.hibernate.jdbc.AbstractBatcher.getResultSet(AbstractBatcher.java:139)
at org.hibernate.loader.Loader.getResultSet(Loader.java:1669)
at org.hibernate.loader.Loader.doQuery(Loader.java:662)
at org.hibernate.loader.Loader.doQueryAndInitializeNonLazyCollections(Loader.java:224)
at org.hibernate.loader.Loader.doList(Loader.java:2145)
at org.hibernate.loader.Loader.listIgnoreQueryCache(Loader.java:2029)
at org.hibernate.loader.Loader.list(Loader.java:2024)
at org.hibernate.loader.hql.QueryLoader.list(QueryLoader.java:375)
at org.hibernate.hql.ast.QueryTranslatorImpl.list(QueryTranslatorImpl.java:308)
at org.hibernate.engine.query.HQLQueryPlan.performList(HQLQueryPlan.java:153)
at org.hibernate.impl.SessionImpl.list(SessionImpl.java:1106)
at org.hibernate.impl.QueryImpl.list(QueryImpl.java:79)
at org.hibernate.hopeDAO.StudentDBentity.findStudent(StudentDBentity.java:75)
at com.hope.student.action.StudentAction.execute(StudentAction.java:483)
at org.apache.struts.action.RequestProcessor.processActionPerform(RequestProcessor.java:419)
at org.apache.struts.action.RequestProcessor.process(RequestProcessor.java:224)
at org.apache.struts.action.ActionServlet.process(ActionServlet.java:1194)
at org.apache.struts.action.ActionServlet.doPost(ActionServlet.java:432)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:710)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:803)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:230)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:175)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:128)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:104)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:261)
at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:844)
at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:581)
at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:447)
at java.lang.Thread.run(Thread.java:595)


** END NESTED EXCEPTION **



Last packet sent to the server was 1 ms ago.

STACKTRACE:

com.mysql.jdbc.CommunicationsException: Communications link failure due to underlying exception:
查看了Mysql的文档,以及Connector/J的文档以及在线说明发现,出现这种异常的原因是:Mysql服务器默认的“wait_timeout”是8小时,也就是说一个connection空闲超过8个小时,Mysql将自动断开该 connection。这就是问题的所在,在C3P0 pools中的connections如果空闲超过8小时,Mysql将其断开,而C3P0并不知道该connection已经失效,如果这时有 Client请求connection,C3P0将该失效的Connection提供给Client,将会造成上面的异常。
解决的方法有3种:
1.增加wait_timeout的时间。
2.减少Connection pools中connection的lifetime。
3.测试Connection pools中connection的有效性。
当然最好的办法是同时综合使用上述3种方法,下面就对hibernate使用C3P0分别做一说明,假设wait_timeout为默认的8小时。
?
Hibernate使用C3P0的连接池,并队c3p0配置。
1.导入c3p0.jar包,hibernate自带的包,也可以在网上下载一个。
2.Hibernate的配置文件,hibernate.cfg.xml中增加:
<property name="c3p0.acquire_increment">1</property>
????????????? <property name="c3p0.idle_test_period">100</property>
????????????? <property name="c3p0.max_size">5</property>
<property name="c3p0.max_statements">0</property>
????????????? <property name="c3p0.min_size">2</property>
?????? ?????? <property name="c3p0.timeout">90</property>
????????????? <property name="c3p0.preferredTestQuery ">select 1 from user where id=1</property>
????????????? <property name="c3p0.idleConnectionTestPeriod ">18000</property>???????????
<property name="c3p0.maxIdleTime">25000</property>????????
<property name="c3p0.testConnectionOnCheckout">true</property>
3.重新启动tomcat,问题解决。
分享到:
评论
2 楼 tianmingqi 2009-01-10  
干脆放在我邮箱里吧,
403668225@qq.com
我真的很急用,先谢谢大侠了,麻烦你!
1 楼 tianmingqi 2009-01-10  
老大你再写一下吧,你的第二步2.Hibernate的配置文件,hibernate.cfg.xml中增加的内容为乱码,我现在也遇到了这个问题,急等用啊,在线=

相关推荐

    android.support.v4.util.Pools使用

    在`PoolsDemo`项目中,我们可以看到如何在实际应用中使用`Pools`。通常,我们首先定义一个可池化的对象类,然后创建一个对象池实例,最后在需要创建或回收对象时调用相应的方法。例如,创建一个`MyObject`类,并使用...

    开源项目-c3mb0-go-do-work.zip

    开源项目-c3mb0-go-do-work.zip,go-do-work: Dynamically resizable pools of goroutines which can queue an infinite number of jobs

    Preverifier.rar_Pools

    在Java平台上,预验证器(Preverifier)是J2ME(Java Micro Edition)环境中的一个重要组件,主要用于处理CLDC(Connected Limited Device Configuration)和MIDP(Mobile Information Device Profile)应用。...

    pools.unitypackage

    自己写好的对象池,可以拿下来直接用,挺简单的哈,为什么要50个字的描述,能说清楚不久得了,希望改进XXXXXXXXXXXXXXXXXXXX

    CraftCode_2020华为_huaweicraft_pools3r_

    - cSource:这个文件名暗示可能包含C++源代码,可能是参赛者实现的一个特定功能模块或者完整的C++解决方案。 4. **算法设计**: - 在“huaweicraft_pools3r”这个任务中,参赛者可能需要使用到的基本算法包括但不...

    IBM DS8000存储中的Arrays,Ranks,Extent pools的概念.doc

    一个Rank可以被分配给一个或多个相同的Extent类型的Extent pool,但不能分配给多个不同的Extent pools。 总的来说,IBM DS8000通过Arrays、Ranks和Extent pools的设计,实现了高效的数据组织、冗余和性能优化,以...

    Java-ConnectionPools.rar_连接池

    2. **c3p0**:这是一个开源的JDBC连接池,由Maurice Priester创建。c3p0提供了连接测试、空闲连接检查等功能,同时支持JNDI集成。它允许开发者配置各种参数,如最小和最大连接数、初始连接数量、超时时间等。 3. **...

    Memory Pools V1.2

    通过阅读和分析这个文件,开发者可以了解Memory Pools V1.2的具体实现细节,包括其内部数据结构、分配策略以及如何在项目中集成和使用。为了充分利用这个库,开发者需要熟悉内存管理原理,并根据自己的项目需求进行...

    VC_Thread_Pools.rar_Pools_VC线程池_vc 多线程_多线程多任务_线程池

    线程池是多线程编程中的一个重要概念,它在现代软件开发中被广泛使用,特别是在高性能服务器和并发处理大量任务的场景中。本资源“VC_Thread_Pools.rar”提供了在VC++ 6.0环境下实现线程池的一个实例,帮助开发者...

    dhcpd-pools:ISC dhcpd租约使用情况分析-开源

    这是dhcpd-pools ISC dhcp共享网络和池范围使用情况的分析。 该命令的目的是计算ISC dhcpd控制的每个IP范围和共享网络池的使用率。 该命令的用户最有可能是具有较大IP空间的ISP和其他组织。 程序用C编写。设计目标是...

    ThreadPools

    线程池(ThreadPools)在C++编程中是一个重要的多线程管理工具,它能够有效地管理和调度线程资源,从而提高程序的执行效率和并发性能。本文将深入探讨线程池的概念、工作原理以及在C++中的实现。 线程池的概念: ...

    ThreadPoolWithCameraPreview, 在Android上,使用threadpools提高性能的演示.zip

    ThreadPoolWithCameraPreview, 在Android上,使用threadpools提高性能的演示 带相机预览的ThreadPool下载演示应用在 Google Play 上。项目演示了如何使用 HandlerThread s 和 ThreadPool s 在后台线程的android API...

    IIS-7.5版本中一些诡异问题的解决方案

    以上四个问题都是IIS 7.5使用过程中可能会遇到的典型问题,通过正确配置IIS和应用设置,可以有效地解决这些问题,确保服务的正常运行。在进行任何配置更改之前,请记得备份当前的设置,以防止意外情况发生,并确保在...

    mem poolsmem pools

    2. 分配内存:当程序需要小块内存时,它从内存池中申请一个已分割好的固定大小的内存块。由于内存池中的块已经预分配,所以这个过程比常规的内存分配更快。 3. 回收内存:当不再需要某块内存时,程序将其归还给内存...

    ion_system_heap.rar_Pools

    uncached pages come the page pools, zero them before returning for security purposes (other allocations are zerod at alloc time.

    JAVA操作数据库方式与设计模式应用.txt

    注意,在实际应用中,通常会使用成熟的连接池库(如HikariCP、C3P0等),这些库提供了更强大的功能和更好的性能。 综上所述,通过使用JDBC和上述设计模式,我们可以有效地管理和操作数据库,同时提高程序的可维护性...

    DBCP数据库连接池.pdf

    DBCP(Database Connection Pool)是Apache的一个开源项目Commons DBCP,它提供了一个数据库连接池的实现。...因此,在实际应用中,开发者可能还会考虑其他更现代的连接池实现,如HikariCP或C3P0。

    relint-ci-pools

    relint-ci-pools更新发布池该池用于更新发布管道,因此可以一次运行多个作业。 当前有4个,并且锁定文件本身包含元数据,该元数据将在cf-deployment-concourse-tasks中使用,以动态地针对正确的环境。 证书本身是...

    数据库连接池的例子数据库连接池的例子

    在实际应用中,有许多成熟的数据库连接池实现,例如 Apache 的 DBCP、C3P0、HikariCP 等,它们提供了更完善的功能,如连接健康检查、自动重连、连接超时处理等,提高了系统的稳定性和效率。开发人员可以根据项目需求...

    上传excel到SAP内表.doc

    TYPE-POOLS语句用于定义一个类型池,类型池是ABAP语言中的一个概念,用于存储数据类型和变量的定义。在本例中,TYPE-POOLS语句用于定义一个类型池,并在其中定义了一个结构体t_datatab,该结构体包含了三个字段:col...

Global site tag (gtag.js) - Google Analytics