丹调生活 发表于 2017-2-27 12:31:45

1.3.2 Jetty 的基本配置(2)

  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,即看到数据库的访问结果。
页: [1]
查看完整版本: 1.3.2 Jetty 的基本配置(2)