设为首页 收藏本站
查看: 461|回复: 0

[经验分享] 配置java连接池 tomcat方式、Spring方式配置的比较

[复制链接]

尚未签到

发表于 2017-2-6 08:10:02 | 显示全部楼层 |阅读模式
一、首先配置连接池
1、tomcat下配置连接池
  *>在tomcat下的context.xml配置连接池代码   
<Resource
      name="jdbc/sqlserver"                  //连接池名称
      type="javax.sql.DataSource"  
      password="syl6413"
         driverClassName="com.microsoft.sqlserver.jdbc.SQLServerDriver"
      maxIdle="5"
      maxWait="5000"
      username="sa"
      url="jdbc:sqlserver://192.168.0.9:1433; DatabaseName=disasterSystem"
      maxActive="10"/>
    *>tomcat连接池中配置web.xml代码
<!-- DataSource -->
<resource-ref>
        <description>SQLServer2005 Datasource disasterSystem</description>
         <res-ref-name>jdbc/sqlserver</res-ref-name>
        <res-type>javax.sql.DataSource</res-type>
        <res-auth>Container</res-auth>
</resource-ref>
    *>在Spring配置tomcat连接池的JNDI代码
<bean id="dataSource" class="org.springframework.jndi.JndiObjectFactoryBean">
         <property name="jndiName" value="java:comp/env/jdbc/sqlserver">
      </property>
</bean>
    自此tomcat连接池已配置完毕,若不用Spring管理连接池,也可以不配Spring,这样即可以在程序中使用tomcat连接池了.若使用Spring来统一管理连接池,也就是统一SessionFactory,配置方式如下:   
<bean id="sessionFactory"
        class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">

        <property name="dataSource">
            <ref bean="dataSource" />
        </property>
        <property name="hibernateProperties">
            <props>
                <prop key="hibernate.dialect">
                    org.hibernate.dialect.SQLServerDialect
                </prop>
                <prop key="hibernate.connection.autocommit">true</prop>
                <!-- 显示sql语句 -->
                <prop key="hibernate.show_sql">true</prop>
                <!-- 解决提交乱码问题 -->
                <prop key="connection.useUnicode">true</prop>
                <prop key="connection.characterEncoding">utf-8</prop>
                <!-- 格式化sql语句 -->
                <prop key="hibernate.format_sql">true</prop>
                <prop key="hibernate.order_updates">true</prop>
                <!-- 事务自动管理 -->
                <prop key="hibernate.connection.release_mode">
                    after_transaction
                </prop>
            </props>
        </property>

        <property name="mappingResources">
            <list></list>
        </property>
    </bean>
2、tomcat下配置连接池
    Spring不通过用tomcat中配置的JNDI来连接,但是它也是通过用commons.dbcp.jar连接池来管理的,也可以通过其他的开源连接池工具如:C3P0等。配置又分为两种,具体代码如下:
    *>一种是直接配置applicationContext.xml   
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
        <property name="driverClassName" value="oracle.jdbc.driver.OracleDriver">
        </property>
        <property name="url" value="jdbc:oracle:thin:@localhost:1521:SJY">
        </property>
        <property name="username" value="**"></property>
        <property name="password" value="**"></property>
</bean>
    *>另一种是通过perportise配置文件:datasource.properties再通过applicationContext.xml得到
        datasource.properties代码:        
datasource.driverClassName=com.microsoft.sqlserver.jdbc.SQLServerDriver
datasource.url=jdbc:sqlserver://192.168.0.9:1433;DatabaseName=disasterSystem
datasource.username=sa
datasource.password=syl6413
datasource.maxActive=10
datasource.maxIdle=5
datasource.maxWait=5000
datasource.defaultAutoCommit=true
        applicationContext.xml代码:            
<bean id="placeholderConfig" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
        <property name="location">
        <value>classpath:/datasource.properties</value>
        </property>
    </bean>
    <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
        <property name="driverClassName">
        <value>${datasource.driverClassName}</value>
        </property>
        <property name="url">
         <value>${datasource.url}</value>
            </property>
            <property name="username">
                 <value>${datasource.username}</value>
            </property>
            <property name="password">
                 <value>${datasource.password}</value>
            </property>
            <property name="maxActive">
                 <value>${datasource.maxActive}</value>
            </property>
            <property name="maxIdle">
                 <value>${datasource.maxIdle}</value>
            </property>
            <property name="maxWait">
        <value>${datasource.maxWait}</value>
        </property>
            <property name="defaultAutoCommit">
               <value>${datasource.defaultAutoCommit}</value>
            </property>
    </bean>

二、测试配置连接池
1、测试tomcat连接池
    *>不用Spring管理的tomcat连接池测试代码(只能在jsp里面测试):            
Context initContext = new InitialContext();
    Context envContext =(Context)initContext.lookup("java:comp/env");
    DataSource ds = (DataSource) envContext.lookup("jdbc/sqlserver");
    Connection con = ds.getConnection();
    if (con != null) {
            System.out.println("已经得到连接");
    } else {
        System.out.println("没有得到连接");
    }
    *>用Spring管理tomcat连接池的测试代码:   
//ApplicationContext ctx = new FileSystemXmlApplicationContext("src/applicationContext.xml");//两种得到bean工厂的代码,任选其一
    ApplicationContext ctx = new ClassPathXmlApplicationContext("applicationContext.xml");
    DataSource ds = (DataSource) ctx.getBean("dataSource");
    Connection con = ds.getConnection();
    if(con != null){
        System.out.println("连接成功");
    }else{
        System.out.println("连接不成功");
    }
2.测试Spring连接池
    其实测试Spring连接池的代码和上面Spring管理tomcat连接池测试代码一样:   
//ApplicationContext ctx = new FileSystemXmlApplicationContext("src/applicationContext.xml");//两种得到bean工厂的代码,任选其一
    ApplicationContext ctx = new ClassPathXmlApplicationContext("applicationContext.xml");
    DataSource ds = (DataSource) ctx.getBean("dataSource");
    Connection con = ds.getConnection();
    if(con != null){
        System.out.println("连接成功");
    }else{
        System.out.println("连接不成功");
    }

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-338000-1-1.html 上篇帖子: tomcat的new Date()与系统时间差8小时问题 下篇帖子: Tomcat启动时一闪而过,看不多错误信息解决方案
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表