jndi

数据库中相关参数变更后,只需要修改数据源文件(mysql-ds.xml)里的参数就可以了,这样避免了程序与数据源的紧密耦合。

1.Tomcat根目录下\conf\context.xml:
        在Tomcat根目录\conf\context.xml文件中<Context>节点中添加<Resource>信息(可以在tomcat加载的项目中的context.xml写?)
        <Context>
        ...//原有配置
        <Resource
            name="jdbc/books" ------------------------------------------------指定jndi的名字
            auth="Container"  ------------------------------------------------指定管理resource的方式为容器(还有一种为Application表示由web来管理)
            type="javax.sql.DataSource" ......--------------------------------指定数据源的全路径
            driverClassName="com.microsoft.jdbc.sqlserver.SQLServerDriver"----指定驱动
            url="jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=books"指定连接数据库的URL
            maxActive="0" ----------------------------------------------------指定连接池中处于空闲状态的最大连接数,0表示不受限制
            ...
        />
        </Context>
    2.web.xml文件的配置---WEB-INF\web.xml文件中<web-app>节点下添加<resourse-ref>信息
        <web-app>
        <resource-ref>
            <description>E-Books DataSource</description> -对引用资源的说明
            <res-ref-name>jdbc/books</res-ref-name> -------jndi的名字
            <res-type>javax.sql.DataSource</res-type> -----数据源的全路径
            <res-auth>Container</res-auth> ----------------数据源由容器创建
        </resource-ref>
        ......//其他配置
         </web-app>
    3.添加数据库驱动文件
        把JDBC驱动程序复制到Tomcat common\lib目录下(因为数据源由Tomcat创建并维护)
    JNDI对数据源的引用:
    引用:javax.naming.*
        引用:javax.sql.DataSource
    Context ctx = new InitialContext();
    DataSource ds = (DataSource)ctx.lookup("java:comp/env/jdbc/books")
    Connection con = ds.getConnection();


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值