`

C3P0连接池详细配置

    博客分类:
  • Java
阅读更多
<c3p0-config>
    <default-config>
<!--当连接池中的连接耗尽的时候c3p0一次同时获取的连接数。Default: 3 -->
<property name="acquireIncrement">3</property>
   
<!--定义在从数据库获取新连接失败后重复尝试的次数。Default: 30 -->
<property name="acquireRetryAttempts">30</property>
   
<!--两次连接中间隔时间,单位毫秒。Default: 1000 -->
<property name="acquireRetryDelay">1000</property>
   
<!--连接关闭时默认将所有未提交的操作回滚。Default: false -->
<property name="autoCommitOnClose">false</property>
   
<!--c3p0将建一张名为Test的空表,并使用其自带的查询语句进行测试。如果定义了这个参数那么
     属性preferredTestQuery将被忽略。你不能在这张Test表上进行任何操作,它将只供c3p0测试
     使用。Default: null-->
<property name="automaticTestTable">Test</property>

<!--获取连接失败将会引起所有等待连接池来获取连接的线程抛出异常。但是数据源仍有效
     保留,并在下次调用getConnection()的时候继续尝试获取连接。如果设为true,那么在尝试
     获取连接失败后该数据源将申明已断开并永久关闭。Default: false-->
<property name="breakAfterAcquireFailure">false</property>

<!--当连接池用完时客户端调用getConnection()后等待获取新连接的时间,超时后将抛出
     SQLException,如设为0则无限期等待。单位毫秒。Default: 0 -->
<property name="checkoutTimeout">100</property>

<!--通过实现ConnectionTester或QueryConnectionTester的类来测试连接。类名需制定全路径。
     Default: com.mchange.v2.c3p0.impl.DefaultConnectionTester-->
<property name="connectionTesterClassName"></property>

<!--指定c3p0 libraries的路径,如果(通常都是这样)在本地即可获得那么无需设置,默认null即可
     Default: null-->
<property name="factoryClassLocation">null</property>

<!--Strongly disrecommended. Setting this to true may lead to subtle and bizarre bugs.   
     (文档原文)作者强烈建议不使用的一个属性-->
<property name="forceIgnoreUnresolvedTransactions">false</property>

<!--每60秒检查所有连接池中的空闲连接。Default: 0 -->
<property name="idleConnectionTestPeriod">60</property>

<!--初始化时获取三个连接,取值应在minPoolSize与maxPoolSize之间。Default: 3 -->
<property name="initialPoolSize">3</property>
   
<!--最大空闲时间,60秒内未使用则连接被丢弃。若为0则永不丢弃。Default: 0 -->
<property name="maxIdleTime">60</property>
   
<!--连接池中保留的最大连接数。Default: 15 -->
<property name="maxPoolSize">15</property>
   
<!--JDBC的标准参数,用以控制数据源内加载的PreparedStatements数量。但由于预缓存的statements
     属于单个connection而不是整个连接池。所以设置这个参数需要考虑到多方面的因素。
     如果maxStatements与maxStatementsPerConnection均为0,则缓存被关闭。Default: 0-->
<property name="maxStatements">100</property>
   
<!--maxStatementsPerConnection定义了连接池内单个连接所拥有的最大缓存statements数。Default: 0    -->
<property name="maxStatementsPerConnection"></property>

<!--c3p0是异步操作的,缓慢的JDBC操作通过帮助进程完成。扩展这些操作可以有效的提升性能
     通过多线程实现多个操作同时被执行。Default: 3-->
<property name="numHelperThreads">3</property>

<!--当用户调用getConnection()时使root用户成为去获取连接的用户。主要用于连接池连接非c3p0
     的数据源时。Default: null-->
<property name="overrideDefaultUser">root</property>
   
<!--与overrideDefaultUser参数对应使用的一个参数。Default: null-->
<property name="overrideDefaultPassword">password</property>

<!--密码。Default: null-->
<property name="password"></property>

<!--定义所有连接测试都执行的测试语句。在使用连接测试的情况下这个一显著提高测试速度。注意:
     测试的表必须在初始数据源的时候就存在。Default: null-->
<property name="preferredTestQuery">select id from test where id=1</property>

<!--用户修改系统配置参数执行前最多等待300秒。Default: 300 -->
<property name="propertyCycle">300</property>
   
<!--因性能消耗大请只在需要的时候使用它。如果设为true那么在每个connection提交的
     时候都将校验其有效性。建议使用idleConnectionTestPeriod或automaticTestTable
     等方法来提升连接测试的性能。Default: false -->
<property name="testConnectionOnCheckout">false</property>
   
<!--如果设为true那么在取得连接的同时将校验连接的有效性。Default: false -->
<property name="testConnectionOnCheckin">true</property>

<!--用户名。Default: null-->
<property name="user">root</property>

<!--早期的c3p0版本对JDBC接口采用动态反射代理。在早期版本用途广泛的情况下这个参数
     允许用户恢复到动态反射代理以解决不稳定的故障。最新的非反射代理更快并且已经开始
     广泛的被使用,所以这个参数未必有用。现在原先的动态反射与新的非反射代理同时受到
     支持,但今后可能的版本可能不支持动态反射代理。Default: false-->
<property name="usesTraditionalReflectiveProxies">false</property>

        <property name="automaticTestTable">con_test</property>
        <property name="checkoutTimeout">30000</property>
        <property name="idleConnectionTestPeriod">30</property>
        <property name="initialPoolSize">10</property>
        <property name="maxIdleTime">30</property>
        <property name="maxPoolSize">25</property>
        <property name="minPoolSize">10</property>
        <property name="maxStatements">0</property>
        <user-overrides user="swaldman">
        </user-overrides>
    </default-config>
    <named-config name="dumbTestConfig">
        <property name="maxStatements">200</property>
        <user-overrides user="poop">
            <property name="maxStatements">300</property>
        </user-overrides>
     </named-config>
</c3p0-config>
分享到:
评论

相关推荐

    scratch少儿编程逻辑思维游戏源码-滚动城市.zip

    scratch少儿编程逻辑思维游戏源码-滚动城市.zip

    scratch少儿编程逻辑思维游戏源码-幻想勇士.zip

    scratch少儿编程逻辑思维游戏源码-幻想勇士.zip

    scratch少儿编程逻辑思维游戏源码-火柴人地底冒险.zip

    scratch少儿编程逻辑思维游戏源码-火柴人地底冒险.zip

    scratch少儿编程逻辑思维游戏源码-僵尸逃亡.zip

    scratch少儿编程逻辑思维游戏源码-僵尸逃亡.zip

    MATLAB导热计算:一维/二维全显、全隐及半隐格式的导热算例及迭代方法解析

    内容概要:本文介绍了使用MATLAB进行一维和二维导热计算的各种格式及其迭代方法。首先,针对一维导热问题,分别讲解了全显格式、全隐格式和半隐格式的基本原理和实现步骤。接着,对于二维导热问题,不仅涵盖了全显和全隐格式的应用,还深入探讨了隐式格式下常用的迭代方法,如ADI迭代、点迭代和高斯-赛德点迭代(GS)。此外,文中强调了如何自定义导热几何距离和边界条件,使用户能够灵活应对不同应用场景的需求。最后,提醒使用者在编写代码时要注意算法的稳定性和准确性。 适合人群:对导热计算感兴趣的科研工作者、工程师及高校学生。 使用场景及目标:①掌握MATLAB在一维和二维导热计算中的多种格式和迭代方法;②学会根据实际需求设定导热几何距离和边界条件;③提高对导热问题的理解和解决能力。 其他说明:本文提供的代码片段为示意性质,具体实现还需参考相关文献或MATLAB官方文档。

    容器技术Docker教程与项目资源精选:涵盖安装配置、实战项目及性能优化指南

    内容概要:本文档为2025年最新的Docker教程与项目资源精选,分为四个部分。第一部分介绍入门教程与核心概念,包括多平台安装指南、核心概念解析以及常用命令速查,如容器管理、镜像操作等。第二部分聚焦实战项目与高阶应用,涵盖单服务部署(如MySQL快速部署、Redis集群搭建)、多容器编排(如WordPress部署、微服务架构)。第三部分提供资源导航与工具推荐,列举官方文档、社区教程、离线镜像包、私有仓库搭建等学习资源和实用工具。第四部分给出避坑指南与最佳实践,针对常见问题(如端口冲突处理、时区同步)和性能优化(如资源限制、镜像精简)提出解决方案。; 适合人群:对Docker感兴趣的初学者以及有一定经验的研发人员。; 使用场景及目标:①掌握Docker的基础安装与配置,理解核心概念;②通过实战项目提升技能,如单服务部署、多容器编排等;③利用提供的资源和工具深入学习并解决实际问题,优化Docker使用体验。; 阅读建议:读者应按照文档结构逐步学习,先掌握基础概念和命令,再尝试实战项目,最后结合避坑指南和最佳实践进行优化。同时,可以参考推荐的学习资源和工具,加深理解和应用。

    少儿编程scratch项目源代码文件案例素材-雨林跑酷.zip

    少儿编程scratch项目源代码文件案例素材-雨林跑酷.zip

    scratch少儿编程逻辑思维游戏源码-火柴人冒险记.zip

    scratch少儿编程逻辑思维游戏源码-火柴人冒险记.zip

    scratch少儿编程逻辑思维游戏源码-极限跳跳.zip

    scratch少儿编程逻辑思维游戏源码-极限跳跳.zip

    少儿编程scratch项目源代码文件案例素材-土豆兄弟.zip

    少儿编程scratch项目源代码文件案例素材-土豆兄弟.zip

    S7-200 PLC与MCGS组态在温度及加热控制系统设计中的应用

    内容概要:本文详细介绍了基于S7-200 PLC和MCGS组态软件的温度控制系统及其加热控制设计。首先阐述了项目背景和重要性,接着分别介绍了S7-200 PLC的强大特性和广泛应用,以及MCGS组态软件的功能特点。随后重点讲解了温度控制系统的具体设计流程,包括传感器数据采集、PLC逻辑控制和MCGS界面显示三个关键步骤。最后展示了简化的S7-200 PLC梯形图代码片段,用以说明加热过程的具体控制方法。通过这套系统,实现了高效、精准的温度管理,显著提升了工业生产的质量和效率。 适合人群:从事工业自动化领域的工程师和技术人员,尤其是那些希望深入了解PLC编程和组态软件应用的专业人士。 使用场景及目标:适用于需要高精度温度控制的各种工业场合,如化工、食品加工等行业。目标在于帮助用户掌握利用S7-200 PLC和MCGS组态软件构建稳定可靠的温度控制系统的方法。 其他说明:文中提供的案例和代码片段有助于读者更好地理解和实践相关技术,为实际工程项目提供有价值的参考。

    2024安全行业大模型技术应用态势发展报告-中国通信标准化协会.pdf

    2024安全行业大模型技术应用态势发展报告-中国通信标准化协会

    scratch少儿编程逻辑思维游戏源码-姜饼人.zip

    scratch少儿编程逻辑思维游戏源码-姜饼人.zip

    scratch少儿编程逻辑思维游戏源码-飞翔投篮.zip

    scratch少儿编程逻辑思维游戏源码-飞翔投篮.zip

    少儿编程scratch项目源代码文件案例素材-五月的花.zip

    少儿编程scratch项目源代码文件案例素材-五月的花.zip

    PFC5.02D煤层开挖案例分析:分步开挖实施与效果提升

    内容概要:本文详细介绍了PFC5.02D软件平台下煤层开挖的分步实施方法及其效果。文章首先概述了PFC5.02D作为专业岩石力学分析软件在煤层开挖中的重要性,然后逐步讲解了从前期准备到最终完成开挖的具体操作流程,包括初步开挖、分步开挖、支护与加固等关键环节。通过PFC5.02D软件模拟,实现了对煤层变形、破坏情况的实时监控,确保了开挖的安全性和高效性。最后,文章总结了分步开挖带来的多项优势,如提高开采效率、保障生产安全、降低成本以及增强决策科学性。 适合人群:从事煤炭开采及相关领域的工程师和技术人员。 使用场景及目标:适用于需要利用PFC5.02D软件进行煤层开挖规划和执行的专业人士,旨在帮助他们掌握分步开挖的技术要点,优化开挖方案,提高工作效率和安全性。 其他说明:文中提到的分步开挖方法不仅有助于解决当前的开挖难题,也为未来的煤炭开采技术创新提供了有益借鉴。

    少儿编程scratch项目源代码文件案例素材-渔夫.zip

    少儿编程scratch项目源代码文件案例素材-渔夫.zip

    少儿编程scratch项目源代码文件案例素材-无止境跑酷.zip

    少儿编程scratch项目源代码文件案例素材-无止境跑酷.zip

    少儿编程scratch项目源代码文件案例素材-岩脊求生.zip

    少儿编程scratch项目源代码文件案例素材-岩脊求生.zip

    VID20250429210109.mp4

    VID20250429210109.mp4

Global site tag (gtag.js) - Google Analytics