1.3.2 Jetty 的基本配置(2)

来源:互联网 发布:java将文字写入word 编辑:程序博客网 时间:2024/06/05 19:37

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.jarcommons-pool.jarcommons-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 ServletExceptionsuper.init(conf工g);tryic = new InitialContext();catch (Exception e){throw new ServletException(e);//serv工ce 方法是 Servlet 的服务方法public void service(HttpServletRequest request, HttpServletResponseresponse)throwsServletException,工OExceptionII获取 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,即看到数据库的访问结果。
原创粉丝点击