• 数据源与连接池


    1、JNDI Java Naming and Directory Interface
    Java命名和目录服务接口
    通过一个字符串就能找到指定的资源

    JNDI规范通常提供一个lookup方法通过资源字符串查找所指定的资源

    2、DataSource
    通过一定的配置信息告诉WEB容器,应用连接到哪个数据源

    3、配置数据源和数据连接池
    1)在tomcat的conf目录下的context.xml文件中增加资源描述标记

    <Resource name="jndi/datasource" 数据连接池资源的名称
    auth="Container" 认证类型,由容器提供认证
    type="javax.sql.DataSource" 表示此资源的类型是什么,javax.sql.DataSource表示为jdbc的数据源类型
    driverClassName="com.microsoft.sqlserver.jdbc.SQLServerDriver"
    url="jdbc:sqlserver://localhost:1433;DatabaseName=MyWEB"
    username="sa"
    password="12345"
    maxTotal="20" 最大连接数
    maxIdle="5" 最大空闲连接数
    maxWaitMillis="10000"/> 最大等待时间 

    说明:对tomcat5.0的配置,请参考PPT,<ResourceParams>标记单独配置参数信息
    对6.0及以上的tomcat,只需要使用<Resource>标记,把相关的参数配置直接放在该标记的属性部分
    对5.0, 6.0, 7.0来说,最大连接数是maxActive,最大等待时间是maxWait(ms)
    对8.0来说,最大连接数是maxTotal,最大等待时间 maxWaitMillis
    2)在应用的web.xml文件中声明引用了哪个资源

    <resource-ref>
    <description>JNDI JDBC DataSource </description>
    <res-ref-name>jndi/datasource</res-ref-name>
    <res-type>javax.sql.DataSource</res-type>
    <res-auth>Container</res-auth>
    </resource-ref>

    3)使用Context去获取配置的jndi资源

    javax.naming.Context context = new javax.naming.InitialContext();
    Object obj = context.lookup("java:comp/env/jndi/datasource");
    javax.sql.DataSource ds = (javax.sql.DataSource) obj;
    javax.sql.Connection conn = ds.getConnection();

    4、数据库连接池对数据库相关对象的关闭操作
    rs.close(), conn.close();
    以上的关闭操作,是交由Tomcat容器来做的,conn.close()并没有真正把建立好的数据库连接关闭,而是把此数据库连接放回数据库连接池

    5、补充,如果想让eclipse直接使用数据连接池的方式运行应用,则把context.xml文件copy到WebContent目录下的META-INF目录 -+

  • 相关阅读:
    Visual C#使用DirectX实现视频播放
    sql server中新增一条数据后返回该数据的ID
    JQuery上传插件Uploadify使用详解
    .NET JS escape加密的后台解密
    Redis Sentinel(哨兵模式)
    Redis集群入门
    Redis 4.0.X版本reshard出现错误的解决办法
    首层nginx 传递 二级代理,三级代理......多级代理nginx 客户端真实IP的方法
    Centos6 Ruby 1.8.7升级至Ruby 2.3.1的方法
    SQL Server 2008示例数据库安装问题解决
  • 原文地址:https://www.cnblogs.com/A0926/p/5443820.html
Copyright © 2020-2023  润新知