background image

Java 程序员:配置 tomcat5 数据源心得

在 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

 

的 ... 中,

 

 各个应用是通过 ... 来引用这个数据源的,总是会报错。反复调试还是不行,真是郁闷,
cctv5 直播 acmilan 对 chevo 上半场也是真无趣。
 但只要把 datasource

 

放在你部署应用的 ... 里面定义,就不会再报这个错。

 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 自身的问题。