atitit.jndi的架构与原理以及资源配置and单元测试实践
atitit.jndi的架构与原理以及资源配置and单元测试实践
4.1. D:\workspace\wxb\src\jndi4t.xml 6
4.4. other----maybe help ful code 8
1. jndi架构
为什么会有jndi
jndi诞生的理由似乎很简单。随着分布式应用的发展,远程访问对象访问成为常用的方法。虽然说通过Socket等编程手段仍然可实现远程通信,但按照模式的理论来说,仍是有其局限性的。RMI技术,RMI-IIOP技术的产生,使远程对象的查找成为了技术焦点。JNDI技术就应运而生。JNDI技术产生后,就可方便的查找远程或是本地对象。
作者:: 老哇的爪子 Attilax 艾龙, EMAIL:1466519819@qq.com
转载请注明来源: http://blog.csdn.net/attilax
1. try{
2. Context initCtx = new javax.naming.InitialContext();
3. Context envCtx = (Context)initCtx.lookup("java:comp/env"); //官方的example写法
4. DataSource ds = (DataSource)envCtx.lookup("jdbc/YourDataBase"); // 或下面这样写:
5. // DataSource ds = (DataSource)intCtx.lookup("java:comp/env/jdbc/YourDataBase");
6. return ds.getConnection();
7. }catch(Exception e){
8. throw e;
9. }
2. jndi实现原理
hgjg0k0n1m 10级 分类: JAVA语言 被浏览42次 2013.07.09
采纳率:51% 10级 2013.07.09
jndi类似一个大map 将一些资源以key-value的形式放到jndi。 需要的时候再用key查询出来。 value,可能是一个字符串也可能是一个对象。
3. jndi资源配置
3.1. resin <database> 节点
<database>
<jndi-name>jndi/wxb_site_new</jndi-name>
<driver type="com.mysql.jdbc.Driver">
<url><![CDATA[jdbc:mysql://localhost:3306/wxb_site_new?useUnicode=true&characterEncoding=utf-8]]></url>
<user>root</user>
<password>root</password>
</driver>
<prepared-statement-cache-size>8</prepared-statement-cache-size>
<max-connections>20</max-connections>
<max-idle-time>30s</max-idle-time>
</database>
<!--
<resource>
<max-connections>20</max-connections>
</resource>
-->
</resin>
3.2. tomcat <resource 标签
resin 的resource 语法
<resource> syntax: (( (@jndi-name | <jndi-name>)?
& (@name | <name>)?
& (@var | <var>)?
& (@mbean-name | <mbean-name>)?
& (@mbean-interface | <mbean-interface>)?),
((@type | <type> | @class | <class>),
<arg>*)?,
(<init>*
& (@local-transaction-optimization | <local-transaction-opt
mization>)?
& <mbean-listener>*
& (@shareable | <shareable>)?))
3.3. 自定义资源
tomcat默认提供的jndi配置支持对象有限,比较常用的有datasource,javabean等,
有时无法满足用户的需求 。比如需要在构建对象的构造函数中传递参数等情况。
4. JNDI测试支持:
import org.springframework.mock.jndi.SimpleNamingContextBuilder;
D:\workspace\Book\WebRoot\WEB-INF\lib\org.springframework.test-3.1.0.RELEASE.jar
JNDI测试支持:在org.springframework.mock.jndi包下通过了SimpleNamingContextBuilder来来创建JNDI上下文Mock对象,从而无需依赖特定Java EE容器即可完成JNDI测试。
参考Junit+spring创建JNDI运行测试用例
public static void main(String[] args) throws IllegalStateException,
NamingException {
// System.setProperty("java.naming.factory.initial", "");
String p = pathx.classPath() + "/";
SpringUtil.locations = new String[] { p + "applicationContext.xml",
p + "jndi4t.xml" };
DataSource ds = (DataSource) SpringUtil.getBean("dataSource");
SimpleNamingContextBuilder builder = new SimpleNamingContextBuilder();
builder.bind("java:/comp/env/jndi/wxb_site_new", ds);
builder.activate();
UserInfoService userInfoService = (UserInfoService) SpringUtil
.getBean("userInfoService");
Dto pDto = new BaseDto();
pDto.put("user_id", "23946449");
UserInfo userInfo = userInfoService.checkLogin(pDto);
System.out.println(userInfo);
}
有俩个dataSource一样了三ok这了,改成不一样走错蓝。。
4.1. D:\workspace\wxb\src\jndi4t.xml
<?xml version="1.0" encoding="UTF-8"?>
<beans:beans xmlns:beans="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context"
xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd
http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.0.xsd
http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd">
<beans:bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<beans:property name="driverClassName" value="com.mysql.jdbc.Driver" />
<beans:property name="url" value="jdbc:mysql://localhost:3306/wxb_site_new?useUnicode=true&characterEncoding=utf-8" />
<beans:property name="username" value="root" />
<beans:property name="password" value="root" />
</beans:bean>
</beans:beans>
4.2. applicationContext.xml
<!-- 定义受环境影响易变的变量 -->
<context:property-placeholder location="classpath:jdbc.properties"/>
<!-- 数据源配置,在生产环境使用应用服务器的数据库连接池 -->
<!--<jee:jndi-lookup id="dataSource" jndi-name="${ds}" ></jee:jndi-lookup> -->
<bean id="dataSource"
class="org.springframework.jndi.JndiObjectFactoryBean">
<property name="jndiName">
<!-- <value>java:comp/env/jdbc/my_center</value> -->
<value>${ds}</value>
</property>
</bean>
4.3. jdbc.properties
# Properties file for JDBC configuration
#
# Place this file in the root CLASSPATH
#MySQL Connection Configuration
ct.jdbc.driverClassName=com.mysql.jdbc.Driver
ct.jdbc.url=jdbc:mysql://localhost:3306/wxb_site_new?useUnicode=true&characterEncoding=utf-8
ct.jdbc.username=root
ct.jdbc.password=
ds =java\:/comp/env/jndi/wxb_site_new
4.4. other----maybe help ful code
0
String url="localhost:8080";
这是在Weblogic中的写法:
properties = new Properties();
properties.put(Context.INITIAL_CONTEXT_FACTORY, "weblogic.jndi.WLInitialContextFactory");
properties.put(Context.PROVIDER_URL, url);
//用户是否为空
if (user != null) {
properties.put(Context.SECURITY_PRINCIPAL, user);
properties.put(Context.SECURITY_CREDENTIALS, password == null ? "" : password);
}
Context ctx= new InitialContext(properties);
DataSource ds =(DataSource) ctx.lookup("java:comp/env/jdbc/OracleDB");
Connection conn = ds.getConnection();
查找相关资料,把
properties.put(Context.INITIAL_CONTEXT_FACTORY, "weblogic.jndi.WLInitialContextFactory");
换成相应的tomcat对应的上下文工厂,应该就可以了。
5. 参考
Resin中jndi资源配置 - howareyouo的专栏 - 博客频道 - CSDN.NET.htm
JNDI全攻略(一) - chinaifne - 博客园.htm
TOMCAT自定义JNDI - 我的java 博客,嘿嘿 - ITeye技术网站.htm
各位谁知道怎样在一个测试类的main()函数里访问tomcat的JNDI数据源 -CSDN论坛-CSDN.NET-中国最大的IT技术社区.htm
高分请教Spring做单元测试的时候如果通过mock虚拟jndi数据源呢_IT知识问答_希赛网.htm
Junit+spring创建JNDI运行测试用例 - CSDN博客.htm
atitit.jndi的架构与原理以及资源配置and单元测试实践的更多相关文章
- atitit.jndi的架构与原理以及资源配置and单元測试实践
atitit.jndi的架构与原理以及资源配置and单元測试实践 1. jndi架构 1 2. jndi实现原理 3 3. jndi资源配置 3 3.1. resin <database> ...
- atitit.软件与sql设计模式原理与本质 大总结attialx总结v6 qc26.docx
atitit.软件与sql设计模式原理与本质 大总结attialx总结v6 qc26.docx 1.1. 版本历史2 2. 设计模式是什么2 2.1. 模式就是在一种场合下对某个问题的一个解决方案.& ...
- Atitit 在线支付系统功能设计原理与解决方案 与目录
Atitit 在线支付系统功能设计原理与解决方案 与目录 1.1. 支付系统1 1.2. 独立的支付子体系..微服务架构..1 1.3. 参考书籍1 支付战争 [The PayPal Wars:Bat ...
- Atitit.数据库存储引擎的原理与attilax 总结
Atitit.数据库存储引擎的原理与attilax 总结 1. 存储引擎是什么1 2. 其它数据库系统(包括大多数商业选择)仅支持一种类型的数据存储2 3. 表的存储有三个文件:结构+数据+索引2 4 ...
- Atitit数据库层次架构表与知识点 attilax 总结
Atitit数据库层次架构表与知识点 attilax 总结 第一阶段,大概理论(三五天 数据库的类型,网状,层次,树形数据库,kv数据库.Oodb Er模型 sql 并发控制与lock Acid ...
- atitit.木马病毒webshell的原理and设计 java c# .net php.
atitit.木马病毒webshell的原理and设计 java c# .net php. 1. 隐蔽性 编辑 WebShell后门具有隐蔽性,一般有隐藏在正常文件中并修改文件时间达到隐蔽的,还有利用 ...
- Atitit.数据库存储引擎的原理与attilax 总结
Atitit.数据库存储引擎的原理与attilax 总结 1. 存储引擎是什么1 2. 其它数据库系统(包括大多数商业选择)仅支持一种类型的数据存储2 3. 表的存储有三个文件:结构+数据+索引2 4 ...
- Atitit 延迟绑定架构法attilax总结
Atitit 延迟绑定架构法attilax总结 配置文件的延迟绑定1 Api属性与方法的回调延迟绑定1 后期绑定和前期绑定2 延迟调用2 用 Java 语言延迟绑定2 什么是推迟绑定 C++3 配置文 ...
- Atitit 图像处理 深刻理解梯度原理计算.v1 qc8
Atitit 图像处理 深刻理解梯度原理计算.v1 qc8 1.1. 图像处理 梯度计算 基本梯度 内部梯度 外部梯度 方向梯度1 2. 图像梯度就是图像边缘吗?2 1.1. 图像处理 梯度计算 ...
随机推荐
- [转] EPSG CODE的含义
董雨 原文地址 之前一直对WKT.EPSG.SRID不是很理解,总是混淆,今天看了一下,清晰了很多,顺便总结一下,嘿嘿:) EPSG(欧洲石油调查小组):European Petroleum S ...
- python笔记15-ini配置文件(configparser)
前言 使用配置文件来灵活的配置一些参数是一件很常见的事情,配置文件的解析并不复杂,在python里更是如此,在官方发布的库中就包含有做这件事情的库,那就是configParser configPars ...
- 面经 | 我是如何通过校招拿到京东的Offer的
本文来自粉丝投稿,原作者:红鼻子熊. 版权归Hollis所有. OFFER:京东2018校招物流研发岗 个人:211小硕 面试时间:2017年秋天 整体:三轮面试,前两轮为技术面试,最后为hr面试 一 ...
- 使用nsswitch控制linux dns解析顺序
参考:1.DNS原理入门参考:http://www.ruanyifeng.com/blog/2016/06/dns.html 2.http://cn.linux.vbird.org/linux_ser ...
- nginx最大并发连接数的思考:worker_processes、worker_connections、worker_rlimit_nofile
参考nginx官网:http://nginx.org/en/docs/ngx_core_module.html#worker_connections 从用户的角度,http 1.1协议下,由于浏览器默 ...
- Spark Streaming数据清理内幕彻底解密
本讲从二个方面阐述: 数据清理原因和现象 数据清理代码解析 Spark Core从技术研究的角度讲 对Spark Streaming研究的彻底,没有你搞不定的Spark应用程序. Spark Stre ...
- (六)SSO之CAS框架扩展 改动CAS源代码实现与ESS动态password验证对接
题记: 偶尔的偶尔我们会听到这个站点的数据泄露了,那个站点的用户数据泄露了.让用户又一次改动登录password,所以,对于用户数据安全性越发的引起我们的重视了,尤其是一些保密性要求高的站点.更须要添 ...
- 封装实现JavaScript 文件的动态载入功能
function loadScript(url, callback){ var script = document.createElement ("script") script. ...
- POJ 3122-Pie(二分+精度)
题目地址:id=3122">POJ 3122 题意:给出n个pie的直径.有F+1个人,假设给每人分的大小同样(形状能够不同),每一个人能够分多少.要求是分出来的每一份必须出自同一个p ...
- Visual Studio2015 简体中文版 安装
VS2015简体中文版安装 导航 介绍 解决安装先决条件 安装 VS2015 创建桌面快捷方式 启动 VS2015 命令启动VS2015 配置 VS2015 启动完成 Visual Studio的功能 ...