Tuxedo Multi-Domains 配置

2023-10-11 19:32
文章标签 配置 multi domains tuxedo

本文主要是介绍Tuxedo Multi-Domains 配置,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

简介:本文适合初学tuxedo 。使用的例子也是tuxedo为我们提供的simpapp。

master   192.168.1.127   提供TOLOWER服务

backup   192.168.1.128   提供TOLOWER服务


客户端程序 simpcl.c 中tpcall调用TOLOWER 服务。
ret = tpcall("TOLOWER", (char *)sendbuf, 0, (char **)&rcvbuf, &rcvlen, (long)0);

服务端程序  simpserv.c 增加TOLOWER 函数,保证客户端能够调用。

void TOLOWER(TPSVCINFO *rqst)
{
        int i;

        for(i = 0; i < rqst->len-1; i++)
                rqst->data[i] = tolower(rqst->data[i]);

        /* Return the transformed buffer to the requestor. */
        tpreturn(TPSUCCESS, 0, rqst->data, 0L, 0);
}


一:环境

linux:centos 6.2  i386

tuxedo: Oracle Tuxedo, Version 11.1.1.2.0, 32-bit, Patch Level (none)

需要的文件:

lower 编译好的客户端调用tolower服务的程序。

toupper编译好的客户端调用toupper服务的程序

bdmconfig 编译好的二进制域配置文件


二详细操作步骤

1.设置环境变量

建议两台机子最好一样,避免出错。

TUXDIR=/home/tux/Oracle; export TUXDIR
JAVA_HOME=$TUXDIR/jre; export JAVA_HOME
JVMLIBS=$JAVA_HOME/lib/i386/server:$JAVA_HOME/jre/bin
PATH=$TUXDIR/bin:$JAVA_HOME/bin:$PATH; export PATH
COBCPY=:$TUXDIR/cobinclude; export COBCPY
COBOPT="-C ANS85 -C ALIGN=8 -C NOIBMCOMP -C TRUNC=ANSI -C OSEXT=cbl"; export COBOPT
SHLIB_PATH=$TUXDIR/lib:$JVMLIBS:$SHLIB_PATH; export SHLIB_PATH
LIBPATH=$TUXDIR/lib:$JVMLIBS:$LIBPATH; export LIBPATH
LD_LIBRARY_PATH=$TUXDIR/lib:$JVMLIBS:$LD_LIBRARY_PATH; export LD_LIBRARY_PATH
WEBJAVADIR=$TUXDIR/udataobj/webgui/java; export WEBJAVADIR
LANG=C; export LANG
APPDIR=/home/tux/simpapp; export APPDIR
TUXCONFIG=$APPDIR/tuxconfig; export TUXCONFIG
BDMCONFIG=/home/tux/simpapp/bdmconfig; export BDMCONFIG

2  .编写ubbconfig 文件

以下是master机子上的,只提供tolower服务。backup机子类似,只不过把服务改成toupper。

[tux@master simpapp]$ vi ubbsimple 
MASTER          TUX1
MAXACCESSERS    150
MAXSERVERS      120
MAXSERVICES     120
MODEL           SHM*MACHINES
DEFAULT:master          LMID=TUX1APPDIR="/home/tux/simpapp"TUXCONFIG="/home/tux/simpapp/tuxconfig"TUXDIR="/home/tux/Oracle"MAXWSCLIENTS=5*GROUPS
GROUP1          LMID=TUX1       GRPNO=1                 OPENINFO=NONE
LDMGRP          LMID=TUX1       GRPNO=20
LGWGRP          LMID=TUX1       GRPNO=30*SERVERS
DEFAULT:CLOPT="-A"simpserv        SRVGRP=GROUP1 SRVID=1
WSL             SRVGRP=GROUP1 SRVID=10CLOPT="-A -- -n //192.168.1.127:3200 -m 2 -M 5 -x 10 -p 4500 -P 5000"DMADM           SRVGRP=LDMGRP SRVID=1
GWADM           SRVGRP=LGWGRP SRVID=100
GWTDOMAIN       SRVGRP=LGWGRP SRVID=200 REPLYQ=N*SERVICES
TOLOWER

3.编写domconfig文件

master机器的配置文件:

*DM_RESOURCES
VERSION=test1*DM_LOCAL_DOMAINS
LAPP    GWGRP=LGWGRPTYPE=TDOMAINDOMAINID="LAPP"DMTLOGDEV="/home/tux/simpapp/DLOG"
*DM_REMOTE_DOMAINS
UAPP    TYPE=TDOMAINDOMAINID="UAPP"*DM_TDOMAIN
LAPP    NWADDR="//192.168.1.127:7000"
UAPP    NWADDR="//192.168.1.128:7000"*DM_REMOTE_SERVICES
TOUPPER*DM_LOCAL_SERVICES
TOLOWER

backup远端机器域配置文件如下:

*DM_RESOURCES
VERSION=Utest1*DM_LOCAL_DOMAINS
UAPP    GWGRP=UGWGRPTYPE=TDOMAINDOMAINID="UAPP"DMTLOGDEV="/home/tux/simpapp/DLOG"*DM_REMOTE_DOMAINS
LAPP     TYPE=TDOMAIN   DOMAINID="LAPP"*DM_TDOMAIN
LAPP NWADDR="//192.168.1.127:7000"
UAPP NWADDR="//192.168.1.128:7000"*DM_LOCAL_SERVICES
TOUPPER*DM_REMOTE_SERVICES
TOLOWER

4.在backup机子上执行如上1、2、3操作。只更改服务为toupper服务。

5. 编译配置文件,以及客户端和服务端程序。

buildserver -f simpserv -o simpserv -s TOUPPER -s TOLOWER   

buildclient -f simpcl.c -o lower  

tmloadcf -y ubbsimple (执行之后会生成tuxconfig二进制文件)

dmloadcf -y dmconfig(执行后会生成bdmconfig二进制文件)

6.启动tuxedo。

7.至此整个配置过程已经结束。接下来看一下tuxedo客户端调用服务。我们的客户端是不知道服务在哪台机子上的。

tolower服务在master机子上,我们可以在backup机子的客户端调用tolower服务。因为bakcup机子上的UAPP domain 中不包括这个服务,他就会调用远端机子的tolower的服务。

首先我们看 master机子的服务还没有一笔交易:

[tux@master simpapp]$ tmadmin
tmadmin - Copyright (c) 1996-2010 Oracle.
Portions * Copyright 1986-1997 RSA Data Security, Inc.
All Rights Reserved.
Distributed under license by Oracle.
Tuxedo is a registered trademark.> d -m TUX1TUX1> psr
Prog Name      Queue Name  Grp Name      ID RqDone Load Done Current Service
---------      ----------  --------      -- ------ --------- ---------------
BBL            123456      TUX1           0      0         0 (  IDLE )
DMADM          00020.00001 LDMGRP         1      7       350 (  IDLE )
simpserv       00001.00001 GROUP1         1      0         0 (  IDLE )
WSL            00001.00010 GROUP1        10      0         0 (  IDLE )
GWADM          00030.00100 LGWGRP       100      0         0 (  IDLE )
GWTDOMAIN      00030.00200 LGWGRP       200      0         0 (  IDLE )TUX1> 

在远端机子调用: 

[tux@backup simpapp]$ ./lower "HELLO WORLD"
Returned string is: hello world
[tux@backup simpapp]$

查看master机子 已经有一笔交易:这笔交易就是由远端的tuxedo客户端调用。

TUX1> psr
Prog Name      Queue Name  Grp Name      ID RqDone Load Done Current Service
---------      ----------  --------      -- ------ --------- ---------------
BBL            123456      TUX1           0      0         0 (  IDLE )
DMADM          00020.00001 LDMGRP         1      7       350 (  IDLE )
simpserv       00001.00001 GROUP1         1      1        50 (  IDLE )
WSL            00001.00010 GROUP1        10      0         0 (  IDLE )
GWADM          00030.00100 LGWGRP       100      0         0 (  IDLE )
GWTDOMAIN      00030.00200 LGWGRP       200      0         0 (  IDLE )TUX1> 

----------------------------------------------------------------------------------------------------------------------------------------

同理我们在master 机器调用调用远端机子的toupper服务

调用之前:

[tux@backup simpapp]$ tmadmin
tmadmin - Copyright (c) 1996-2010 Oracle.
Portions * Copyright 1986-1997 RSA Data Security, Inc.
All Rights Reserved.
Distributed under license by Oracle.
Tuxedo is a registered trademark.> d - m^H
TMADMIN_CAT:145: ERROR: Syntax error on command line.> d -m backupbackup> psr
Prog Name      Queue Name  Grp Name      ID RqDone Load Done Current Service
---------      ----------  --------      -- ------ --------- ---------------
BBL            123456      backup         0      0         0 (  IDLE )
DMADM          00020.00001 UDMGRP         1      7       350 (  IDLE )
simpserv       00001.00001 GROUP1         1      0         0 (  IDLE )
WSL            00001.00010 GROUP1        10      0         0 (  IDLE )
GWADM          00030.00100 UGWGRP       100      0         0 (  IDLE )
GWTDOMAIN      00030.00200 UGWGRP       200      1         0 (  IDLE )backup>

调用之后;

[tux@master simpapp]$ ./toupper zhoulei
Returned string is: ZHOULEI
[tux@master simpapp]$ 
backup> psr
Prog Name      Queue Name  Grp Name      ID RqDone Load Done Current Service
---------      ----------  --------      -- ------ --------- ---------------
BBL            123456      backup         0      0         0 (  IDLE )
DMADM          00020.00001 UDMGRP         1      7       350 (  IDLE )
simpserv       00001.00001 GROUP1         1      1        50 (  IDLE )
WSL            00001.00010 GROUP1        10      0         0 (  IDLE )
GWADM          00030.00100 UGWGRP       100      0         0 (  IDLE )
GWTDOMAIN      00030.00200 UGWGRP       200      1         0 (  IDLE )backup> 


最基本的tuxedo多域模式配置,仅供自己学习。学术不精,忘给位给予指点!


参考:

百度文库:http://wenku.baidu.com/view/edbd80a5b0717fd5360cdc4d.html

联动北方技术论坛:http://www.landingbj.com/jbbs/index.jsp

《叱咤风雨-Weblogic企业级运维实战》 清华大学出版社  戴冠平 著











这篇关于Tuxedo Multi-Domains 配置的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/190348

相关文章

jdk1.8的Jenkins安装配置实践

《jdk1.8的Jenkins安装配置实践》Jenkins是一款流行的开源持续集成工具,支持自动构建、测试和部署,通过Jenkins,开发团队可以实现代码提交后自动进行构建、测试,并将构建结果分发到测... 目录Jenkins介绍Jenkins环境搭建Jenkins安装配置Jenkins插件安装Git安装配

Nginx之https证书配置实现

《Nginx之https证书配置实现》本文主要介绍了Nginx之https证书配置的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起... 目录背景介绍为什么不能部署在 IIS 或 NAT 设备上?具体实现证书获取nginx配置扩展结果验证

springboot3.x使用@NacosValue无法获取配置信息的解决过程

《springboot3.x使用@NacosValue无法获取配置信息的解决过程》在SpringBoot3.x中升级Nacos依赖后,使用@NacosValue无法动态获取配置,通过引入SpringC... 目录一、python问题描述二、解决方案总结一、问题描述springboot从2android.x

nginx跨域访问配置的几种方法实现

《nginx跨域访问配置的几种方法实现》本文详细介绍了Nginx跨域配置方法,包括基本配置、只允许指定域名、携带Cookie的跨域、动态设置允许的Origin、支持不同路径的跨域控制、静态资源跨域以及... 目录一、基本跨域配置二、只允许指定域名跨域三、完整示例四、配置后重载 nginx五、注意事项六、支持

Spring配置扩展之JavaConfig的使用小结

《Spring配置扩展之JavaConfig的使用小结》JavaConfig是Spring框架中基于纯Java代码的配置方式,用于替代传统的XML配置,通过注解(如@Bean)定义Spring容器的组... 目录JavaConfig 的概念什么是JavaConfig?为什么使用 JavaConfig?Jav

Spring Boot Interceptor的原理、配置、顺序控制及与Filter的关键区别对比分析

《SpringBootInterceptor的原理、配置、顺序控制及与Filter的关键区别对比分析》本文主要介绍了SpringBoot中的拦截器(Interceptor)及其与过滤器(Filt... 目录前言一、核心功能二、拦截器的实现2.1 定义自定义拦截器2.2 注册拦截器三、多拦截器的执行顺序四、过

springboot的controller中如何获取applicatim.yml的配置值

《springboot的controller中如何获取applicatim.yml的配置值》本文介绍了在SpringBoot的Controller中获取application.yml配置值的四种方式,... 目录1. 使用@Value注解(最常用)application.yml 配置Controller 中

springboot中配置logback-spring.xml的方法

《springboot中配置logback-spring.xml的方法》文章介绍了如何在SpringBoot项目中配置logback-spring.xml文件来进行日志管理,包括如何定义日志输出方式、... 目录一、在src/main/resources目录下,也就是在classpath路径下创建logba

C++多线程开发环境配置方法

《C++多线程开发环境配置方法》文章详细介绍了如何在Windows上安装MinGW-w64和VSCode,并配置环境变量和编译任务,使用VSCode创建一个C++多线程测试项目,并通过配置tasks.... 目录下载安装 MinGW-w64下载安装VS code创建测试项目配置编译任务创建 tasks.js

Nginx概念、架构、配置与虚拟主机实战操作指南

《Nginx概念、架构、配置与虚拟主机实战操作指南》Nginx是一个高性能的HTTP服务器、反向代理服务器、负载均衡器和IMAP/POP3/SMTP代理服务器,它支持高并发连接,资源占用低,功能全面且... 目录Nginx 深度解析:概念、架构、配置与虚拟主机实战一、Nginx 的概念二、Nginx 的特点