WebLogic Tuxedo Connector (WTC) 是一个兼容 JCA ( J2EE 连接器架构)的软件组件,它提供 Tuxedo 服务和 WebLogic Server 部署的企业应用程序之间的互操作性。 WebLogic Server 组件能够使用 WTC 与 Tuxedo 服务进行通信, Tuxedo 服务也能够调交互用基于 WebLogic Server 的 EJB 。
手动配置 WebLogic Tuxedo Connector 是非常沉闷乏味且易于出错的操作,从这种观点出发,本文提出了两种编程式可选解决方案。第一种基于 JMX ,第二种基于对命令行方式的 weblogic.Admin 工具的使用。本文提供了 Java 类库,既能生成所需的 JMX 对象又能生成基于 weblogic.Admin 的 shell 文件。
Tuxedo 服务已经存在多年了,而且很多 EIS (企业信息系统)就是以这种服务功能为基础,比如事务支持、域和 ACL (访问控制列表)安全、域级别故障转移和反馈、以及高级消息服务。另一方面, J2EE 应用程序不能保持与现有的信息系统隔离;它们必须能够支持 Tuxedo 事务,在 CORBA Java 和 CORBA C++ 之间进行互操作,同时也要能够在 Java RMI/IIOP 和 Tuxedo CORBA 之间互操作。
WTC 实现了所有这些方案和一些其他可能类似 JATMI ( Java 应用程序到事务监控器接口)的实现方案,其中 JATMI 是一种与 Tuxedo ATMI 类似的协议。
WTC 实现了所有这些方案和一些其他可能类似 JATMI ( Java 应用程序到事务监控器接口)的实现方案,其中 JATMI 是一种与 Tuxedo ATMI 类似的协议。
说明了 Tuxedo 服务对于 EIS 的重要性,并说明了 WTC 在 EIS 和基于新技术的 J2EE 组件之间所起的关联作用之后,本文的目标是给出在 WebLogic Server 环境中几个 WTC 配置的例子。事实上,为了双向连接到 Tuxedo 域而对 WebLogic Server 进行配置以便使用 WTC 就是一件费力且易于出错的事情,本文给出了两种编程式配置解决方案。它们为基于 WebLogic Server 控制台的方案提供了一种选择,这也许是已知的最佳方法。两种方案其中之一是以使用 weblogic.Admin 工具为基础,并且必将令系统管理员受益。另一个方案是以 JMX ( Java Management Extension )为基础,并极有可能吸引开发人员的注意力。
不论采用哪种方案, WTC 配置过程都基于下列一般步骤:
在全文中,我们都将遵循这些步骤,并且我们将对在三个配置方案中分别执行的方法进行强调。
通过 WebLogic Server 控制台配置 WTC
这是为您的应用程序配置 WTC 的标准方法。它包括了对 WebLogic Server 控制台 GUI 的使用。虽然有很多优点(其中最重要的是其简单性),但这种方案也具有费力、重复、易错等缺点。启动 WebLogic Server 和它的管理控制台之后,您可按照下列步骤来配置 WTC 服务。
正如您所见,通过WebLogic Server管理控制台来配置WTC的确是非常费力的,因为我们必须自己进行很多操作。另外,如果我们需要创建几个这样的WTC域,我们将不得不重复这些操作。这增加了在配置过程中犯错的机会。在这种情况下,关于能创建基于WTC参数的新配置工具的想法显得十分具有吸引力。
通过 JMX 配置 WTC
作为一个可对其进行完全管理的分布式资源,能够通过 JMX ( Java Management Extension )使 WebLogic Server 仪表化。这将通过 Mbean 服务器实现,它作为独立 WebLogic 实例上的 Mbeans 的主机,允许客户创建、访问、检索并修改 WebLogic 域分布对象(比如 JDBC 连接池、 JMS 服务器、目的地和工厂)。从 WTC 的角度出发,你能够通过创建新的特定 WTCMbeans 来创建新 WTC 域。
在以编程的方式创建并处理 WebLogic 分布对象的过程中,我们既可以使用 JMX 标准类的接口(由向 Mbean 传递操作名和一系列参数来调用 Mbean 的操作组成),也可以使用 WebLogic 的类型安全实现(它为每个 Mbean 类型提供了独立接口)。
因为 WebLogic 域可能分布在多个计算机上,这些计算机具有不同部署,而且资源的目标各不相同,所以每个 WebLogic 实例的 Mbean 服务器将拥有三个不同的 Mbeans 集:
提到WTC域时,我们将集中在配置Mbeans上。这种类型的Mbeans拥有对所有托管资源(如web服务器、集群、JDBC连接池和更多的包括WTC域在内的资源)的配置。
WebLogic 实例上的 Mbean 服务器能够通过 weblogic.management.MbeanHome 接口到达。可以获得以下 home 接口的两种实现:
Home接口既能通过查找服务器的JNDI树检索,又能通过WebLogic特定的帮助类检索。例如,以下代码对本地home接口进行检索:
import weblogic.management.*; MBeanHome localHome = (MBeanHome)Helper.getMBeanHome (username,password, url, serverName);
以上代码调用 Helper 类的 getMBeanHome() 方法,向它传递用户名、密码、 WebLogic Server URL 和服务器名。类似地,要检索管理 home 接口,则调用相同 Helper 类的 getAdminMBeanHome 方法,但只需向其传送用户名、密码和管理服务器 URL ,如下例所示:
清单 2 检索管理 home 接口
import weblogic.management.*; MBeanHome localHome = (MBeanHome)Helper.getAdminMBeanHome (username, password, url);
使用 JNDI ( Java 命令目录接口)也同样容易。本地和管理返回地址存储在 MBeanHome.LOCAL_JNDI_NAME 常量和 MBeanHome.ADMIN_JNDI_NAME 常量中。以下代码示例显示了如何进行:
清单 3 使用 JNDI 检索本地 home 接口。
Hashtable ht = new Hashtable(); ht.put (Context.INITIAL_CONTEXT_FACTORY, "weblogic.jndi.WLInitialContextFactory"); ht.put (Context.PROVIDER_URL, "t3://adminserver:8001"); InitialContext ic = new InitialContext (ht); MBeanHome localHome = (MBeanHome)ic.lookup (MBeanHome.LOCAL_JNDI_NAME);
我们已经能够检索本地 / 管理接口,接下来将查看怎样在 JMX 中实现配置 WTC 域所需的 6 步。
清单 4 创建 WTC 服务。
WTCServerMBean wtcServerMBean = homeMBean.createAdminMBean ("myWTCDomain", "WTCServer", "myWebLogicServerDomain");
清单 5 创建本地 Tuxedo 访问点。
WTCLocalTuxDomMBean wtcLocalTuxDomMBean = (WTCLocalTuxDomMBean) homeMBean.createAdminMBean("myLocalTuxDom","WTCLocalTuxDom", getWebLogicDomainName()); wtcLocalTuxDomMBean.setAccessPoint(getLocalAccessPointName()); wtcLocalTuxDomMBean.setAccessPointId(getLocalAccessPointId()); wtcLocalTuxDomMBean.setNWAddr(getLocalNetworkAddress()); wtcLocalTuxDomMBean.setConnectionPolicy("ON_DEMAND"); wtcLocalTuxDomMBean.setSecurity("NONE"); wtcServerMBean.addLocalTuxDom(wtcLocalTuxDomMBean);
清单 6 创建远程 Tuxedo 访问点。
WTCRemoteTuxDomMBean wtcRemoteTuxDomMBean = (WTCRemoteTuxDomMBean) homeMBean.createAdminMBean("myRemoteTuxDom", "WTCRemoteTuxDom", "myWebLogicServerDomain"); wtcRemoteTuxDomMBean.setAccessPoint ("myRemoteAccessPoint"); wtcRemoteTuxDomMBean.setAccessPointId("myRemoteAccessPointId"); wtcRemoteTuxDomMBean.setNWAddr("myRemoteNetworkAddress"); wtcRemoteTuxDomMBean.setLocalAccessPoint("myLocalTuxDom"); wtcServerMBean.addRemoteTuxDom(wtcRemoteTuxDomMBean);
清单 7 导出服务。
WTCExportMBean wtcExportMBean = (WTCExportMBean) homeMBean.createAdminMBean ("myRemoteTuxDom", "WTCExport", "myWebLogicServerDomain"); wtcExportMBean.setResourceName ("myExportedResource"); wtcExportMBean.setLocalAccessPoint ("myLocalTuxDom"); wtcExportMBean.setEJBName ("myResourceJndiName"); wtcServerMBean.addExport(wtcExportMBean);
清单 8 导入服务。
WTCImportMBean wtcImportMBean = (WTCImportMBean) homeMBean.createAdminMBean ("myRemoteTuxDom","WTCImport", "myWebLogicServerDomain"); wtcImportMBean.setResourceName ("myImportedResource"); wtcImportMBean.setLocalAccessPoint ("myLocalAccessPoint"); wtcImportMBean.setRemoteAccessPointList ("myRemoteAccessPoint"); wtcServerMBean.addImport(wtcImportMBean);
清单 9 为服务器分配 WTC 服务。
wtcServerMBean.addTarget ((TargetMBean)homeMBean.getMBeanServer());
使用 weblogic.Admin 工具配置 WTC
weblogic.Admin 是一个能用于编写 WebLogic Server 脚本的 Java 工具。因为 weblogic.Admin 能够操纵 JMX 数据,所以将它用来配置 WTC 域也许会比较简便。
在我们能够使用 weblogic.Admin 工具配置 WTC 域前,我们必须理解 WebLogic 是怎样对其 Mbeans 进行命名的。每个由 Mbean 服务器宿主的 Mbean 都拥有独一无二的名称,并且每个名称都使用 JMX ObjectName 类的实例构建,它们扩展了 ObjectName 来携带附加信息。 Mbean 的名字遵循以下格式:
<domain>:Name=<name>,Type=<type>[,Location=<server>][<attr>=<value>]*
where:
<domain> is the name of the WebLogic domain to which the MBean server belongs
<name> is the name of the resource associated with the MBean
<type> is the name of the MBean
<server> is the name of the server hosting the MBean server
<attr> and <value> are name-value pairs for MBean attributes
现在让我们看一下怎样通过该工具配置 WTC 域。
java weblogic.Admin -url t3://localhost:8001 -username weblogic -password weblogic CREATE -mbean "myDomain:Name=myWtcService,Type=WTCServer"
java weblogic.Admin ... CREATE -mbean "myDomain:Name=myLoclTuxDom, Type=WTCLocalTuxDom,WTCServer=myWtcService" java weblogic.Admin ... SET -mbean "myDomain:Name=myLoclTuxDom,Type=WTCLocalTuxDom,WTCServer=myWtcService -property AccessPoint MyLclAccessPt -property AccessPointId MyLclAccessPtId -property NWAddr //footse:9010 -property ConnectionPolicy ON_DEMAND -property Security NONE" java weblogic.Admin ... SET -mbean "myDomain:Name=myWtcService,Type=WTCServer -property LocalTuxDoms myDomain:Name=myLoclTuxDom,Type=WTCLocalTuxDom, WTCServer=myWtcService"
java weblogic.Admin ... CREATE -mbean "myDomain:Name=myRemoteTuxDom, Type=WTCRemoteTuxDom,WTCServer=myWtcService" java weblogic.Admin ... SET -mbean "myDomain:Name=myRemoteTuxDom,Type=WTCRemoteTuxDom,WTCServer=myWtcService -property AccessPoint MyRemoteAccessPt -property AccessPointId MyRemoteAccessPtId -property NWAddr //footse:9020 -property LocalAccessPoint MyLclAccessPt" java weblogic.Admin ... SET -mbean "myDomain:Name=myWtcService,Type=WTCServer -property RemoteTuxDoms myDomain:Name=myRemoteTuxDom,Type=WTCRemoteTuxDom, WTCServer=myWtcService"
java weblogic.Admin ... CREATE -mbean "myDomain:Name=myExportedResources, Type=WTCExport,WTCServer=myWtcService" java weblogic.Admin ... SET -mbean "myDomain:Name=myExportedResources,Type=WTCExport, WTCServer=myWtcService -property ResourceName myExportedService -property EJBName myServiceJNDIName -property LocalAccessPoint MyLclAccessPt" java weblogic.Admin ... SET -mbean "myDomain:Name=myWtcService,Type=WTCServer -property Exports myDomain:Name=myExportedResources, Type=WTCExport,WTCServer=myWtcService"
java weblogic.Admin ... CREATE -mbean "myDomain:Name=myImportedResources, Type=WTCImport,WTCServer=myWtcService" java weblogic.Admin ... SET -mbean "myDomain:Name=myImportedResources,Type=WTCImport, WTCServer=myWtcService -property ResourceName myImportedService -property RemoteAccessPoint MyRemoteAccessPt -property LocalAccessPoint MyLclAccessPt" java weblogic.Admin ... SET -mbean "myDomain:Name=myWtcService,Type=WTCServer -property Imports myDomain:Name=myImportedResources, Type=WTCImport,WTCServer=myWtcService"
java weblogic.Admin ... SET -mbean myDomain:Name=myWtcService,Type=WTCServer -property Targets myDomain:Name=myServer,Type=Server
另一个允许用户对创建、查看、监控或修改 Mbeans 等活动进行记录的灵活工具是 WLShell ,该工具也许能从 dev2dev web 站点下载。关于它的详细文档可在网址 http://www.wlshell.com 上找到 。
结束语
使用 WebLogic Administration Console 来配置 WTC 域也许在某些方案中实用,但它很快就会产生重复性,并生成错误。编程式解决方案能够缓解这个问题,本文对这样的两种方案进行了说明。第一种以标准 JMX 解决方案为基础,而第二种方案使用功能强大的、以 weblogic.Admin 工具为基础的脚本命令。
本文所附代码样例提供了对这些想法的实现。