Tomcat配置JNDI数据源

来源:互联网 发布:图论算法总结 编辑:程序博客网 时间:2024/06/04 17:53
【方式一】
步骤1:将数据库驱动拷贝到tomcat的lib下;
步骤2:配置context.xml文件
方法1:使用tomcat的context.xml文件,添加:
<Resource
name="jdbc/TestDB"
auth="Container"
type="javax.sql.DataSource"
username="root"
password="mysql"
driverClassName="com.mysql.jdbc.Driver"
url="jdbc:mysql://localhost:3306/kjxt"
maxActive="100"
maxIdle="30"
maxWait="10000"
/>
方法2:在应用中新建一个context.xml文件进行配置,在WebRoot目录下的METE_INF的目录下
<Context>
<Resource
....
/>
</Context>


步骤3:应用的web.xml配置,添加:
<resource-ref>
<description>MySQLDataSource</description>
<res-ref-name>jdbc/TestDB</res-ref-name>
<res-type>javax.sql.DataSource</res-type>
<res-auth>Container</res-auth>
</resource-ref>
[应用]使用数据源连接数据库
String jndi = "jdbc/TestDB";
Context initContext = new InitialContext();
Context envContext = (Context)initContext.lookup("java:/comp/env"); //固定,不需要修改
DataSource ds = (DataSource)envContext.lookup(jndi);
Connection conn = ds.getConnection();


【全局数据源配置】
步骤1.直接在tomcat中的server.xml文件中的GlobalNamingResource标签中增加一下内容:
<Resource
name="jdbc/TestDB"
auth="Container"
type="javax.sql.DataSource"
username="root"
password="mysql"
driverClassName="com.mysql.jdbc.Driver"
url="jdbc:mysql://localhost:3306/kjxt"
maxActive="100"
maxIdle="30"
maxWait="10000"
/>
步骤2:在tomcat的context.xml的Context标签中添加
<ResourceLink global="jdbc/TestDB" name="jdbc/test2" type="javax.sql.DataSource"/>
[说明:jdbc/TestDB是全局的JNDI,jdbc/test2是你的应用中使用的JNDI]
此步骤可以是在应用程序中的WebRoot\META-INF \下新建context.xml,然后添加:
<Context>
<ResourceLink global="jdbc/TestDB" name="jdbc/test2" type="javax.sql.DataSource"/>
</Context>
步骤3:直接在代码中使用该JNDI即可(web.xml无需任何配置了)
0 0
原创粉丝点击