本文向大家介绍Hibernate proxool连接池,可能好多人还不了解Hibernate proxool连接池,没有关系,看完本文你肯定有不少收获,希望本文能教会你更多东西。
Hibernate proxool连接池跟c3p0以及dbcp不一样,它是自己生成连接的,因此连接信息放在proxool配置文件中。使用它时,需要将proxool-0.8.3.jar加入到classespath中。配置举例如下:
hibernate.cfg.xml
- <?xml version="1.0" encoding="UTF-8"?>
- <!DOCTYPE hibernate-configuration PUBLIC
- "-//Hibernate/Hibernate Configuration DTD 3.0//EN
- "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
- <hibernate-configuration>
- <session-factory>
- <!-- 显示实际操作数据库时的SQL -->
- <property name="show_sql">true</property>
- <!-- SQL方言,这边设定的是MySQL -->
- <property name="dialect">net.sf.hibernate.dialect.MySQLDialect</property
- <!—proxool的配置 -->
- <property name="proxool.pool_alias">pool1</property>
- <property name="proxool.xml">ProxoolConf.xml</property>
- <property name="connection.provider_class">net.sf.hibernate.
connection.ProxoolConnectionProvider</property>- <!-- 对象与数据库表格映像文件 -->
- <mapping resource="com/amigo/pojo/User.hbm.xml"/>
- <mapping resource="com/amigo/pojo/Org.hbm.xml"/>
- </session-factory>
- </hibernate-configuration>
在hibernate.cfg.xml的同目录下编写proxool的配置文件:ProxoolConf.xml,该文件的配置实例如下:
ProxoolConf.xml
- <?xml version="1.0" encoding="utf-8"?>
- <!-- the proxool configuration can be embedded within your own application's.
- Anything outside the "proxool" tag is ignored. -->
- <something-else-entirely>
- <proxool>
- <alias>pool1</alias>
- <!--proxool只能管理由自己产生的连接-->
- <!-- 驱动的url-->
- <!-- jdbc:mysql://localhost:3306/dbname?useUnicode=true&characterEncoding=GBK-->
- <driver-url>… </driver-url>
- <!-- 驱动类,eg. com.mysql.jdbc.Driver-->
- <driver-class>… <driver-class>
- <driver-properties>
- <!-- 数据库用户名,eg. value为root-->
- <property name="user" value="…"/>
- <!-- 数据库密码,eg. value为root-->
- <property name="password" value="…."/>
- </driver-properties>
- <!-- proxool自动侦察各个连接状态的时间间隔(毫秒),侦察到空闲的连接就马上回收,超时的销毁-->
- <house-keeping-sleep-time>90000</house-keeping-sleep-time>
- <!-- 指因未有空闲连接可以分配而在队列中等候的***请求数,超过这个请求数的用户连接就不会被接受-->
- <maximum-new-connections>20</maximum-new-connections>
- <!-- 最少保持的空闲连接数-->
- <prototype-count>5</prototype-count>
- <!-- 允许***连接数,超过了这个连接,再有请求时,就排在队列中等候,
***的等待请求数由maximum-new-connections决定-->- <maximum-connection-count>100</maximum-connection-count>
- <!-- 最小连接数-->
- <minimum-connection-count>10</minimum-connection-count>
- </proxool>
- </something-else-entirely>
以上介绍Hibernate proxool连接池
【编辑推荐】