内嵌jetty配置jndi数据源

最近一直忙着玩,书业荒废了深感罪孽深重,在此面壁思过10分钟……


自从项目部署环境换上jboss后,开发效率低了很多,相对jetty而言jboss还是有些重,由于各方面事情的影响也惰于调整优化。

从jboss切换为jetty部署关键问题在于如何为内嵌jetty配置JNDI数据源,废话少说,看码

首先需要在/web-inf/目录下添加jetty-env.xml配置文件,配置如下

<Configure class="org.eclipse.jetty.webapp.WebAppContext">
	<New class="org.eclipse.jetty.plus.jndi.Resource">
		<Arg>java:/MasterDataSource-Test</Arg>
		<Arg>
			<New class="org.springframework.jdbc.datasource.DriverManagerDataSource">
				<Set name="driverClassName">com.mysql.jdbc.Driver</Set>
				<Set name="url">jdbc:mysql://XX.X.XX.XXX:3306/DB_name?useUnicode=true&characterEncoding=utf-8</Set>
				<Set name="username">username</Set>
				<Set name="password">password</Set>
			</New>
		</Arg>
	</New>
	<New class="org.eclipse.jetty.plus.jndi.Resource">
		<Arg>java:/SlaveDataSource-Test</Arg>
		<Arg>
			<New class="org.springframework.jdbc.datasource.DriverManagerDataSource">
				<Set name="driverClassName">com.mysql.jdbc.Driver</Set>
				<Set name="url">jdbc:mysql://XX.X.XX.XXX:3306/DB_name?useUnicode=true&characterEncoding=utf-8</Set>
				<Set name="username">username</Set>
				<Set name="password">password</Set>
			</New>
		</Arg>
	</New>
</Configure>

我们还需要为内嵌jetty容器指定数据库驱动包(当然这里也可以指定容器级jetty-env.xml)

<plugin>
	<groupId>org.mortbay.jetty</groupId>
	<artifactId>jetty-maven-plugin</artifactId>
	<version>8.0.0.RC0</version>
	<configuration>
		<scanIntervalSeconds>10</scanIntervalSeconds>
		<webApp>/</webApp>
	</configuration>
	<dependencies>
	        <dependency>
		        <groupId>mysql</groupId>
			<artifactId>mysql-connector-java</artifactId>
			<version>5.1.10</version>
		</dependency>
	</dependencies>
</plugin>

当jetty容器启动时会自动取得数据源,我们就可以很顺畅地在jetty环境中进行开发调试了。
当然,此次环境配置全是梦清调试的成果,我只是对maven依赖配置做了些调整。

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值