`
newleague
  • 浏览: 1499912 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类

JNDI,JTA,JMS 详解

阅读更多

JNDI
Java术语

英文全称是:Java Naming and Directory Interface

术语解释:一组帮助做多个命名和目录服务接口的API。

JNDI(Java Naming and Directory Interface)是SUN公司提供的一种标准的Java命名系统接口,JNDI提供统一的客户端API,通过不同的访问提供者接口JNDI SPI的实现,由管理者将JNDI API映射为特定的命名服务和目录系统,使得Java应用程序可以和这些命名服务和目录服务之间进行交互。集群JNDI实现了高可靠性JNDI[8],通过服务器的集群,保证了JNDI的负载平衡和错误恢复。在全局共享的方式下,集群中的一个应用服务器保证本地JNDI树的独立性,并拥有全局的JNDI树。每个应用服务器在把部署的服务对象绑定到自己本地的JNDI树的同时,还绑定到一个共享的全局JNDI树,实现全局JNDI和自身JNDI的联系。

JNDI(Java Naming and Directory Interface)是一个应用程序设计的API,为开发人员提供了查找和访问各种命名和目录服务的通用、统一的接口,类似JDBC都是构建在抽象层上。
JNDI可访问的现有的目录及服务有:
DNS、XNam 、Novell目录服务、LDAP(Lightweight Directory Access Protocol 轻型目录访问协议)、 CORBA对象服务、文件系统、Windows XP/2000/NT/Me/9x的注册表、RMI、DSML v1&v2、NIS。
JNDI优点:
包含了大量的命名和目录服务,使用通用接口来访问不同种类的服务;
可以同时连接到多个命名或目录服务上;
建立起逻辑关联,允许把名称同Java对象或资源关联起来,而不必指导对象或资源的物理ID。
JNDI程序包:
javax.naming:命名操作;
javax.naming.directory:目录操作;
javax.naming.event:在命名目录服务器中请求事件通知;
javax.naming.ldap:提供LDAP支持;
javax.naming.spi:允许动态插入不同实现。
利用JNDI的命名与服务功能来满足企业级APIs对命名与服务的访问,诸如EJBs、JMS、JDBC 2.0以及IIOP上的RMI通过JNDI来使用CORBA的命名服务。
JNDI与JDBC:
JNDI提供了一种统一的方式,可以用在网络上查找和访问服务。通过指定一个资源名称,该名称对应于数据库或命名服务中的一个纪录,同时返回数据库连接建立所必须的信息。
代码示例:
try{
Context cntxt = new InitialContext();
DataSource ds = (DataSource) cntxt.lookup("jdbc/dpt");
}
catch(NamingException ne){
...
}
JNDI与JMS:
消息通信是软件组件或应用程序用来通信的一种方法。JMS就是一种允许应用程序创建、发送、接收、和读取消息的JAVA技术。
代码示例:
try{
Properties env = new Properties();
InitialContext inictxt = new InitialContext(env);
TopicConnectionFactory connFactory = (TopicConnectionFactory) inictxt.lookup("TTopicConnectionFactory");
...
}
catch(NamingException ne){
...
}
访问特定目录:举个例子,人是个对象,他有好几个属性,诸如这个人的姓名、电话号码、电子邮件地址、邮政编码等属性。通过getAttributes()方法
Attribute attr =
    directory.getAttributes(personName).get("email");
String email = (String)attr.get();
通过使用JNDI让客户使用对象的名称或属性来查找对象:
foxes = directory.search("o=Wiz,c=US", "sn=Fox", controls);
通过使用JNDI来查找诸如打印机、数据库这样的对象,查找打印机的例子:
Printer printer = (Printer)namespace.lookup(printerName);
printer.print(document);
浏览命名空间:
NamingEnumeration list = namespace.list("o=Widget, c=US");
while (list.hasMore()) {
NameClassPair entry = (NameClassPair)list.next();
display(entry.getName(), entry.getClassName());
}

参考资料:
http://java.sun.com/products/jndi/examples.html
http://java.sun.com/products/jndi/serviceproviders.html


常用的JNDI操作:
常用的JNDI操作:
void bind(String sName,Object object);――绑定:把名称同对象关联的过程
void rebind(String sName,Object object);――重新绑定:用来把对象同一个已经存在的名称重新绑定
void unbind(String sName);――释放:用来把对象从目录中释放出来
void lookup(String sName,Object object);――查找:返回目录总的一个对象
void rename(String sOldName,String sNewName);――重命名:用来修改对象名称绑定的名称
NamingEnumeration listBinding(String sName);――清单:返回绑定在特定上下文中对象的清单列表
NamingEnumeration list(String sName);
代码示例:重新得到了名称、类名和绑定对象。
NamingEnumeration namEnumList = ctxt.listBinding("cntxtName");
...
while ( namEnumList.hasMore() ) {
Binding bnd = (Binding) namEnumList.next();
String sObjName = bnd.getName();
String sClassName = bnd.getClassName();
SomeObject objLocal = (SomeObject) bnd.getObject();
}

JTA :
JTA(Java Transaction API) 为 J2EE 平台提供了分布式事务服务。
要用 JTA 进行事务界定,应用程序要调用 javax.transaction.UserTransaction 接口中的方法。例如:
utx.begin();
      // ...
      DataSource ds = obtainXADataSource();
      Connection conn = ds.getConnection();
      pstmt = conn.prepareStatement("UPDATE MOVIES ...");
      pstmt.setString(1, "Spinal Tap");
      pstmt.executeUpdate();
      // ...
      utx.commit();
让我们来关注下面的话:
“用 JTA 界定事务,那么就需要有一个实现 javax.sql.XADataSource 、 javax.sql.XAConnection 和 javax.sql.XAResource 接口的 JDBC 驱动程序。一个实现了这些接口的驱动程序将可以参与 JTA 事务。一个 XADataSource 对象就是一个 XAConnection 对象的工厂。 XAConnection s 是参与 JTA 事务的 JDBC 连接。”
要使用JTA事务,必须使用XADataSource来产生数据库连接,产生的连接为一个XA连接。
XA连接(javax.sql.XAConnection)和非XA(java.sql.Connection)连接的区别在于:XA可以参与JTA的事务,而且不支持自动提交。
     Note:
Oracle, Sybase, DB2, SQL Server等大型数据库才支持XA, 支持分布事务。 
My SQL 连本地都支持不好,更别说分布事务了。
JTA方式的实现过程:
   用XADataSource产生的XAConnection它扩展了一个getXAResource()方法,事务通过这个方法把它加入到事务容器中进行管理.对于调用者来说,根本看不到事务是如果管理的,你只要声明开始事务,告诉容器我下面的操作要求事务参与了,最后告诉事务说到这儿可以提交或回滚了,别的都是黑箱操作。
在使用JTA之前,你必须首先实现一个Xid类用来标识事务(在普通情况下这将由事务管理程序来处理)。Xid包含三个元素:formatID、gtrid(全局事务标识符)和bqual(分支修饰词标识符)。
下面的例子说明Xid的实现:
import javax.transaction.xa.*; 
public class MyXid implements Xid 

protected int formatId; 
protected byte gtrid[]; 
protected byte bqual[]; 
public MyXid() 


public MyXid(int formatId, byte gtrid[], byte bqual[]) 

this.formatId = formatId; 
this.gtrid = gtrid; 
this.bqual = bqual; 

public int getFormatId() 

return formatId; 

public byte[] getBranchQualifier() 

return bqual; 

public byte[] getGlobalTransactionId() 

return gtrid; 

}
其次,你需要创建一个你要使用的数据库的数据源:
public DataSource getDataSource() 
throws SQLException 

SQLServerDataSource xaDS = new 
com.merant.datadirect.jdbcx.sqlserver.SQLServerDataSource(); 
xaDS.setDataSourceName("SQLServer"); 
xaDS.setServerName("server"); 
xaDS.setPortNumber(1433); 
xaDS.setSelectMethod("cursor"); 
return xaDS; 

例1?这个例子是用“两步提交协议”来提交一个事务分支:
XADataSource xaDS; 
XAConnection xaCon; 
XAResource xaRes; 
Xid xid; 
Connection con; 
Statement stmt; 
int ret; 
xaDS = getDataSource(); 
xaCon = xaDS.getXAConnection("jdbc_user", "jdbc_password"); 
xaRes = xaCon.getXAResource(); 
con = xaCon.getConnection(); 
stmt = con.createStatement(); 
xid = new MyXid(100, new byte[], new byte[]); 
try { 
xaRes.start(xid, XAResource.TMNOFLAGS); 
stmt.executeUpdate("insert into test_table values (100)"); 
xaRes.end(xid, XAResource.TMSUCCESS); 
ret = xaRes.prepare(xid); 
if (ret == XAResource.XA_OK) { 
    xaRes.commit(xid, false); 
   } 

catch (XAException e) { 
e.printStackTrace(); 

finally { 
stmt.close(); 
con.close(); 
xaCon.close(); 
}
当然,实际过程中,我们不需要写这些代码,这些代码是JTA最终的实现代码。
关于“两步提交协议”,可以参看下面的文章:
http://www.jspcn.net/htmlnews/11049371131251752.html
http://www.vermicelli.pasta.cs.uit.no/ipv6/students/andrer/doc/html/node18.html

选择最好的方式
用 JDBC API 进事务界定来构建 DAO 类的。这些 DAO 类可以总结如下:
事务界定代码嵌入在 DAO 类中。 
DAO 类使用 JDBC API 进行事务界定。 
调用者不能界定事务。 
事务范围局限于单个 JDBC 连接。 
JDBC 事务并不总是适合复杂的企业应用程序。如果您的事务要跨越多个 DAO 或者多个数据库,那么下列实现策略也许更合适:
事务用 JTA 界定。 
事务界定代码从 DAO 中分离出来。 
调用者负责界定事务。 
DAO 加入一个全局事务。 
JDBC 方式由于其简单性而具有吸引力,JTA 方式提供了更大的灵活性。您所选择的实现将取决于应用程序的特定需求。
XADataSource例子:
<?xml version="1.0" encoding="UTF-8"?>
<!-- ===================================================================== -->
<!--    -->
<!-- JBoss Server Configuration    -->
<!-- Thanks to Horia Muntean <horia@bvb.ro>   -->
<!-- ===================================================================== -->
<!-- $Id: db2-xa-ds.xml,v 1.1.2.1 2003/05/30 18:25:57 d_jencks Exp $ -->

<datasources>
   <!--
       XADatasource for DB2 V8.1 (app driver)
       copy $db2_install_dir/java/db2java.zip into $jboss_install_dir/server/default/lib
   -->
   <xa-datasource>
     <jndi-name>DB2XADS</jndi-name>
     <xa-datasource-class>COM.ibm.db2.jdbc.DB2XADataSource</xa-datasource-class>
     <xa-datasource-property name="DatabaseName">yout_database_name</xa-datasource-property>
     <xa-datasource-property name="User">your_user</xa-datasource-property>
     <xa-datasource-property name="Password">your_password</xa-datasource-property>
   </xa-datasource>
</datasources>

JMS:

JMS(Java Messaging Service)是Java平台上有关面向消息中间件的技术规范,翻译为Java消息服务。JMS支持点对点和发布/订阅两种消息模型。

JMS基本概念
1.JMS(Java Message Service)是访问企业消息系统的标准API,它便于消息系 
统中的Java应用程序进行消息交换,并且通过提供标准的产生、发送、接收消息的接口简化企业应用的开发。 
2. JMS基本功能 
JMS是用于和面向消息的中间件相互通信的应用程序接口。它既支持点对点(point-to-point)的域,又支持发布/订阅(publish/subscribe)类型的域,并且提供对下列类型的支持:经认可的消息传递,事务型消息的传递,一致性消息和具有持久性的订阅者支持。JMS还提供了另一种方式来对您的应用与旧的后台系统相集成。 
3. WebLogic JMS Server介绍 
WebLogic Server8.1符合JAVA规范,并通过Sun Microsystems J2EE 1.3认 
证.作为WebLogic的一部分,当然WebLogic JMS Server也完全遵从JMS规范,还支持集群,并可以应用于实际企业系统.下图是WebLogic JMS Server体系结构.图中可以看到WebLogic JMS Server主要组件有: WebLogic JMS servers(用于消息通信),Java客户端,JNDI(用于域名查找), 后备存储(用于持久消息存储,基于文件或者JDBC数据库). 

WebLogic JMS特性
1. 消息通信模型 
JMS 支持两种消息通信模型:点到点(point-to-point)(PTP)模型和发布/订阅(Pub/Sub)模型。除了下列不同之外,这两种消息通信模型非常地相似: 
PTP 模型规定了一个消息只能有一个接收者;Pub/Sub 模型允许一个消息可以有多个接收者。 
2. 消息组成 
消息传递系统的中心就是消息。 
一条 Message 分为三个组成部分: 
· 头(header)是个标准字段集,客户机和供应商都用它来标识和路由消息。 
· 属性(property)支持把可选头字段添加到消息。如果您的应用程序需要不使用标准头字段对消息编目和分类,您就可以添加一个属性到消息以实现这个编目和分类。提供 set<Type>Property(...) 和 get<Type>Property(...) 方法以设置和获取各种 Java 类型的属性,包括 Object。JMS 定义了一个供应商选择提供的标准属性集。 
· 消息的主体(body)包含要发送给接收应用程序的内容。每个消息接口特定于它所支持的内容类型。 
JMS 为不同类型的内容提供了它们各自的消息类型,但是所有消息都派生自 Message 接口。 
· StreamMessage:包含 Java 基本数值流,用标准流操作来顺序的填充和读取。 
· MapMessage:包含一组名/值对;名称为 string 类型,而值为 Java 的基本类型。 
· TextMessage:包含一个 String。 
· ObjectMessage:包含一个 Serializable Java 对象;能使用 JDK 的集合类。 
· BytesMessage:包含未解释字节流: 编码主体以匹配现存的消息格式。 
· XMLMessage: 包含XML内容。扩展TextMessage,XMLMessage 类型的使用,使得消息过滤非常便利。 
3. 消息确认模式 
非事务性会话中,应用程序创建的会话有5 种确认模式,而在事务性会话中,确认模式被忽略。 
五种确认模式说明: 
· AUTO_ACKNOWLEDGE:自动确认模式。一旦接收方应用程序的方法调用从处理消息处返回,会话对象就会确认消息的接收。 
· CLIENT_ACKNOWLEDGE:客户端确认模式。会话对象依赖于应用程序对被接收的消息调用一个acknowledge()方法。一旦这个方法被调用,会话会确认最后一次确认之后所有接收到的消息。这种模式允许应用程序以一个调用来接收,处理并确认一批消息。注意:在管理控制台中,如果连接工厂的Acknowledge Policy(确认方针)属性被设置为"Previous"(提前),但是你希望为一个给定的会话确认所有接收到的消息,那么就用最后一条消息来调用acknowledge()方法。 
· DUPS_OK_ACKNOWLEDGE:允许副本的确认模式。一旦接收方应用程序的方法调用从处理消息处返回,会话对象就会确认消息的接收;而且允许重复确认。在需要考虑资源使用时,这种模式非常有效。注意:如果你的应用程序无法处理重复的消息的话,你应该避免使用这种模式。如果发送消息的初始化尝试失败,那么重复的消息可以被重新发送。 
· NO_ACKNOWLEDGE:不确认模式。不确认收到的消息是需要的。消息发送给一个NO_ACKNOWLEDGE 会话后,它们会被WebLogic 服务器立即删除。在这种模式下,将无法重新获得已接收的消息,而且可能导致下面的结果:1. 消息可能丢失;和(或者)另一种情况:2. 如果发送消息的初始化尝试失败,会出现重复消息被发送的情况。 
· MULTICAST_NO_ACKNOWLEDGE:IP组播下的不确认模式,同样无需确认。发送给一个MULTICAST_NO_ACKNOWLEDGE会话的消息, 会共享之前所述的NO_ACKNOWLEDGE 确认模式一样的特征。这种模式支持希望通过IP 组播方式进行消息通信的应用程序,而且无需依赖会话确认提供的服务质量。注意:如果你的应用程序无法处理消息的丢失或者重复,那么你应该避免使用这种模式。如果发送消息的初始化尝试失败的话,重复的消息可能会被再次发送。 
注:在上表的5 种确认模式中,AUTO_ACKNOWLEDGE ,DUPS_OK_ACKNOWLEDGE 和 
CLIENT_ACKNOWLEDGE 是JMS 规范定义的,NO_ACKNOWLEDGE 和MULTICAST_NO_ACKNOWLEDGE是WebLogic JMS 提供的。

分享到:
评论

相关推荐

    JMS-详解[收集].pdf

    - JNDI:JMS客户端通过JNDI(Java Naming and Directory Interface)查找并使用JMS对象,如ConnectionFactory和Destination。 2. JMS编程模型: - ConnectionFactory:这是用于创建Connection的工厂类,通常在jms...

    ActiveMq-JMS好用实例详解

    ### ActiveMQ-JMS好用实例详解 #### 一、ActiveMQ简介及特点 **ActiveMQ** 是一个非常流行的开源消息中间件,它基于 **Java消息服务(JMS)** 规范,能够提供高度可靠的消息传递机制。ActiveMQ 以其丰富的功能集、...

    JMS1.1规范中文版

    ### JMS 1.1 规范中文版详解 #### 一、引言与概述 **JMS 1.1规范**是针对Java应用程序的消息传递系统制定的一套标准,其目的是确保不同消息传递系统之间的互操作性和移植性。随着Java技术在企业级应用中的普及,...

    J2EE应用开发详解

    它提供了丰富的API和服务,包括Servlet、JSP、EJB、JMS、JTA等,以支持并发、事务处理、安全性和可伸缩性等关键特性。 1. **Servlet**:Servlet是Java Web开发的基础,它是一个服务器端的小程序,用于扩展服务器的...

    JavaEE5学习笔记01-JTA和数据库事务

    #### 二、JTA:Java事务API详解 ##### 2.1 JTA的基本概念 JTA(Java Transaction API)是JavaEE5中用于管理分布式事务的标准接口,它定义了一套API,用于协调跨多个资源管理器(如数据库、消息队列)的事务。JTA由...

    J2EE 经典实例详解

    《J2EE经典实例详解》是一本专注于Java企业级应用开发的实践指南,它通过一系列精选的实例,帮助开发者深入理解和熟练运用J2EE技术。J2EE(Java 2 Platform, Enterprise Edition)是Java平台的企业版,为构建分布式...

    J2EE 经典实例详解10

    8. **JTA与JMS的结合**:在大型企业应用中,JTA经常与JMS一起使用,以确保跨多个系统和组件的事务一致性。例如,一个交易可能涉及数据库更新和消息发布,JTA确保这两个操作要么全部成功,要么全部回滚。 9. **Web...

    J2EE应用开发详解(罗玉玲版)光盘内容(源代码)

    光盘中的源代码可能涵盖了诸如Servlet、JSP、EJB(Enterprise JavaBeans)、JMS(Java Message Service)、JTA(Java Transaction API)、JNDI(Java Naming and Directory Interface)等关键组件的实例。...

    j2ee 经典实例详解3

    这本书旨在帮助开发者理解并熟练掌握J2EE的各项技术,包括Servlet、JSP、EJB(Enterprise JavaBeans)、JMS(Java Message Service)、JTA(Java Transaction API)以及JNDI(Java Naming and Directory Interface)...

    J2EE试题(j2ee)

    本试题集涵盖了J2EE的关键知识点,包括但不限于Servlet、JSP、EJB、JNDI、JMS、JTA、JDBC以及MVC设计模式等。以下是对这些主题的详细解释: 1. **Servlet**:Servlet是Java编写的服务器端程序,主要功能是接收并...

    TongLinkQ开发手册

    - **JMS与其他企业级Java API的关系**:JMS通常与其他Java企业级API(如JDBC、JTA)协同工作,共同构建复杂的企业应用。 - **JMS消息模型**: - **点到点的消息模型**:每个消息都有一个明确的目标接收者。 - **...

    用友笔试题用友笔试题用友笔试题

    3. **JNDI、JMS、JTA、RMI**: - JNDI(Java Naming and Directory Interface):提供了一种标准的接口,用于查找和访问各种命名和目录服务,如DNS、LDAP等。 - JMS(Java Messaging Service):Java平台上的消息...

    J2EE 经典实例详解5

    《J2EE经典实例详解5》是一本深入探讨J2EE技术的专著,通过一系列精选实例,旨在帮助读者理解并掌握J2EE平台的核心技术和实际应用。J2EE(Java 2 Platform, Enterprise Edition)是Java技术在企业级开发中的重要框架...

    J2EE 经典实例详解(201-250)

    在J2EE中,核心概念包括Servlet、JavaServer Pages (JSP)、JavaBean、EJB(Enterprise JavaBeans)、JMS(Java Message Service)、JTA(Java Transaction API)以及JNDI(Java Naming and Directory Interface)等...

    J2EE经典实例详解

    6. **JNDI(Java Naming and Directory Interface)**:提供了一种查找和绑定资源的机制,如数据库连接池、邮件服务器等。 7. **JSF(JavaServer Faces)**:一种MVC(模型-视图-控制器)框架,简化了创建用户界面...

    J2EE开发详解一书的光盘

    J2EE(Java 2 Platform, Enterprise Edition)是Oracle公司推出的用于构建分布式、多层的企业级应用程序的平台,它提供了丰富的API和服务,包括Servlet、JSP、EJB、JMS、JTA等,以支持Web应用、事务处理、消息传递等...

    j2ee 经典实例详解

    6. **JTA(Java Transaction API)**:JTA提供了一个标准的API,用于管理分布式事务,确保数据的一致性。 7. **JPA(Java Persistence API)**:JPA是Java平台上的对象关系映射(ORM)标准,它简化了Java应用程序与...

    J2EE 经典实例详解(1-100)

    这个平台提供了丰富的服务和组件,包括但不限于:Servlet、JSP(JavaServer Pages)、EJB(Enterprise JavaBeans)、JMS(Java Message Service)、JTA(Java Transaction API)等,旨在简化开发、部署和管理大型...

Global site tag (gtag.js) - Google Analytics