快精灵印艺坊 您身边的文印专家
广州名片 深圳名片 会员卡 贵宾卡 印刷 设计教程
产品展示 在线订购 会员中心 产品模板 设计指南 在线编辑
 首页 名片设计   CorelDRAW   Illustrator   AuotoCAD   Painter   其他软件   Photoshop   Fireworks   Flash  

 » 彩色名片
 » PVC卡
 » 彩色磁性卡
 » 彩页/画册
 » 个性印务
 » 彩色不干胶
 » 明信片
   » 明信片
   » 彩色书签
   » 门挂
 » 其他产品与服务
   » 创业锦囊
   » 办公用品
     » 信封、信纸
     » 便签纸、斜面纸砖
     » 无碳复印纸
   » 海报
   » 大篇幅印刷
     » KT板
     » 海报
     » 横幅

TOMCAT中DATASOURCE的配置方式

很多网上的文章都在说要改Server.xml,包括我手上的一本《Eclipse 从入门到精通》。不过经过今天的噩梦般的体验,最终还是没有改Server.xml,把DataSource配置好了。中间走过无数弯路,包括把 Tomcat从5.5.9降到5.0.28(最终还是没有用5.5.9,四周人都说,不要用最新的东西……实验室的都在用4.1……)。

先说一下关于Tomcat 5.5.9的问题,由于Tomcat5.5.9没有带上admin包,必须要自己下,下完以后复制到对应的目录。另外还有一重要步骤:把root下的那个 admin目录给删掉……或者把那个adminindex.html改名或删掉……这个问题折磨了我半个多小时,就是找不出来admin的配置页面在哪儿……
很希奇,rootadmin目录里没有任何jsp/html文件,让我几乎以为下漏了东西。其实好像是假如把那个admin目录删掉, Tomcat自动指到了另外一个地方。进入以后查看,可以发现其实/admin指向/server/webapps/admin,但是那里也并没有 jsp/html文件,真正的地址在:/src/jakarta-tomcat-catalina/webapps/admin……所以,大家一定要记住吧index.html给干掉……

但是成功进入了以后,我一直无法配置好jdbc/mysql的DataSource……极度郁闷之下,加上旁人说最新版总是有bug的……我换回了5.0.28……
5.0.28直接进入admin就可以了,不用走那么多弯路。配置DataSource有两种方式,一个就是直接到那个Context(/jsp文件目录)下面的Data Sources配置,配置的内容基本上都很清晰(以mysql为例):
JNDI Name: jdbc/mysql(自己定)
Data Source URL: jdbc:mysql://localhost/test (test是数据库名)
JDBC Driver Class: com.mysql.jdbc.Driver (记得把驱动拷到commonlib)
Max. Active Connections: 最大活动连接,默认4,不能用于产品发布,发布的时候,改成1000左右比较好,不过调试的时候没有必要。
Max. Idle Connections: 最大空闲连接,默认2。
Max. Wait for Connection: 等待连接时间,默认5000。
Validation Query: 验证用查询语句,非必填。
然后Save, Commit。
这里有一个bug. 一般最好是在所有修改完成以后Commit。假如先Commit再进行其他的选择修改,一般来说会直接退出界面……我一般都是Save/Commit/Log out……
然后在程序中引用:
InitialContext ctx=new InitialContext();
DataSource ds=(DataSource)ctx.lookup("java:comp/env/jdbc/mysql"); // jdbc/mysql是JNDI Name
con = ds.getConnection();
其他的就相同用了,注重返回前要手动关闭数据库连接,否则很快就会连接数耗尽。

另外一种方式就是在全局的Resource里的DataSource进行设置,然后在Context中的Resource Links里面引用。
Resource Link设置方式如下:
Name: jdbc/mysql(可以与全局名不同,比如jj,其他不变即可,相应的,ctx.lookup中要改为"java:comp/env/jj")
Global: jdbc/mysql(全局Resource里Data Source的名字)
Type: javax.sql.DataSource
在这里《Eclipse从入门到精通》的方式有一些问题:可以直接在Resource Link里面设置,并不用直接去更改Server.xml。它前面用写Server.xml的方式设置不用deploy的Context,tomcat确认更新以后就把这个Context写到其他地方了,可以在Host.Contest里面直接修改了,增加Resource Link。
《E》书里面手写Server.xml达到增加非Tomcat目录Context效果的语句如下:
在server.xml文件最末尾的之前插入:
</Context path="/hello"
reloadable="true"
docBase="C:eclipseworkspacemywebhello"
workDir="C:eclipseworkspacemywebbin">

其实也可以直接在admin界面里面TomcatServer.Service.Host里面直接添加(注重将Use Naming设为True,否则会出现Name java:comp is not bound in this Context非常),但是这样的话,无法规定servlet输出的目录(workDir)。可以权衡后使用。个人认为直接设置admin界面还是挺方便的。
返回类别: 教程
上一教程: JAVAMAIL在JSP中调用
下一教程: JAVA基础知识(2)

您可以阅读与"TOMCAT中DATASOURCE的配置方式"相关的教程:
· Windows下jsp运行环境的配置方案
· JSP中TOMCAT的SQL SERVER2000数据库连接池的配置
· TOMCAT下JSP、SERVLET和JAVABEAN环境的配置
· JNDI简介,jndi在tomcat中的配置,jdbc api简介,java连接数据库服务
· Tomcat5.x中的虚拟主机配置方式
    微笑服务 优质保证 索取样品