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,即看到数据库的访问结果。
基于bert实现关系三元组抽取python源码+数据集+项目说明.zip基于bert实现关系三元组抽取python源码+数据集+项目说明.zip基于bert实现关系三元组抽取python源码+数据集+项目说明.zip基于bert实现关系三元组抽取python源码+数据集+项目说明.zip基于bert实现关系三元组抽取python源码+数据集+项目说明.zip 个人大四的毕业设计、课程设计、作业、经导师指导并认可通过的高分设计项目,评审平均分达96.5分。主要针对计算机相关专业的正在做毕设的学生和需要项目实战练习的学习者,也可作为课程设计、期末大作业。 [资源说明] 不懂运行,下载完可以私聊问,可远程教学 该资源内项目源码是个人的毕设或者课设、作业,代码都测试ok,都是运行成功后才上传资源,答辩评审平均分达到96.5分,放心下载使用! 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.md文件(如有),供学习参考。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值