在Admin控制台下host里面新建一个context,然后在下面配置datasource,由于是在页面环境下配置,所以一切都显得很简单。
然后就是在jsp里面测试看datasource配置是否成功。
try{
InitialContext ctx=new InitialContext();
Context envCtx = (Context)ctx.lookup("java:comp/env");
ds=(DataSource)envCtx.lookup("jdbc/sqlserver");
Connection conn = ds.getConnection();
Statement stmt = conn.createStatement();
........
}catch(Exception ex) {
out.print(" error , info = "+ex.getMessage());
ex.printStackTrace();
}
执行时报错:
javax.naming.NameNotFoundException: Name java:comp is not bound in this Context
查看了tomat的server.xml、web.xml还有应用下面的web.xml,怎么该都报这个错。
最后只能把数据源配置都删除了,自己手工的来配置数据源。
起初系统配置的数据源在server.xml的<GlobalNamingResources> ... </GlobalNamingResources>中,
各个应用是通过 <resource-ref> ... </resource-ref>来引用这个数据源的,总是会报错。反复调试还是不行,真是郁闷,cctv5直播acmilan对chevo上半场也是真无趣。
但只要把datasource放在你部署应用的<context> ... </context> 里面定义,就不会再报这个错。
context 可以直接放在 TOMCAT_HOME/server.xml里面的host中。
<service>
<host>
context 定义就放在这里
</host>
</service>
如果是在admin控制台中部署的应用,就在TOMCAT_HOME/conf/Catalina/localhost/YOURWEBAPP.xml中的context里面定义数据源,也就不必再利用resource-ref来引用数据源了。
或者在你的应用的WEB-INF/web.xml中定义也行,总之,datasource的定义最好放在你的web应用的context里面定义,不然就会报上面的错,不知道是不是tomcat自身的问题。