丁保国的博客

收集整理工作生活,点点滴滴

  :: :: 博问 :: 闪存 :: :: :: :: 管理 ::

1.3.2 Jetty 的基本配置(2)

3. 配置 JNDI 绑定

Jetty 同样可以整合 DBCP、 C3PO 等数据源来提供容器管理的数据源。提供容器管理的数据源,只是 Jetty JNDI 绑定功能之一。

下面介绍如何在 Jetty 绑定 JNDI,以及 JNDI 的使用。

增加 JNDI 绑定必须使用 Jetty 的 plus 功能。因此,启动时必须增加 jetty-plus.xml
文件。增加 JNDI 的绑定同样有两个方法:

·修改系统默认的jetty.xml 文件。
·增加自己的配置文件。

两种配置方式大同小异,区别是前者需要修改系统默认的配置文件,此处仅介绍增加自己的配置文件方式。

在 Jetty 的 plus 中,有如下包。

org.mortbay.jetty.plus.naming:执行JNDI绑定的包。

该包下有如下四个类。

EnvEntry: 绑定简单值。

NamingEntry: 抽象类,是另外三个类的父类。

Resource: 用于绑定数据源等资源。

Transaction: 用于绑定事务。

增加数据源绑定请按如下步骤进行。

(1)此处绑定的数据源依然以 DBCP 为实现,当然也可以绑定 C3PO 数据源,但必须将 DBCP 所需要的 jar文件复制到 Jetty 可以使用的路径中。根据前面介绍 DBCP 主要需要如下三个文件:

commons-dbcp.jar
commons-pool.jar
commons-collections.jar

将这三个文件复制到 Jetty 的 lib 路径下即可, Jetty 启动时会自动加载该路径的jar文件。当然,还需将数据库驱动复制到该路径下。

(2) 增加如下配置文件:

 <?xrn1versio口="l.0"?>
<!一 Jetty配置文件的文件头,包含DTD等信息>
<lDOCTYPE Configure PUBLIC "-//Mort Bay Consu1ting//DTD
Configure//EN"''http://jetty.mortbay.org/configure.dtd''>
<'一Jetty配置文件的根元素一〉
<Configure id="Server" c1ass="org.mortbay.jetty.Server">
<!-配置第一个环境变量,只是一个普通值>
<New id="wogg1e"c1ass="org.mortbay.jetty.p1us.naming.
EnvEntry"><Arg>wogg1e</Arg>
<Argtype="java.1ang.工nteger">4000</Arg>
</New>
<!--配置第二个环境变量,只是一个普通值一〉
<New id="wigg1e"c1ass="org.mortbay.jetty.p1us.naming.EnvEntry">
<Arg>wigg1e</Arg><Arg type="java.1ang.Doub1e">100</Arg>
<Arg type="boo1ean">true</Arg>
</New><!…创建一个数据源一〉
<New 工d="ds" class="org.apache.commons.dbcp.Bas工cDataSource">
<!设置数据库驱动>
<Set name="driverClassName">com.mysql.jdbc.Driver</Set>
<!一设置数据库url-->
<Set name="url">jdbc:mysql://localhost:3306/j2ee</Set>
<1一设置数据库用户名-->
<Set name="username">root</Set>
<!--设置数据库密码一〉
<Set name="password">32147</Set>
<!设置数据库驱动二〉
<Set name="maxActive" type="int">100</Set>
<1设置数据源最大空闲连接数>
<Set 口ame="maxldle"type="int">30</Set>
<!--设置数据源最大的等待数-->
<Set 口ame="maxWait"type="int">1000</Set>
<1 一设置数据库是否自动提交一〉
<Set 口ame="defaultAutoComm工t"type="boolean">true</Set>
<!一设置连接是否自动删除>
<Set name="removeAbandoned" type="boolean">true</Set>
<!设置数据库驱动>
<Set name="removeAbandonedTimeout"type="工nt">60</Set:>
<Set name="logAbandoned" type="boolean">true</Set>
</New>
<1 一将实际的数据源绑定到jdbc/mydatasource这个 JNDI 名…〉
<New 工d="mydatasource"class="org.mortbay.jetty.plus.naming.Resource">
<Arg>jdbc/mydatasource</Arg>
<Arg><Ref id="ds"/></Arg></New></Configure>
在上面的配置文件中,绑定了三个JNDI值,下面测试该JNDI 的 Servlet:
public class TestServlet extends HttpServlet
工nitialContextic;
//Servlet的初始化方法,该方法完成Context的初始化
public void init(ServletConfig config) throws ServletException
super.init(conf工g);
try
ic = new InitialContext();
catch (Exception e)
{
throw new ServletException(e);
//serv工ce 方法是 Servlet 的服务方法
public void service(HttpServletRequest request, HttpServletResponseresponse)
throwsServletException,工OException
II获取 JSP 页面输出流
PrintStream out = newPr工ntStream(response.getOutputStream());
try
//在控制台输出 w工ggle 的绑定值
System.out.printl口 (ic.lookup("wiggle"));
/I:在控制台输出 woggle 的绑定值
System.out.pr工口tl口 (ic.lookup("woggle") );
//获取绑定的数据源
DataSource ds = (DataSource)ic.lookup("jdbc/mydatasource");
//通过数据源获取数据库连接
Co口口ectionconn = ds.getConnection();
//通过数据库连接创建Statement对象
Statement stmt=conn.createStatement();
//通过 Statement对象执行SQL查询,返回ResultSet对象
ResultSet rs = stmt.executeQuery("select* from news");
//遍历记录集
wh工le(rs.next())
out.pr工ntl口 (rs.getString(2));
}
catch (Exception e)
e.printStackTrace() ;
在 web.xml 文件中增加如下片段:
<servlet>
<!一定义Servlet-->
<servlet-name>aa</servlet-name><servlet-class>lee.TestServlet</servlet-class>
</servlet><servlet-mapping>
<J 一定义 Servlet的 url 映射〉
<servlet-name>aa</servlet-name><url-pattern>/aa</url-pattern></servlet-mapping>
启动 Jetty,访问该Se凹let,即看到数据库的访问结果。
posted on 2008-12-04 13:26  丁保国  阅读(825)  评论(0编辑  收藏  举报